Register to post in forums, or Log in to your existing account
 

Play RetroMUD
Post new topic  Reply to topic     Home » Forums » CMUD General Discussion
Securis
Newbie


Joined: 03 Nov 2010
Posts: 5

PostPosted: Sun Jan 17, 2016 10:59 pm   

Prompt trigger triggering "too soon"
 
For my MIP trigger (which I used on 3Kingdoms), in certain cases my prompt trigger triggers "too soon".
Perhaps this is best illustrated by this debug logging (newlines added for clarity):
Code:

c  3Kingdom |[1] 3Kingdoms Comline : start :
a  3Kingdom |look
j  3Kingdom >look
d  3Kingdom |[1] 3Kingdoms Comline : stopped
a  3Kingdom |
a  3Kingdom |                                                                    -O-       
a  3Kingdom |                                                                     |       
a  3Kingdom |                                                                    -O-       
a  3Kingdom |                                                                   |/| | |   
a  3Kingdom |Dark Forest (e,n,w)                                                O-@-2-1   
a  3Kingdom |                                                                  /           
a  3Kingdom |
a  3Kingdom |This part of the forest seems much darker and is much more eerie.
a  3Kingdom |You can hear the howling of wolves and the rustle of leaves. Perhaps
a  3Kingdom |you shouldn't stay here too long.
a  3Kingdom |    There are three obvious exits: east, north, west                       
a  3Kingdom ]#K%31831008DDDe~n~w#K%31831038HABnoun~forest~forest~exa #N/search #N#K%31831060HAAnpc~Wolf~Small wolf~exa #N/say hi, #N/consider #N/kill #N#K%31831060HAAnpc~Wolf~Small wolf~exa #N/say hi, #N/con


f  3Kingdom |Pattern: #K\%(?:@MIP/Vars/mipcode)(\d{3})(\a{3})(.*) : (%1=008, %2="DDD", %3="e~n~w#K%31831038HABnoun~forest~forest~exa #N/search #N#K%31831060HAAnpc~Wolf~Small wolf~exa #N/say hi, #N/consider #N/kill #N#K%31831060HAAnpc~Wolf~Small wolf~exa #N/say hi, #N/con")
c  3Kingdom |[295] 3Kingdoms Trigger : start : Pattern "prompt_miptrigger" : //(?:^)?\#K\%(?:@MIP/mipcod...
d  3Kingdom |[295] 3Kingdoms Trigger : stopped


g  3Kingdom =    There are three obvious exits: east, north, west                       
a  3Kingdom |sider #N/kill #NSmall wolf {2}.


Notice that the last line, "sider #N/kill #NSmall wolf {2}."
That should've been part of the prompt trigger. Instead, it's simply printed to the screen as is. So it seems like the prompt trigger fired earlier than I wanted it to.

This is the output with triggers turned off:
Code:

c  3Kingdom |[1] 3Kingdoms Comline : start :
a  3Kingdom |look
j  3Kingdom >look
d  3Kingdom |[1] 3Kingdoms Comline : stopped
a  3Kingdom |
a  3Kingdom |                                                                    -O-       
a  3Kingdom |                                                                     |       
a  3Kingdom |                                                                    -O-       
a  3Kingdom |                                                                   |/| | |   
a  3Kingdom |Dark Forest (e,n,w)                                                O-@-2-1   
a  3Kingdom |                                                                  /           
a  3Kingdom |
a  3Kingdom |This part of the forest seems much darker and is much more eerie.
a  3Kingdom |You can hear the howling of wolves and the rustle of leaves. Perhaps
a  3Kingdom |you shouldn't stay here too long.
a  3Kingdom |    There are three obvious exits: east, north, west                       
a  3Kingdom ]#K%31831008DDDe~n~w#K%31831038HABnoun~forest~forest~exa #N/search #N#K%31831060HAAnpc~Wolf~Small wolf~exa #N/say hi, #N/consider #N/kill #N#K%31831060HAAnpc~Wolf~Small wolf~exa #N/say hi, #N/con
a  3Kingdom |#K%31831008DDDe~n~w#K%31831038HABnoun~forest~forest~exa #N/search #N#K%31831060HAAnpc~Wolf~Small wolf~exa #N/say hi, #N/consider #N/kill #N#K%31831060HAAnpc~Wolf~Small wolf~exa #N/say hi, #N/consider #N/kill #NSmall wolf {2}.
a  3Kingdom |Hp: 256/256 Sp: 178/170 Gp1: 0 Gp2: 0

Now, the same output but only with the "Raw input/output data" logging:
Code:


