summaryrefslogtreecommitdiff
path: root/world/map/npc/009-7/rouge.txt
diff options
context:
space:
mode:
authorWushin <pasekei@gmail.com>2014-11-14 00:26:49 -0600
committerWushin <pasekei@gmail.com>2014-11-14 00:26:49 -0600
commit39ccb932b39ec342ce940fc990ed09052f81b7eb (patch)
treed532de9fd8fffe36fc1aa6b421ba0a6de5676c05 /world/map/npc/009-7/rouge.txt
parent10846f235e6c3a531f1b4691785556b5d5ac68cd (diff)
parent29ddbded7eb9666df30e67f25fcbee467bbd124f (diff)
downloadserverdata-39ccb932b39ec342ce940fc990ed09052f81b7eb.tar.gz
serverdata-39ccb932b39ec342ce940fc990ed09052f81b7eb.tar.bz2
serverdata-39ccb932b39ec342ce940fc990ed09052f81b7eb.tar.xz
serverdata-39ccb932b39ec342ce940fc990ed09052f81b7eb.zip
Merge pull request #203 from mekolat/fightclub-fix
Fightclub fix
Diffstat (limited to 'world/map/npc/009-7/rouge.txt')
-rw-r--r--world/map/npc/009-7/rouge.txt21
1 files changed, 16 insertions, 5 deletions
diff --git a/world/map/npc/009-7/rouge.txt b/world/map/npc/009-7/rouge.txt
index bf872566..c8c4dfaa 100644
--- a/world/map/npc/009-7/rouge.txt
+++ b/world/map/npc/009-7/rouge.txt
@@ -11,10 +11,11 @@ L_CallDebug:
goto L_Main;
L_Main:
- mes "[Rouge]";
+ set @requests, 0;
if(@Duel_Queue$[0] != "") goto L_Queue;
+ mes "[Rouge]";
mes "Welcome to the Sanguine Vault's duel arena.";
- if(($fightclub_enabled % 5) != 3) goto L_Disabled;
+ if($SANGUINE & $@SV_FCDBit != 0) goto L_Disabled;
mes "What do you want to do?";
menu
"See the commands.", L_Challenge,
@@ -25,7 +26,13 @@ L_Queue:
set @caster_name$, @Duel_Queue$[0];
set @target_name$, strcharinfo(0);
set @target, getcharid(3, @caster_name$);
+ set $@my_rid, getcharid(3);
set @Duel_Queue$[0], "";
+ if(attachrid(@target) != 1) goto L_Missing;
+ if(getmap() != "009-7") goto L_Missing;
+ if(attachrid($@my_rid) != 1) goto L_End;
+ set @requests, (@requests + 1);
+ set $@my_rid, 0; // clean this ASAP
mes @caster_name$ + " wishes to challenge you to a duel.";
mes "";
callfunc "fightclub_getrules";
@@ -37,6 +44,7 @@ L_Queue:
"No.", L_Decline;
L_ShiftQueue: // here we shift the array to the left
+ if((@Duel_Queue$[@loop] == "" ) && (@requests < 1)) goto L_Main;
if(@Duel_Queue$[@loop] == "") goto L_End;
set @Duel_Queue$[(@loop - 1)], @Duel_Queue$[@loop];
set @Duel_Queue$[@loop], "";
@@ -46,17 +54,20 @@ L_ShiftQueue: // here we shift the array to the left
L_Accept:
callfunc "fightclub_AddToQueue";
- message @caster_name$, @target_name$ + " Accepted your offer.";
set @loop, 1;
goto L_ShiftQueue;
L_Decline:
- message @caster_name$, @target_name$ + " turned down your offer.";
set @loop, 1;
goto L_ShiftQueue;
+L_Missing:
+ if(attachrid($@my_rid) != 1) goto L_End;
+ set $@my_rid, 0; // clean this ASAP
+ goto L_Decline;
+
L_Challenge:
- if(($fightclub_enabled % 5) != 3) goto L_Disabled;
+ if($SANGUINE & $@SV_FCDBit != 0) goto L_Disabled;
next;
mes "[Rouge]";
mes "To challenge a player to a duel, you need to write this command:";