Okay, so basically, I'm trying to get a working mp_damage all and mp_restore all on my mud, but I've not yet been able to get this loop to work. Wondering if anyone here can possibly tell me which pieces of my code need to be changed.
mpdamage:
void do_mp_damage( CHAR_DATA * ch, const char *argument )
{
CHAR_DATA *vch_next;
char buf[MAX_INPUT_LENGTH];
char arg1[MAX_INPUT_LENGTH];
char arg2[MAX_INPUT_LENGTH];
CHAR_DATA *victim;
int dam;
/*if( IS_AFFECTED( ch, AFF_CHARM ) )
return; */
if( !IS_NPC( ch ) || ( ch->desc && get_trust( ch ) < LEVEL_IMMORTAL ) )
{
send_to_char( "Huh?\r\n", ch );
return;
}
argument = one_argument( argument, arg1 );
argument = one_argument( argument, arg2 );
if( arg1[0] == '\0' )
{
send_to_char( "mpdamage whom?\r\n", ch );
progbug( "Mpdamage: invalid argument1", ch );
return;
}
if( arg2[0] == '\0' )
{
send_to_char( "mpdamage inflict how many hps?\r\n", ch );
progbug( "Mpdamage: invalid argument2", ch );
return;
}
if( ( victim = get_char_room_mp( ch, arg1 ) ) == NULL )
{
send_to_char( "Victim must be in room.\r\n", ch );
//progbug( "Mpdamage: victim not in room", ch );
return;
}
if( victim == ch )
{
send_to_char( "You can't mpdamage yourself.\r\n", ch );
progbug( "Mpdamage: trying to damage self", ch );
return;
}
dam = atoi( arg2 );
if( ( dam < 0 ) || ( dam > 1000000 ) )
{
send_to_char( "Mpdamage how much?\r\n", ch );
progbug( "Mpdamage: invalid (nonexistent?) argument", ch );
return;
}
/*
* this is kinda begging for trouble
*/
/*
* Note from Thoric to whoever put this in...
* Wouldn't it be better to call damage(ch, ch, dam, dt)?
* I hate redundant code
*/
if ( !str_cmp( arg1, "all" ) )
{
for ( victim = ch->in_room->first_person; victim; victim = vch_next )
{
vch_next = victim->next_in_room;
if ( victim != ch
&& can_see( ch, victim ) ) /* Could go either way */
{
sprintf( buf, "'%s' %s", victim->name, arg2 );
do_mp_damage( ch, buf );
}
}
return;
}
if( simple_damage( ch, victim, dam, TYPE_UNDEFINED ) == rVICT_DIED )
{
stop_fighting( ch, FALSE );
stop_hating( ch );
stop_fearing( ch );
stop_hunting( ch );
}
return;
}
mprestore:
/*
* syntax: mprestore (character) (#hps) Gorog
*/
void do_mp_restore( CHAR_DATA * ch, const char *argument )
{
char arg1[MAX_INPUT_LENGTH];
char arg2[MAX_INPUT_LENGTH];
CHAR_DATA *victim;
int hp;
/*if( IS_AFFECTED( ch, AFF_CHARM ) )
return;*/
if( !IS_NPC( ch ) || ( ch->desc && get_trust( ch ) < LEVEL_IMMORTAL ) )
{
send_to_char( "Huh?\r\n", ch );
return;
}
argument = one_argument( argument, arg1 );
argument = one_argument( argument, arg2 );
if( arg1[0] == '\0' )
{
send_to_char( "mprestore whom?\r\n", ch );
progbug( "Mprestore: invalid argument1", ch );
return;
}
if( arg2[0] == '\0' )
{
send_to_char( "mprestore how many hps?\r\n", ch );
progbug( "Mprestore: invalid argument2", ch );
return;
}
if( ( victim = get_char_room_mp( ch, arg1 ) ) == NULL )
{
send_to_char( "Victim must be in room.\r\n", ch );
progbug( "Mprestore: victim not in room", ch );
return;
}
hp = atoi( arg2 );
if( ( hp < 0 ) || ( hp > 32000 ) )
{
send_to_char( "Mprestore how much?\r\n", ch );
progbug( "Mprestore: invalid (nonexistent?) argument", ch );
return;
}
hp += victim->hit;
victim->hit = ( hp > 32000 || hp < 0 || hp > victim->max_hit ) ? victim->max_hit : hp;
}
For lack of being unable to make mp_damage work for an "all" command, I haven't touched mp_restore yet. I figured if I was able to make one work, the other would follow suit after. |