Go Back   EQEmulator Home > EQEmulator Forums > Quests > Quests::Q&A

Quests::Q&A This is the quest support section

Reply
 
Thread Tools Display Modes
  #1  
Old 10-26-2010, 05:03 PM
Kayen
Developer
 
Join Date: Mar 2009
Location: -
Posts: 228
Default Odd bug with Damage(from, damage, spell_id, attack_skill, avoidable= true, buffslot=

Well I recently discovered why randomly scripts would break for months that seemed to make no sense ever.

We have a few scripts that utilize the damage function.
Code:
Damage(from, damage, spell_id, attack_skill, avoidable= true, buffslot= -1, iBuffTic= false)
For some reason however, when you do this function verse an NPC who has an HP Event set, it sets the HP Event to -1. Thus breaking the scripts.

Doesn't matter if a client casts it on an NPC or the NPC casts it on them selves, or NPC cast it on different NPC, result is the same $hpevent is set to -1.

Anyone have any insight on fixing this? Cause the function itself is darn useful otherwise.
Reply With Quote
  #2  
Old 11-03-2010, 09:45 PM
trevius's Avatar
trevius
Developer
 
Join Date: Aug 2006
Location: USA
Posts: 5,946
Default

This issue is very odd indeed. After reviewing the source code for the perl Damage function as well as the Damage and CommonDamage functions in attack.cpp and seeing where the HP Events get parsed as well, I cannot figure out how this issue is occurring. I don't see why the perl Damage command would be any different than any other type of damage, and I really don't see what it would have to do with setting the hp event to -1.

Here is an example script that reproduces the problem 100%:

Code:
my $nexthp = 99;

sub EVENT_SPAWN {

	quest::setnexthpevent($nexthp);

}


sub EVENT_HP {
	my $HP_RATIO_CHK = int($npc->GetHPRatio());
	quest::gmsay("Script Debug - HPEvent $hpevent, HPRatio $HP_RATIO_CHK");
	
	if ($hpevent == -1)
	{
		quest::setnexthpevent($HP_RATIO_CHK);
		$nexthp = $HP_RATIO_CHK;
		quest::gmsay("Script Debug - Correcting Next HP Event to $HP_RATIO_CHK");
	}
	
	# Set a new HP Event to occur with every 1% of NPC HP loss
	if($hpevent == $nexthp) {
		
		$nexthp = $hpevent - 1;
		quest::gmsay("Script Debug - HPEvent $hpevent, HPRatio $HP_RATIO_CHK, NextHPEvent $nexthp");
		if ($hpevent == -1)
		{
			quest::setnexthpevent($HP_RATIO_CHK);
		}
		else
		{
			quest::setnexthpevent($nexthp);
		}
	}

}


sub EVENT_AGGRO_SAY {

	if ($status > 80) {

		if($text =~ /Damage/i)
		{
			$npc->Damage($client, 1000, 0, 28, 0);
			quest::say("Damaging now");
		}

	}

}

sub EVENT_SAY {

	if ($status > 80) {

		if($text =~ /Damage/i)
		{
			$npc->Damage($client, 1000, 0, 28, 0);
			quest::say("Damaging now");
		}

	}

}
Just put that on an NPC that has 100k HPs, and say "damage" to it a few times. You can attack normally or even #damage it and the HP Events will function as they should, but as soon as you say "damage" to it, it will set $hpevent to -1.

I set this example script to automatically recover from $hpevent getting set to -1, but that isn't a real solution to the problem. This is just puzzling the heck out of me. As far as I can tell, the only times that $hpevent are set to -1 is when the NPC is first spawned and when the last quest::setnexthpevent() in the script has been used.
__________________
Trevazar/Trevius Owner of: Storm Haven
Everquest Emulator FAQ (Frequently Asked Questions) - Read It!
Reply With Quote
  #3  
Old 11-03-2010, 10:02 PM
Caryatis
Dragon
 
Join Date: May 2009
Location: Milky Way
Posts: 539
Default

possibly from this?

line 849 from mob.cpp

Code:
	// hp event 
	if ( IsNPC() && ( GetNextHPEvent() > 0 ) ) { 
		if ( ds->hp < GetNextHPEvent() ) { 
			int lasthpevent = nexthpevent;
			parse->Event(EVENT_HP, GetNPCTypeID(), 0, CastToNPC(), NULL);
			if ( lasthpevent == nexthpevent ) {
				SetNextHPEvent(-1);
			}
		} 
	}
Reply With Quote
  #4  
Old 11-03-2010, 10:48 PM
trevius's Avatar
trevius
Developer
 
Join Date: Aug 2006
Location: USA
Posts: 5,946
Default

Yeah, that is just where nexthpevent gets set to -1 if no further HP events are set when the EVENT_HP gets parsed there. It doesn't make sense why that would treat the perl Damage function different than normal damage.
__________________
Trevazar/Trevius Owner of: Storm Haven
Everquest Emulator FAQ (Frequently Asked Questions) - Read It!

Last edited by trevius; 11-03-2010 at 10:56 PM..
Reply With Quote
  #5  
Old 11-04-2010, 05:23 AM
Secrets's Avatar
Secrets
Demi-God
 
Join Date: May 2007
Location: b
Posts: 1,449
Default

Quote:
Originally Posted by trevius View Post
Yeah, that is just where nexthpevent gets set to -1 if no further HP events are set when the EVENT_HP gets parsed there. It doesn't make sense why that would treat the perl Damage function different than normal damage.
Every time an HP Packet gets sent, it sets it to -1 if it is less than the amount of HP on the mob. You could try forcing an HP update right after damaging it. If what is happening is what I think is happening, it's parsing EVENT_HP twice; once when you damage the NPC, another when the tick gets sent to the client. I think so anyway; didn't look into it more than that.

Resolving it manually or sending an HP update after doing the damage should work though.
Reply With Quote
  #6  
Old 11-04-2010, 10:07 AM
trevius's Avatar
trevius
Developer
 
Join Date: Aug 2006
Location: USA
Posts: 5,946
Default

In order for what you are describing to happen, both the regular HP update and the one caused by Damage() would have to be getting run at the exact same time. I thought about that possibility, but I highly doubt that would ever happen and certainly not with a 100% reproducibility.

From how I am reading the code, it looks like it checks if the current HP ratio is less than the nexthpevent and if so, it then parses the EVENT_HP, and then if nexthpevent wasn't changed (no nexthpevent was set in the script when it was parsed), it then (and only then) sets it to -1. Even if that were to happen, I have no idea how it would still parse an EVENT_HP with a nexthpevent of -1.

There has to be something I am missing here...
__________________
Trevazar/Trevius Owner of: Storm Haven
Everquest Emulator FAQ (Frequently Asked Questions) - Read It!
Reply With Quote
  #7  
Old 11-04-2010, 01:57 PM
Derision
Developer
 
Join Date: Feb 2004
Location: UK
Posts: 1,540
Default

This is what appears to be happening in Trevius' example:

If you call Damage from Perl, when:
Code:
	parse->Event(EVENT_HP, GetNPCTypeID(), 0, CastToNPC(), NULL);
is called from void Mob::CreateHPPacket(EQApplicationPacket* app), it gets to this point:
Code:
void PerlembParser::EventCommon(QuestEventID event, int32 objid, const char * data, NPC* npcmob, ItemInst* iteminst, Mob* mob, int32 extradata)
{
        if(!perl)
                return;

        if(event >= _LargestEventID)
                return;

        if(perl->InUse()) {
and since 'Perl is in use', executing the EVENT_SAY, the EVENT_HP is queued until the EVENT_SAY completes, therefore SetNextHPEvent is also not yet executed which means
lasthpevent == nexthpevent in the test in CreateHPPacket, leading to SetNextHPEvent(-1) being called.

As I say, the EVENT_HP is queued and should execute (along with any other queued EVENTs) once the EVENT_SAY in this example has finished.
Reply With Quote
  #8  
Old 11-05-2010, 07:32 PM
trevius's Avatar
trevius
Developer
 
Join Date: Aug 2006
Location: USA
Posts: 5,946
Default

Thanks Derision! I think that makes the most sense of anything I have seen yet. I was thinking EVENT_HP could probably have been coded better anyway, so maybe I will think on it a bit and see if I can figure out a better solution. I thought it seemed odd that the code for it would rely on a value that was supposed to be changed by perl during the function. If you are correct, probably other servers are getting bugged events that use EVENT_HP sometimes and maybe not realizing this is the cause. We use it in quite a few events on Storm Haven and some of those are out buggiest events. It would be awesome if a rewrite of how EVENT_HP is handled could resolve the random events bugs we have seen.
__________________
Trevazar/Trevius Owner of: Storm Haven
Everquest Emulator FAQ (Frequently Asked Questions) - Read It!
Reply With Quote
  #9  
Old 11-06-2010, 04:49 PM
trevius's Avatar
trevius
Developer
 
Join Date: Aug 2006
Location: USA
Posts: 5,946
Default

Thanks to Derision finding the cause of the issue, I was able to get it fixed and it is in Rev1715 on the SVN now
__________________
Trevazar/Trevius Owner of: Storm Haven
Everquest Emulator FAQ (Frequently Asked Questions) - Read It!
Reply With Quote
Reply


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 08:02 PM.


 

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