i  3Kingdom <<CR><LF>
                                                                    -<ESC>[36;1mO<ESC>[0m-       <CR><LF>
                                                                     |        <CR><LF>
                                                                    -<ESC>[36;1mO<ESC>[0m-       <CR><LF>
                                                                   |/| | |    <CR><LF>
<ESC>[32;1mDark Forest (e,n,w)                                         <ESC>[0m       <ESC>[36;1mO<ESC>[0m-<ESC>[33;1m@<ESC>[0m-<ESC>[35;1m2<ESC>[0m-<ESC>[35;1m1<ESC>[0m    <CR><LF>
                                                                  /           <CR><LF><CR><LF>
<ESC>[33mThis part of the forest seems much darker and is much more eerie.<CR><LF>
You can hear the howling of wolves and the rustle of leaves. Perhaps<CR><LF>
you shouldn't stay here too long.<ESC>[0m<CR><LF>
<ESC>[33;1m    There are three obvious exits: east, north, west                       <ESC>[0m<CR><LF>
#K%31831008DDDe~n~w#K%31831038HABnoun~forest~forest~exa #N/search #N#K%31831060HAAnpc~Wolf~Small wolf~exa #N/say hi, #N/consider #N/kill #N#K%31831060HAAnpc~Wolf~Small wolf~exa #N/say hi, #N/con
i  3Kingdom <sider #N/kill #NSmall wolf {2}.<CR><LF>


What seems to happen is that Cmud receives the raw data (up until "sider #N/kill #NSmall wolf {2}.") and then receives the rest in the next buffer update.

So my question is, is there a way to 'delay' prompt triggers for a few milliseconds upon receiving data in case more is coming, or do they work only on buffer flushes?
Or is there anyone else who might have had this problem and found a (semi-) reliable way to work around it? It doesn't have to be pretty Wink

Thanks in advance!


Last edited by Securis on Sun Jan 17, 2016 11:17 pm; edited 1 time in total
Reply with quote
shalimar
GURU


Joined: 04 Aug 2002
Posts: 4715
Location: Pensacola, FL, USA

PostPosted: Sun Jan 17, 2016 11:16 pm   
 
You could account for the fact that it is on more than one line in your pattern or with another trigger state.
I don't think #WAIT is likely to help much.
_________________
Discord: Shalimarwildcat
Reply with quote
Securis
Newbie


Joined: 03 Nov 2010
Posts: 5

PostPosted: Sun Jan 17, 2016 11:18 pm   
 
Edited the post with raw session input/output data. I think that's where the problem lies.
Reply with quote
shalimar
GURU


Joined: 04 Aug 2002
Posts: 4715
Location: Pensacola, FL, USA

PostPosted: Mon Jan 18, 2016 12:01 am   
 
Show us the trigger you use to capture it.
_________________
Discord: Shalimarwildcat
Reply with quote
Securis
Newbie


Joined: 03 Nov 2010
Posts: 5

PostPosted: Mon Jan 18, 2016 6:37 am   
 
The capture regex:
Code:
#K\%(?:@MIP/mipcode)(\d{3})(\a{3})(.*)
Reply with quote
Securis
Newbie


Joined: 03 Nov 2010
Posts: 5

PostPosted: Mon Jan 18, 2016 3:45 pm   
 
As a follow up: I've confirmed that it's due to the trigger adhering to network packet boundaries.
When I capture some MUD traffic in Wireshark, I see that the network packet boundary coincides with the exact point that is excluded from the prompt trigger.
In my case, the packet's payload is 1024 bytes; everything that doesn't fit in that, is sent in a next packet.

When I eliminate some traffic (like turning off ANSI or disabling the map), everything fits within the same packet, so the triggers work perfectly.
Reply with quote
Securis
Newbie


Joined: 03 Nov 2010
Posts: 5

PostPosted: Mon Jan 18, 2016 4:47 pm   
 
Well, I've seemed to work around it reliably.

Sorry that this has turned out into a monologue, but I'll post my solution here in the hope that it might be useful for someone else in the future.

For reference, this is the "broken up" MIP string:
Code:

#K%31831060HAAnpc~Wolf~Small wolf~exa #N/say hi, #N/con
<next network buffer>
sider #N/kill #NSmall wolf {2}.

In my case, luckily, the MIP protocol contains a 'length' parameter. The '060' in the header denote that 60 characters should follow in this MIP message.
That makes it rather trivial to check if we have a "broken up" MIP message (ie. %len(mipmsg) != expectedlength).
Once such a message has been detected, I can put the message back in the screen buffer using #SHOWP, and the next time triggers are evaluated, the trigger will trigger again, this time successfully and with the complete message.
Code:

#if (%len($mipCodeAndMsg) != $miplen) {
  #SHOWP $unparsedMipString
  #CMD refresh
}


Thanks for your time, and have a good one!
Reply with quote
Display posts from previous:   
Post new topic   Reply to topic     Home » Forums » CMUD General Discussion All times are GMT
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum

© 2009 Zugg Software. Hosted by Wolfpaw.net