/***************************************************************************
* Original Diku Mud copyright (C) 1990, 1991 by Sebastian Hammer, *
* Michael Seifert, Hans Henrik St{rfeldt, Tom Madsen, and Katja Nyboe. *
* *
* Merc Diku Mud improvments 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 *
* benefitting. We hope that you share your changes too. What goes *
* around, comes around. *
***************************************************************************/
/***************************************************************************
* ROM 2.4 is copyright 1993-1995 Russ Taylor *
* ROM has been brought to you by the ROM consortium *
* Russ Taylor (rtaylor@pacinfo.com) *
* Gabrielle Taylor (gtaylor@pacinfo.com) *
* Brian Moore (rom@rom.efn.org) *
* By using this code, you have agreed to follow the terms of the *
* ROM license, in the file Rom24/doc/rom.license *
***************************************************************************/
/***************************************************************************
* ROT 1.4 is copyright 1996-1997 by Russ Walsh *
* By using this code, you have agreed to follow the terms of the *
* ROT license, in the file doc/rot.license *
***************************************************************************/
#if defined(macintosh)
#include <types.h>
#else
#include <sys/types.h>
#endif
#include <stdio.h>
#include <string.h>
#include <time.h>
#include "merc.h"
CH_CMD ( do_ignor )
{
send_to_char ( "I'm sorry, forget must be entered in full.\n\r", ch );
return;
}
CH_CMD ( do_ignore )
{
CHAR_DATA *rch;
char arg[MAX_INPUT_LENGTH], buf[MAX_STRING_LENGTH];
DESCRIPTOR_DATA *d;
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;
smash_tilde ( argument );
argument = one_argument ( argument, arg );
if ( arg[0] == '\0' )
{
if ( rch->pcdata->forget[0] == NULL )
{
send_to_char ( "You are not forgetting anyone.\n\r", ch );
return;
}
send_to_char ( "You are currently forgetting:\n\r", ch );
for ( pos = 0; pos < MAX_FORGET; pos++ )
{
if ( rch->pcdata->forget[pos] == NULL )
break;
sprintf ( buf, " %s\n\r", rch->pcdata->forget[pos] );
send_to_char ( buf, ch );
}
return;
}
for ( pos = 0; pos < MAX_FORGET; pos++ )
{
if ( rch->pcdata->forget[pos] == NULL )
break;
if ( !str_cmp ( arg, rch->pcdata->forget[pos] ) )
{
send_to_char ( "You have already forgotten that person.\n\r",
ch );
return;
}
}
for ( d = descriptor_list; d != NULL; d = d->next )
{
CHAR_DATA *wch;
if ( d->connected != CON_PLAYING || !can_see ( ch, d->character ) )
continue;
wch = ( d->original != NULL ) ? d->original : d->character;
if ( !can_see ( ch, wch ) )
continue;
if ( !str_cmp ( arg, wch->name ) )
{
found = TRUE;
if ( wch == ch )
{
send_to_char
( "You forget yourself for a moment, but it passes.\n\r",
ch );
return;
}
if ( wch->level >= LEVEL_IMMORTAL )
{
send_to_char ( "That person is very hard to forget.\n\r",
ch );
return;
}
}
}
if ( !found )
{
send_to_char ( "No one by that name is playing.\n\r", ch );
return;
}
for ( pos = 0; pos < MAX_FORGET; pos++ )
{
if ( rch->pcdata->forget[pos] == NULL )
break;
}
if ( pos >= MAX_FORGET )
{
send_to_char ( "Sorry, you have reached the forget limit.\n\r", ch );
return;
}
/* make a new forget */
rch->pcdata->forget[pos] = str_dup ( arg );
sprintf ( buf, "You are now deaf to %s.\n\r", arg );
send_to_char ( buf, ch );
}
CH_CMD ( do_remembe )
{
send_to_char ( "I'm sorry, remember must be entered in full.\n\r", ch );
return;
}
CH_CMD ( do_remember )
{
CHAR_DATA *rch;
char arg[MAX_INPUT_LENGTH], buf[MAX_STRING_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' )
{
if ( rch->pcdata->forget[0] == NULL )
{
send_to_char ( "You are not forgetting anyone.\n\r", ch );
return;
}
send_to_char ( "You are currently forgetting:\n\r", ch );
for ( pos = 0; pos < MAX_FORGET; pos++ )
{
if ( rch->pcdata->forget[pos] == NULL )
break;
sprintf ( buf, " %s\n\r", rch->pcdata->forget[pos] );
send_to_char ( buf, ch );
}
return;
}
for ( pos = 0; pos < MAX_FORGET; pos++ )
{
if ( rch->pcdata->forget[pos] == NULL )
break;
if ( found )
{
rch->pcdata->forget[pos - 1] = rch->pcdata->forget[pos];
rch->pcdata->forget[pos] = NULL;
continue;
}
if ( !str_cmp ( arg, rch->pcdata->forget[pos] ) )
{
send_to_char ( "Forget removed.\n\r", ch );
free_string ( rch->pcdata->forget[pos] );
rch->pcdata->forget[pos] = NULL;
found = TRUE;
}
}
if ( !found )
send_to_char ( "No one by that name is forgotten.\n\r", ch );
}