Go Back   EQEmulator Home > EQEmulator Forums > Development > Development::Server Code Submissions

Reply
 
Thread Tools Display Modes
  #1  
Old 01-21-2008, 05:57 AM
Knightly
Accomplished Programmer
 
Join Date: Nov 2006
Location: Honolulu, HI
Posts: 91
Default Merchant names when talking to players

When talking to players, the Merchant Name that shows up is not the version of the name with spaces so it shows up as:
Quote:
Merchant_Name0 says, "Welcome to my shop!"
The fix for that is to edit zone\client_process.cpp and change the section from:
Code:
	if(merch != NULL && handyitem){
		char handy_id[8]={0};
		int greeting=rand()%5;
		int greet_id=0;
		switch(greeting){
			case 1:
				greet_id=MERCHANT_GREETING;
				break;
			case 2:
				greet_id=MERCHANT_HANDY_ITEM1;
				break;
			case 3:
				greet_id=MERCHANT_HANDY_ITEM2;
				break;
			case 4:
				greet_id=MERCHANT_HANDY_ITEM3;
				break;
			default:
				greet_id=MERCHANT_HANDY_ITEM4;
        }
		sprintf(handy_id,"%i",greet_id);
		char merchantname[64]={0};
		strncpy(merchantname,merch->GetName(),strncpy(merchantname,merch->GetName(),strlen(merch->GetName())-2);
		if(greet_id!=MERCHANT_GREETING){
			Message_StringID(10,GENERIC_STRINGID_SAY,merchantname,handy_id,this->GetName(),handyitem->Name);
		
        }
        else
			Message_StringID(10,GENERIC_STRINGID_SAY,merchantname,handy_id,this->GetName());
		
		merch->CastToNPC()->FaceTarget(this->CastToMob());
    }
To:
Code:
	if(merch != NULL && handyitem){
		char handy_id[8]={0};
		int greeting=rand()%5;
		int greet_id=0;
		switch(greeting){
			case 1:
				greet_id=MERCHANT_GREETING;
				break;
			case 2:
				greet_id=MERCHANT_HANDY_ITEM1;
				break;
			case 3:
				greet_id=MERCHANT_HANDY_ITEM2;
				break;
			case 4:
				greet_id=MERCHANT_HANDY_ITEM3;
				break;
			default:
				greet_id=MERCHANT_HANDY_ITEM4;
        }
		sprintf(handy_id,"%i",greet_id);
		char merchantname[64]={0};
		strcpy(merchantname,merch->GetCleanName());
		if(greet_id!=MERCHANT_GREETING){
			Message_StringID(10,GENERIC_STRINGID_SAY,merchantname,handy_id,this->GetName(),handyitem->Name);
		
        }
        else
			Message_StringID(10,GENERIC_STRINGID_SAY,merchantname,handy_id,this->GetName());
		
		merch->CastToNPC()->FaceTarget(this->CastToMob());
    }
Now when Merchants offer up things it will be:
Quote:
Merchant Name says, "Welcome to my shop!"
There is one condition that the code above does not account for and that is the situation where a Merchant's name is longer than 64 characters. I just assumed that forcing the Merchant's name under 64 characters had to do with the size of the packet struct required to push that information which would mean that there are no merchants with names longer than 64 characters, in which case the issue is moot.

However, if you do have merchants with names longer than 64 characters then that specific merchant just won't say anything. The reason for this is because you can't copy something longer than 64 characters into something that is 64 characters, so the code doesn't work at that point, but it does continue and does not crash, so the merchant just skips what he would have said. If you're concerned about this, the way to fix it is to calculate the length of the string generated by merch->GetCleanName() and if it is longer than 64 characters use strncpy to chop it to 64 characters, otherwise use the function I've changed above. I wasn't that industrious.
Reply With Quote
  #2  
Old 01-23-2008, 03:06 AM
cavedude's Avatar
cavedude
The PEQ Dude
 
Join Date: Apr 2003
Location: -
Posts: 1,988
Default

Hmmm this was merged into the official code and it is working very nicely. Such a small but extremely nice change. However, certain NPCs will no longer say anything, specifically all of the Necromancer merchants in Paineel. 'Linnleu_Brackmar Necromancer Supplies' is one example. I don't think the lastname is used, but even if it is as you can see it is still under 64 characters in length.

Now, oddly in the same area the guildmasters all do work. 'Coriante_Verisue Necromancer Guildmaster' as example does use her proper text.

I went through other cities, and had no problem with their merchants and they all had a nice clean name

Not a big deal, as most don't even look at the text anyway I'm sure, and since it probably is a minority of NPCs anyway who really cares. I was just letting you know about it in case you can stumble upon the problem.
Reply With Quote
  #3  
Old 01-23-2008, 09:14 PM
Knightly
Accomplished Programmer
 
Join Date: Nov 2006
Location: Honolulu, HI
Posts: 91
Default

The guildmaster code is in a different area, so this wouldn't have affected that.

I loaded up an older version of the emu and found that I couldn't get the Paineel merchants to talk to me before the change above. I thought at first it had something to do with the handyitem, but I'm not sure now that it is the case.

I probably won't really get around to looking at it any time soon, but thank you for letting me know so that I have NPCs to test with if I happen to see the problem.
Reply With Quote
Reply

Thread Tools
Display Modes

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off

Forum Jump

   

All times are GMT -4. The time now is 10:14 AM.


 

Everquest is a registered trademark of Daybreak Game Company LLC.
EQEmulator is not associated or affiliated in any way with Daybreak Game Company LLC.
Except where otherwise noted, this site is licensed under a Creative Commons License.
       
Powered by vBulletin®, Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Template by Bluepearl Design and vBulletin Templates - Ver3.3