Go Back   EQEmulator Home > EQEmulator Forums > Development > Development::Bug Reports

Development::Bug Reports Post detailed bug reports and what you would like to see next in the emu here.

 
 
Thread Tools Display Modes
Prev Previous Post   Next Post Next
  #1  
Old 05-01-2012, 07:23 AM
Uleat's Avatar
Uleat
Developer
 
Join Date: Apr 2012
Location: North Carolina
Posts: 2,815
Default Ranger tracking skillups after tracking session expires

I've been experiencing a rather odd bug with my SoF client.

I'm receiving Ranger Tracking skillups after the tracking sessions times out. After a normal amount of tracking time, and the mob is not killed, I receive the message defined by TRACK_LOST_TARGET. After that, I'm still getting random skillups.

What I would normally do is 'track' a non-specific mob, then go about killing in a random manner - never killing the original track mob. I haven't played it out to see if killing the original mob will stop these skillups, but I can if it's needed. Camping out or zoning stops this activity. This is a repeatable bug and the last occurrence was in "The Umbral Plains" with my GM flag on, but it has happened in the past in different zones and non-flagged..as well as on previous revision builds.


I've looked through the code and noticed that Client:oTracking() (client_process.cpp) is triggered if the client version is SoD or greater. I've also found that the skillup sequence is handled in Client::Handle_OP_ClientUpdate (client_packet.cpp.) Since I couldn't find a function that enabled/disabled the [TrackingTimer] in the server code, I'm guessing that all tracking events are initiated by the client.

I can't figure out if the tracking session cancellation is a server- or client-side event, but something seems to be cancelling it without releasing the client-side TrackingID.


I have a few scenarios of what could be happening, but none may be true:

1) The client or server cancels the tracking session after ## minutes and the client needs to receive a command to clear its TrackingID, but isn't and continues to resend it (though I'm not getting continuous TRACK_LOST_TARGET messages from Client:oTracking(), just the one..assuming that it's a server-side event trigger. I placed Message(#, "$$$") markers in the DoTracking() sub and never received them, and since my client is pre-SoD, they probably weren't being processed.)

2) Or, maybe that the packet handler's buffer isn't being cleared of the client packet's TrackingID value and that it is still being processed by the IsTracking() function for skillup, but since it's not actually being sent by the client, it doesn't register in the packet stream and isn't raising the tracking event flag. (Again, a guess since I'm learning that the tracking subroutines are probably client-side for SoF.)

3) Assuming that the TrackingID value is received from the client for pre-SoD, is it possible that the client IsTracking is being set to false, but TrackingID isn't cleared and is continuously being sent back to the server and being processed by Client::Handle_OP_ClientUpdate?

4) All of the above. (If in doubt, always choose 'C', err, I mean '4'!)

I'll go back and review those code segments again, looking at it from a client-side event perspective, and see if I can help you guys out with this. (Probably won't amount to much, but anything is better than nothing.)

(For all I know, this could be a non-patched "SoF" client bug...)


If I didn't explain the bug scenario well enough, please ask for clarification.


Current Specs:
-------------
2.6 GHz P4 (no HT)
32-bit WinXP SP3
2GB Ram
---
EmuLoginServer rev2135 compiled on VC10 (Release/Win32; converted VC9 EQEmuLoginServer.sln - *testing*)
Emu rev2135 compiled on VC10 (ReleaseBots/Win32)
PEQ rev2133
MySQL 5.1.62-win32
Perl 5.12.4.1205-win32
Zlib 1.2.3 (I know I should update to the SVN's)
---
"SoF" EQ Client
"non-SoD" opcodes (login & emu_config)
-------------


U
__________________
Uleat of Bertoxxulous

Compilin' Dirty

Last edited by Uleat; 05-01-2012 at 07:35 AM.. Reason: Oops..TrackingID, not TargetID
Reply With Quote
 

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 11:28 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