/************************************************************************** * Original Diku Mud copyright (C) 1990, 1991 by Sebastian Hammer, * * Michael Seifert, Hans Henrik St{rfeldt, Tom Madsen, and Katja Nyboe. * * * * Merc Diku Mud improvements copyright (C) 1992, 1993 by Michael * * Chastain, Michael Quan, and Mitchell Tse. * * * * In order to use any part of this Merc Diku Mud, you must comply with * * both the original Diku license in 'license.doc' as well the Merc * * license in 'license.txt'. In particular, you may not remove either of * * these copyright notices. * * * * Much time and thought has gone into this software and you are * * benefiting. We hope that you share your changes too. What goes * * around, comes around. * *************************************************************************** * ROM 2.4 is copyright 1993-1998 Russ Taylor * * ROM has been brought to you by the ROM consortium * * Russ Taylor (rtaylor@hypercube.org) * * Gabrielle Taylor (gtaylor@hypercube.org) * * Brian Moore (zump@rom.org) * * By using this code, you have agreed to follow the terms of the * * ROM license, in the file Rom24/doc/rom.license * *************************************************************************** * 1stMUD ROM Derivative (c) 2001-2002 by Ryan Jennings * * http://1stmud.dlmud.com/ <r-jenn@shaw.ca> * ***************************************************************************/ #include <sys/types.h> #include <stdio.h> #include <string.h> #include <time.h> #include "merc.h" #include "interp.h" /* does aliasing and other fun stuff */ void substitute_alias (DESCRIPTOR_DATA * d, char *argument) { CHAR_DATA *ch; char buf[MAX_STRING_LENGTH], prefix[MAX_INPUT_LENGTH], name[MAX_INPUT_LENGTH]; const char *point; int alias; ch = d->original ? d->original : d->character; /* check for prefix */ if (ch->prefix[0] != '\0' && str_prefix ("prefix", argument)) { if (strlen (ch->prefix) + strlen (argument) > MAX_INPUT_LENGTH) chprintln (ch, "Line to long, prefix not processed."); else { sprintf (prefix, "%s %s", ch->prefix, argument); argument = prefix; } } if (IS_NPC (ch) || ch->pcdata->alias[0] == NULL || !str_prefix ("alias", argument) || !str_prefix ("una", argument) || !str_prefix ("prefix", argument)) { interpret (d->character, argument); return; } strcpy (buf, argument); for (alias = 0; alias < MAX_ALIAS; alias++) /* go through the aliases */ { if (ch->pcdata->alias[alias] == NULL) break; if (!str_prefix (ch->pcdata->alias[alias], argument)) { point = one_argument (argument, name); if (!strcmp (ch->pcdata->alias[alias], name)) { buf[0] = '\0'; strcat (buf, ch->pcdata->alias_sub[alias]); strcat (buf, " "); strcat (buf, point); if (strlen (buf) > MAX_INPUT_LENGTH - 1) { chprintln (ch, "Alias substitution too long. Truncated."); buf[MAX_INPUT_LENGTH - 1] = '\0'; } break; } } } interpret (d->character, buf); } CH_CMD (do_alia) { chprintln (ch, "I'm sorry, alias must be entered in full."); return; } CH_CMD (do_alias) { CHAR_DATA *rch; char arg[MAX_INPUT_LENGTH]; int pos; smash_tilde (argument); if (ch->desc == NULL) rch = ch; else rch = ch->desc->original ? ch->desc->original : ch; if (IS_NPC (rch)) return; argument = one_argument (argument, arg); if (arg[0] == '\0') { if (rch->pcdata->alias[0] == NULL) { chprintln (ch, "You have no aliases defined."); return; } chprintln (ch, "Your current aliases are:"); for (pos = 0; pos < MAX_ALIAS; pos++) { if (rch->pcdata->alias[pos] == NULL || rch->pcdata->alias_sub[pos] == NULL) break; chprintlnf (ch, " %s: %s", rch->pcdata->alias[pos], rch->pcdata->alias_sub[pos]); } return; } if (!str_prefix ("una", arg) || !str_cmp ("alias", arg)) { chprintln (ch, "Sorry, that word is reserved."); return; } if (argument[0] == '\0') { for (pos = 0; pos < MAX_ALIAS; pos++) { if (rch->pcdata->alias[pos] == NULL || rch->pcdata->alias_sub[pos] == NULL) break; if (!str_cmp (arg, rch->pcdata->alias[pos])) { chprintlnf (ch, "%s aliases to '%s'.", rch->pcdata->alias[pos], rch->pcdata->alias_sub[pos]); return; } } chprintln (ch, "That alias is not defined."); return; } if (!str_prefix (argument, "delete") || !str_prefix (argument, "prefix")) { chprintln (ch, "That shall not be done!"); return; } for (pos = 0; pos < MAX_ALIAS; pos++) { if (rch->pcdata->alias[pos] == NULL) break; if (!str_cmp (arg, rch->pcdata->alias[pos])) /* redefine an alias */ { free_string (rch->pcdata->alias_sub[pos]); rch->pcdata->alias_sub[pos] = str_dup (argument); chprintlnf (ch, "%s is now realiased to '%s'.", arg, argument); return; } } if (pos >= MAX_ALIAS) { chprintln (ch, "Sorry, you have reached the alias limit."); return; } /* make a new alias */ rch->pcdata->alias[pos] = str_dup (arg); rch->pcdata->alias_sub[pos] = str_dup (argument); chprintlnf (ch, "%s is now aliased to '%s'.", arg, argument); } CH_CMD (do_unalias) { CHAR_DATA *rch; char arg[MAX_INPUT_LENGTH]; int pos; bool found = FALSE; if (ch->desc == NULL) rch = ch; else rch = ch->desc->original ? ch->desc->original : ch; if (IS_NPC (rch)) return; argument = one_argument (argument, arg); if (arg[0] == '\0') { chprintln (ch, "Unalias what?"); return; } for (pos = 0; pos < MAX_ALIAS; pos++) { if (rch->pcdata->alias[pos] == NULL) break; if (found) { rch->pcdata->alias[pos - 1] = rch->pcdata->alias[pos]; rch->pcdata->alias_sub[pos - 1] = rch->pcdata->alias_sub[pos]; rch->pcdata->alias[pos] = NULL; rch->pcdata->alias_sub[pos] = NULL; continue; } if (!strcmp (arg, rch->pcdata->alias[pos])) { chprintln (ch, "Alias removed."); free_string (rch->pcdata->alias[pos]); free_string (rch->pcdata->alias_sub[pos]); rch->pcdata->alias[pos] = NULL; rch->pcdata->alias_sub[pos] = NULL; found = TRUE; } } if (!found) chprintln (ch, "No alias of that name to remove."); }