Login
User Name:

Password:



Register
Forgot your password?
Vote for Us!
auth_update crash
Dec 23, 2017, 10:15 pm
By Remcon
check_tumble
Dec 18, 2017, 7:21 pm
By Remcon
parse description bug
Dec 15, 2017, 10:08 pm
By Remcon
Couple bugs
Dec 12, 2017, 5:42 pm
By Remcon
Bug in disarm( )
Nov 12, 2017, 6:54 pm
By GatewaySysop
LoP 1.46
Author: Remcon
Submitted by: Remcon
LOP 1.45
Author: Remcon
Submitted by: Remcon
LOP Heroes Edition
Author: Vladaar
Submitted by: Vladaar
Heroes sound extras
Author: Vladaar
Submitted by: Vladaar
6Dragons 4.3
Author: Vladaar
Submitted by: Vladaar
Users Online
CommonCrawl, Google, DotBot, Bing

Members: 0
Guests: 10
Stats
Files
Topics
Posts
Members
Newest Member
478
3,708
19,242
612
Jacki72H
Today's Birthdays
There are no member birthdays today.
Related Links
» SmaugMuds.org » Bugfix Lists » LoP Bugfix List » nifty_is_name issue
Forum Rules | Mark all | Recent Posts

nifty_is_name issue
< Newer Topic :: Older Topic >

Pages:<< prev 1 next >>
Post is unread #1 Jan 27, 2012, 6:20 pm
Go to the top of the page
Go to the bottom of the page

Remcon
Geomancer
GroupAdministrators
Posts1,868
JoinedJul 26, 2005

The old nifty_is_name seems to not work like it should in some cases.
Take an exit and set it with the keywords 'Iron Gate' (Since you want it to show iron gate when opening, closing etc...)
If you don't put the 's around it, then iron and gate will work, but it will only show iron when opening, closing etc...
After you do that flag the exit as isdoor and closed and then try the keywords iron, gate, iron gate, 'iron gate' and none of them will work...

After taking a bit of time to play around with nifty_is_name I suggest making it look like this:
/* Checks if str is a name in namelist supporting multiple keywords - Thoric */
bool nifty_is_name( char *str, char *namelist )
{
   char name[MIL], strname[MIL];

   /* Exact match is good */
   if( str && str[0] != '\0' && namelist && namelist[0] != '\0' )
   {
      if( is_name2( str, namelist ) )
         return true;
   }

   while( namelist && namelist[0] != '\0' )
   {
      namelist = one_argument2( namelist, name );

      while( str && str[0] != '\0' )
      {
         str = one_argument2( str, strname );
         if( is_name2( strname, name ) )
            return true;
      }
   }
   return false;
}

After doing so it makes 'iron gate', iron, gate all work.
       
Pages:<< prev 1 next >>