summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--npc/battleground/bg_common.txt382
-rw-r--r--npc/battleground/kvm/kvm_enter.txt40
-rw-r--r--npc/quests/thana_quest.txt130
3 files changed, 82 insertions, 470 deletions
diff --git a/npc/battleground/bg_common.txt b/npc/battleground/bg_common.txt
index 1e4f5b364..6997187fb 100644
--- a/npc/battleground/bg_common.txt
+++ b/npc/battleground/bg_common.txt
@@ -3,21 +3,22 @@
//===== By: ==================================================
//= ????, L0ne_W0lf
//===== Current Version: =====================================
-//= 1.1
+//= 1.3
//===== Compatible With: =====================================
//= rAthena 1.0
//===== Description: =========================================
//= [AEGIS Conversion]
-//= Battleground npcs:
+//= Battleground NPCs:
//= - Generals and Aides
-//= - Battlegroun Warper
+//= - Battleground Warper
//= - Kafra and Repairman.
-//= - GM Management NPC (Disabled by default)
-//= - Badge Exhanger (Tierra and Flavius.)
+//= - GM Management NPC (disabled by default)
+//= - Badge Exchanger (Tierra and Flavius)
//===== Additional Comments: =================================
//= 1.0 First Version.
//= 1.1 Updated several NPCs to Official.
//= 1.2 Updated Repairman NPC
+//= 1.3 Optimized "Erundek" NPC. [Euphy]
//============================================================
// Generals
@@ -406,219 +407,70 @@ bat_room,160,150,3 script Erundek 109,{
mes "[Erundek]";
mes "The following items are available in the ^3131FFDagger, One-Handed Sword, Two-Handed Sword, and Two-Handed Spear^000000 category.";
next;
- switch(select("Brave Assassin's Damascus(BB):Valorous Assassin's Damascus(VB):Brave Gladiator's Blade(BB):Valorous Gladiator's Blade(VB):Brave Assaulter's Katzbalger(BB):Valorous Assaulters's Katzbalger(VB):Assaulter Spear(BB):Assaulter Lance(VB)")) {
- case 1:
- setarray .@cost[0],7828,100; //BF_Badge1
- setarray .@item[0],13036,1; //BF_Dagger1
- break;
- case 2:
- setarray .@cost[0],7829,100; //BF_Badge2
- setarray .@item[0],13037,1; //BF_Dagger2
- break;
- case 3:
- setarray .@cost[0],7828,100; //BF_Badge1
- setarray .@item[0],13411,1; //BF_Sword2
- break;
- case 4:
- setarray .@cost[0],7829,100; //BF_Badge2
- setarray .@item[0],13410,1; //BF_Sword1
- break;
- case 5:
- setarray .@cost[0],7828,100; //BF_Badge1
- setarray .@item[0],1183,1; //BF_Two_Handed_Sword1
- break;
- case 6:
- setarray .@cost[0],7829,100; //BF_Badge2
- setarray .@item[0],1184,1; //BF_Two_Handed_Sword2
- break;
- case 7:
- setarray .@cost[0],7828,100; //BF_Badge1
- setarray .@item[0],1425,1; //BF_Spear1
- break;
- case 8:
- setarray .@cost[0],7829,100; //BF_Badge2
- setarray .@item[0],1482,1; //BF_Lance1
- break;
- }
+ setarray .@Weapons[0],13036,7828,13037,7829,13411,7828,13410,7829,1183,7828,1184,7829,1425,7828,1482,7829;
break;
case 2:
mes "[Erundek]";
mes "The following items are available in the ^3131FFStaff / Mace / Two-Handed Axe / Huuma Shuriken^000000 category.";
next;
- switch(select("Warlock's Magic Wand(BB):Warlock's Battle Wand(VB):Strong Recovery Wand:Speedy Recovery Wand:Brave Battlefield Morning Star(BB):Valorous Battlefield Morning Star(VB):Insane Battle Axe(BB):Insane Battle Axe(VB):Brave Huuma Front Shuriken(BB):Valorous Huuma Front Shuriken(VB)")) {
- case 1:
- setarray .@cost[0],7828,100; //BF_Badge1
- setarray .@item[0],1632,1; //BF_Staff1
- break;
- case 2:
- setarray .@cost[0],7829,100; //BF_Badge2
- setarray .@item[0],1633,1; //BF_Staff2
- break;
- case 3:
- setarray .@cost[0],7828,100; //BF_Badge1
- setarray .@item[0],1634,1; //BF_Staff3
- break;
- case 4:
- setarray .@cost[0],7829,100; //BF_Badge2
- setarray .@item[0],1635,1; //BF_Staff4
- break;
- case 5:
- setarray .@cost[0],7828,100; //BF_Badge1
- setarray .@item[0],1543,1; //BF_Morning_Star2
- break;
- case 6:
- setarray .@cost[0],7829,100; //BF_Badge2
- setarray .@item[0],1542,1; //BF_Morning_Star1
- break;
- case 7:
- setarray .@cost[0],7828,100; //BF_Badge1
- setarray .@item[0],1380,1; //BF_Two_Handed_Axe2
- break;
- case 8:
- setarray .@cost[0],7829,100; //BF_Badge2
- setarray .@item[0],1379,1; //BF_Two_Handed_Axe1
- break;
- case 9:
- setarray .@cost[0],7828,100; //BF_Badge1
- setarray .@item[0],13305,1; //BF_Huuma_Shuriken1
- break;
- case 10:
- setarray .@cost[0],7829,100; //BF_Badge2
- setarray .@item[0],13306,1; //BF_Huuma_Shuriken2
- break;
- }
+ setarray .@Weapons[0],1632,7828,1633,7829,1634,7828,1635,7829,1543,7828,1542,7829,1380,7828,1379,7829,13305,7828,13306,7829;
break;
case 3:
mes "[Erundek]";
mes "The following weapons are available in the ^3131FFBow / Katar / Musical Instrument / Whip^000000 category.";
next;
- switch(select("Brave Battle CrossBow(BB):Valorous Battle CrossBow(VB):Brave Carnage Katar(BB):Valorous Carnage Katar(VB):Brave Battlefield Guitar(BB):Valorous Battlefield Guitar(VB):Brave Battle Lariat(BB):Valorous Battle Lariat(VB)")) {
- case 1:
- setarray .@cost[0],7828,100; //BF_Badge1
- setarray .@item[0],1739,1; //BF_Bow2
- break;
- case 2:
- setarray .@cost[0],7829,100; //BF_Badge2
- setarray .@item[0],1738,1; //BF_Bow1
- break;
- case 3:
- setarray .@cost[0],7828,100; //BF_Badge1
- setarray .@item[0],1279,1; //BF_Katar1
- break;
- case 4:
- setarray .@cost[0],7829,100; //BF_Badge2
- setarray .@item[0],1280,1; //BF_Katar2
- break;
- case 5:
- setarray .@cost[0],7828,100; //BF_Badge1
- setarray .@item[0],1924,1; //BF_Instrument2
- break;
- case 6:
- setarray .@cost[0],7829,100; //BF_Badge2
- setarray .@item[0],1923,1; //BF_Instrument1
- break;
- case 7:
- setarray .@cost[0],7828,100; //BF_Badge1
- setarray .@item[0],1978,1; //BF_Whip2
- break;
- case 8:
- setarray .@cost[0],7829,100; //BF_Badge2
- setarray .@item[0],1977,1; //BF_Whip1
- break;
- }
+ setarray .@Weapons[0],1739,7828,1738,7829,1279,7828,1280,7829,1924,7828,1923,7829,1978,7828,1977,7829;
break;
case 4:
mes "[Erundek]";
mes "The following weapons are available in the ^3131FFBook / Knuckle^000000 category.";
next;
- switch(select("Brave Battle Strategy Book(BB):Valorous Battle Strategy Book(VB):Brave Battle Fist(BB):Valorous Battle Fist(VB)")) {
- case 1:
- setarray .@cost[0],7828,100; //BF_Badge1
- setarray .@item[0],1574,1; //BF_Book1
- break;
- case 2:
- setarray .@cost[0],7829,100; //BF_Badge2
- setarray .@item[0],1575,1; //BF_Book2
- break;
- case 3:
- setarray .@cost[0],7828,100; //BF_Badge1
- setarray .@item[0],1824,1; //BF_Knuckle2
- break;
- case 4:
- setarray .@cost[0],7829,100; //BF_Badge2
- setarray .@item[0],1823,1; //BF_Knuckle1
- break;
- }
+ setarray .@Weapons[0],1574,7828,1575,7829,1824,7828,1823,7829;
break;
case 5:
mes "[Erundek]";
mes "The following weapons are available in the ^3131FFRevolver / Rifle / Gatling Gun / Shotgun / Grenade Launcher^000000 category.";
next;
- switch(select("Soldier Revolver:Soldier Rifle:Soldier Gatling Gun:Soldier Shotgun:Soldier Grenade Launcher")) {
- case 1:
- setarray .@cost[0],7828,100; //BF_Badge1
- setarray .@item[0],13108,1; //BF_Pistol1
- break;
- case 2:
- setarray .@cost[0],7829,100; //BF_Badge2
- setarray .@item[0],13171,1; //BF_Rifle1
- break;
- case 3:
- setarray .@cost[0],7828,100; //BF_Badge1
- setarray .@item[0],13172,1; //BF_Gatling_Gun1
- break;
- case 4:
- setarray .@cost[0],7829,100; //BF_Badge2
- setarray .@item[0],13173,1; //BF_Shotgun1
- break;
- case 5:
- setarray .@cost[0],7829,100; //BF_Badge2
- setarray .@item[0],13174,1; //BF_Launcher1
- break;
- }
+ setarray .@Weapons[0],13108,7828,13171,7829,13172,7828,13173,7829,13174,7829;
break;
}
- if (.@cost[0] == 7829)
- set .@type$,"(VB)";
- else
- set .@type$,"(BB)";
+ set .@menu$,"";
+ for(set .@i,0; .@i<getarraysize(.@Weapons); set .@i,.@i+2)
+ set .@menu$, .@menu$+getitemname(.@Weapons[.@i])+((.@Weapons[.@i+1]==7828)?"(BB)":"(VB)")+":";
+ set .@i, (select(.@menu$)-1)*2;
+ set .@type$, ((.@Weapons[.@i+1]==7828)?"(BB)":"(VB)");
mes "[Erundek]";
- mes "You chose ^3131FF"+getitemname(.@item[0])+""+.@type$+"^000000.";
- mes "You can exchange for this item with ^FF0000"+.@cost[1]+" "+getitemname(.@cost[0])+"^000000.";
+ mes "You chose ^3131FF"+getitemname(.@Weapons[.@i])+.@type$+"^000000.";
+ mes "You can exchange for this item with ^FF0000100 "+getitemname(.@Weapons[.@i+1])+"^000000.";
mes "Would you like to exchange?";
next;
switch(select("Do not exchange:Exchange")) {
case 1:
- mes "[Erundek]";
- mes "Do you need more time to check the items?";
break;
case 2:
mes "[Erundek]";
- mes "Would you like to spend ^FF0000"+.@cost[1]+" "+getitemname(.@cost[0])+"^000000 and receive an ^3131FF"+getitemname(.@item[0])+""+.@type$+"^000000?";
+ mes "Would you like to spend ^FF0000100 "+getitemname(.@Weapons[.@i+1])+"^000000 and receive a ^3131FF"+getitemname(.@Weapons[.@i])+.@type$+"^000000?";
next;
mes "[Erundek]";
mes "Remember, Battleground Reward Items are ^FF0000Character Bound^000000. Are you sure you want this item?";
next;
switch(select("Yes:No")) {
case 1:
- if (countitem(.@cost[0]) >= .@cost[1]) {
- mes "[Erundek]";
+ mes "[Erundek]";
+ if (countitem(.@Weapons[.@i+1]) >= 100) {
mes "Thank you for exchanging.";
- delitem .@cost[0],.@cost[1];
- getitem .@item[0],.@item[1];
- }
- else {
- mes "[Erundek]";
- mes "I'm sorry, but you don't have enough badges to exchange.";
+ delitem .@Weapons[.@i+1],100;
+ getitem .@Weapons[.@i],1;
}
- break;
+ else mes "I'm sorry, but you don't have enough badges to exchange.";
+ close;
case 2:
- mes "[Erundek]";
- mes "Do you need more time to check out the items?";
break;
}
break;
}
+ mes "[Erundek]";
+ mes "Do you need more time to check the items?";
close;
case 2:
mes "[Erundek]";
@@ -627,64 +479,10 @@ bat_room,160,150,3 script Erundek 109,{
next;
switch(select("Garments / Shoes:Armor")) {
case 1:
- switch(select("Captain's Manteau:Commander's Manteau:Sheriff's Manteau:Battle Greave:Combat Boots:Battle Boots")) {
- case 1:
- setarray .@cost[0],7828,50,7829,50; //BF_Badge1
- setarray .@item[0],2538,1; //Commander_Manteau
- break;
- case 2:
- setarray .@cost[0],7828,50,7829,50; //BF_Badge1
- setarray .@item[0],2539,1; //Commander_Manteau_
- break;
- case 3:
- setarray .@cost[0],7828,50,7829,50; //BF_Badge1
- setarray .@item[0],2540,1; //Sheriff_Manteau
- break;
- case 4:
- setarray .@cost[0],7828,50,7829,50; //BF_Badge1
- setarray .@item[0],2435,1; //Battle_Greave
- break;
- case 5:
- setarray .@cost[0],7828,50,7829,50; //BF_Badge1
- setarray .@item[0],2436,1; //Combat_Boots
- break;
- case 6:
- setarray .@cost[0],7828,50,7829,50; //BF_Badge1
- setarray .@item[0],2437,1; //Battle_Boots
- break;
- }
+ setarray .@Items[0],2538,50,2539,50,2540,50,2435,50,2436,50,2437,50;
break;
case 2:
- switch(select("Assaulter Plate:Elite Engineer Armor:Assassin Robe:Warlock's Battle Robe:Medic's Robe:Elite Archer Suit:Elite Shooter Suit")) {
- case 1:
- setarray .@cost[0],7828,80,7829,80; //BF_Badge1
- setarray .@item[0],2376,1; //Assaulter_Plate
- break;
- case 2:
- setarray .@cost[0],7828,80,7829,80; //BF_Badge1
- setarray .@item[0],2377,1; //Elite_Engineer_Armor
- break;
- case 3:
- setarray .@cost[0],7828,80,7829,80; //BF_Badge1
- setarray .@item[0],2378,1; //Assassin_Robe
- break;
- case 4:
- setarray .@cost[0],7828,80,7829,80; //BF_Badge1
- setarray .@item[0],2379,1; //Warlock_Battle_Robe
- break;
- case 5:
- setarray .@cost[0],7828,80,7829,80; //BF_Badge1
- setarray .@item[0],2380,1; //Medic_Robe
- break;
- case 6:
- setarray .@cost[0],7828,80,7829,80; //BF_Badge1
- setarray .@item[0],2381,1; //Elite_Archer_Suit
- break;
- case 7:
- setarray .@cost[0],7828,80,7829,80; //BF_Badge1
- setarray .@item[0],2382,1; //Elite_Shooter_Suit
- break;
- }
+ setarray .@Items[0],2376,80,2377,80,2378,80,2379,80,2380,80,2381,80,2382,80;
break;
}
break;
@@ -693,64 +491,15 @@ bat_room,160,150,3 script Erundek 109,{
mes "You chose ^3131FFAccessory^000000.";
mes "You can exchange the Medal of Honors with your Badges according to the job classes, as follows:";
next;
- switch(select("Gunslinger:Swordman/Taekwon Master:Thief:Acolyte:Magician:Archer:Merchant")) {
- case 1:
- setarray .@cost[0],7828,500,7829,500; //BF_Badge1
- setarray .@item[0],2733,1; //Medal_Gunner
- break;
- case 2:
- setarray .@cost[0],7828,500,7829,500; //BF_Badge1
- setarray .@item[0],2720,1; //Medal_Swordman
- break;
- case 3:
- setarray .@cost[0],7828,500,7829,500; //BF_Badge1
- setarray .@item[0],2721,1; //Medal_Thief
- break;
- case 4:
- setarray .@cost[0],7828,500,7829,500; //BF_Badge1
- setarray .@item[0],2722,1; //Medal_Acolyte
- break;
- case 5:
- setarray .@cost[0],7828,500,7829,500; //BF_Badge1
- setarray .@item[0],2723,1; //Medal_Mage
- break;
- case 6:
- setarray .@cost[0],7828,500,7829,500; //BF_Badge1
- setarray .@item[0],2724,1; //Medal_Archer
- break;
- case 7:
- setarray .@cost[0],7828,500,7829,500; //BF_Badge1
- setarray .@item[0],2725,1; //Medal_Merchant
- break;
- }
+ setarray .@Items[0],2733,500,2720,500,2721,500,2722,500,2723,500,2724,500,2725,500;
+ set .@menu1$,"Gunslinger:Swordman/Taekwon Master:Thief:Acolyte:Magician:Archer:Merchant";
break;
case 4:
mes "[Erundek]";
mes "You chose ^3131FFConsumable^000000.";
mes "The following consumable items are available for exchange with the battlefield badges:";
next;
- switch(select("Tasty Pink Ration:Tasty White Ration:Military Ration A:Military Ration B:Military Ration C")) {
- case 1:
- setarray .@cost[0],7828,10,7829,10; //BF_Badge1
- setarray .@item[0],12269,1; //Tasty_Colonel
- break;
- case 2:
- setarray .@cost[0],7828,10,7829,10; //BF_Badge1
- setarray .@item[0],12270,1; //Tasty_Major
- break;
- case 3:
- setarray .@cost[0],7828,5,7829,5; //BF_Badge1
- setarray .@item[0],12271,1; //Mre_A
- break;
- case 4:
- setarray .@cost[0],7828,10,7829,10; //BF_Badge1
- setarray .@item[0],12272,1; //Mre_B
- break;
- case 5:
- setarray .@cost[0],7828,10,7829,10; //BF_Badge1
- setarray .@item[0],12273,1; //Mre_C
- break;
- }
+ setarray .@Items[0],12269,10,12270,10,12271,5,12272,10,12273,10;
break;
}
break;
@@ -761,20 +510,24 @@ bat_room,160,150,3 script Erundek 109,{
ReadBook 11010,1;
end;
}
-
+ set .@menu$,"";
+ if (.@menu1$ != "") set .@menu$, .@menu1$;
+ else for(set .@i,0; .@i<getarraysize(.@Items); set .@i,.@i+2)
+ set .@menu$, .@menu$+getitemname(.@Items[.@i])+":";
+ set .@i, (select(.@menu$)-1)*2;
mes "[Erundek]";
- mes "You chose ^3131FF"+getitemname(.@item[0])+"^000000.";
- switch(.@item[0]) {
- case 2720: mes "This item is for Swordman and Taekwon Master Class only."; break;
- case 2721: mes "This item is for Thief Class only."; break;
- case 2722: mes "This item is for Acolyte Class only."; break;
- case 2723: mes "This item is for Magician Class only."; break;
- case 2724: mes "This item is for Archer Class only."; break;
- case 2725: mes "This item is for Merchant Class only."; break;
- case 2733: mes "This item is for Gunslinger only."; break;
- default: break;
+ mes "You chose ^3131FF"+getitemname(.@Items[.@i])+"^000000.";
+ switch(.@Items[.@i]) {
+ case 2720: mes "This item is for Swordman and Taekwon Master Class only."; break;
+ case 2721: mes "This item is for Thief Class only."; break;
+ case 2722: mes "This item is for Acolyte Class only."; break;
+ case 2723: mes "This item is for Magician Class only."; break;
+ case 2724: mes "This item is for Archer Class only."; break;
+ case 2725: mes "This item is for Merchant Class only."; break;
+ case 2733: mes "This item is for Gunslinger only."; break;
+ default: break;
}
- mes "You can exchange for this item with ^FF0000"+.@cost[1]+" "+getitemname(.@cost[0])+" or "+.@cost[3]+" "+getitemname(.@cost[2])+"^000000.";
+ mes "You can exchange for this item with ^FF0000"+.@Items[.@i+1]+" "+getitemname(7828)+" or "+.@Items[.@i+1]+" "+getitemname(7829)+"^000000.";
mes "Would you like to exchange?";
next;
switch(select("Do not exchange:Exchange")) {
@@ -785,43 +538,26 @@ bat_room,160,150,3 script Erundek 109,{
case 2:
mes "[Erundek]";
mes "Which Badge do you want to exchange?";
- mes "You need ^3131FF"+.@cost[1]+" Badges^000000 to exchange.";
+ mes "You need ^3131FF"+.@Items[.@i+1]+" Badges^000000 to exchange.";
next;
if (.@item[0] < 12269 || .@item[0] > 12273 ) {
mes "[Erundek]";
mes "Remember, Battleground Reward Items are ^FF0000Character Bound^000000. Are you sure you want this item?";
next;
}
- switch(select("Bravery Badge:Valor Badge:Cancel")) {
- case 1:
- if (countitem(.@cost[0]) >= .@cost[1]) {
- mes "[Erundek]";
- mes "Thank you for exchanging.";
- delitem .@cost[0],.@cost[1];
- getitem .@item[0],.@item[1];
- }
- else {
- mes "[Erundek]";
- mes "You do not have enough Bravery Badges.";
- }
- break;
- case 2:
- if (countitem(.@cost[2]) >= .@cost[3]) {
- mes "[Erundek]";
- mes "Thank you for exchanging.";
- delitem .@cost[2],.@cost[3];
- getitem .@item[0],.@item[1];
- }
- else {
- mes "[Erundek]";
- mes "You do not have enough Valor Badges.";
- }
- break;
- case 3:
- mes "[Erundek]";
+ set .@j, select("Bravery Badge:Valor Badge:Cancel");
+ mes "[Erundek]";
+ if (.@j == 3) {
mes "You cancelled the exchange.";
break;
}
+ set .@cost, ((.@j==1)?7828:7829);
+ if (countitem(.@cost) >= .@Items[.@i+1]) {
+ mes "Thank you for exchanging.";
+ delitem .@cost, .@Items[.@i+1];
+ getitem .@Items[.@i],1;
+ }
+ else mes "You do not have enough "+getitemname(.@cost)+"s.";
break;
}
close;
diff --git a/npc/battleground/kvm/kvm_enter.txt b/npc/battleground/kvm/kvm_enter.txt
index 2df3c9a59..d54792bb5 100644
--- a/npc/battleground/kvm/kvm_enter.txt
+++ b/npc/battleground/kvm/kvm_enter.txt
@@ -27,9 +27,7 @@ bat_room,164,178,5 script KVM Mercenary Officer#1 418,{
mes "I know that you've already signed with the Croix. Go back and join their team. We will not accept traitors to fight for us.";
close;
}
- else if (.@kvm == 2) {
- erasequest 6026;
- }
+ else if (.@kvm == 2) erasequest 6026;
*/
set .@permit,checkquest(6025,PLAYTIME);
if ((.@permit == 0) || (.@permit == 1)) {
@@ -37,9 +35,7 @@ bat_room,164,178,5 script KVM Mercenary Officer#1 418,{
mes "It seems you have recently participated in a KVM battle. You must wait 5 minutes before signing up again.";
close;
}
- else if (.@permit == 2) {
- erasequest 6025;
- }
+ else if (.@permit == 2) erasequest 6025;
mes "[Guillaume Mercenary Officer]";
mes "Let them know the real might of Guillaume!";
next;
@@ -50,15 +46,9 @@ bat_room,164,178,5 script KVM Mercenary Officer#1 418,{
mes "Today, everyone will hear the shout of triumph from Guillaume!";
close2;
//setquest 6025;
- if (BaseLevel > 79) {
- warp "bat_room",169,223;
- }
- else if (BaseLevel < 60) {
- warp "bat_room",197,223;
- }
- else {
- warp "bat_room",225,223;
- }
+ if (BaseLevel > 79) warp "bat_room",169,223;
+ else if (BaseLevel < 60) warp "bat_room",197,223;
+ else warp "bat_room",225,223;
close;
case 2:
mes "[Guillaume Mercenary Officer]";
@@ -137,9 +127,7 @@ bat_room,164,121,1 script KVM Mercenary Officer#2 414,{
mes "I know that you've already signed with the Guillaume. Go back and join their team. We will not accept traitors to fight for us.";
close;
}
- else if (.@kvm == 2) {
- erasequest 6025;
- }
+ else if (.@kvm == 2) erasequest 6025;
*/
set .@permit,checkquest(6025,PLAYTIME);
if ((.@permit == 0) || (.@permit == 1)) {
@@ -147,9 +135,7 @@ bat_room,164,121,1 script KVM Mercenary Officer#2 414,{
mes "It seems you have recently participated in a KVM battle. You must wait 5 minutes before signing up again.";
close;
}
- else if (.@permit == 2) {
- erasequest 6025;
- }
+ else if (.@permit == 2) erasequest 6025;
mes "[Croix Mercenary Officer]";
mes "Let them know the real might of Croix!";
next;
@@ -160,15 +146,9 @@ bat_room,164,121,1 script KVM Mercenary Officer#2 414,{
mes "Today, everyone will hear the shout of triumph from Croix!";
close2;
//setquest 6026;
- if (BaseLevel > 79) {
- warp "bat_room",169,207;
- }
- else if (BaseLevel < 60) {
- warp "bat_room",197,207;
- }
- else {
- warp "bat_room",225,207;
- }
+ if (BaseLevel > 79) warp "bat_room",169,207;
+ else if (BaseLevel < 60) warp "bat_room",197,207;
+ else warp "bat_room",225,207;
close;
case 2:
mes "[Croix Mercenary Officer]";
diff --git a/npc/quests/thana_quest.txt b/npc/quests/thana_quest.txt
index ab3307c5f..654e5474e 100644
--- a/npc/quests/thana_quest.txt
+++ b/npc/quests/thana_quest.txt
@@ -3,7 +3,7 @@
//===== By: ==================================================
//= [Ishizu-chan]
//===== Current Version: =====================================
-//= 2.5a
+//= 2.6
//===== Compatible With: =====================================
//= rAthena SVN
//===== Description: =========================================
@@ -28,6 +28,7 @@
//= 2.4 Fixed a minor bug with Arch Bishop checks. [Euphy]
//= 2.5 Cleaning. [Euphy]
//= 2.5a Fixed an incorrect variable. [Euphy]
+//= 2.6 Merged identical timer labels. [Euphy]
//============================================================
hu_fild01,140,163,5 script Tower Keeper 852,3,3,{
@@ -2280,34 +2281,17 @@ OnEnable:
end;
OnTimer500:
- specialeffect EF_BEGINSPELL7;
- end;
-
OnTimer1000:
- specialeffect EF_BEGINSPELL7;
- end;
-
OnTimer1500:
- specialeffect EF_BEGINSPELL7;
- end;
-
OnTimer2000:
- specialeffect EF_BEGINSPELL7;
- end;
-
OnTimer2500:
specialeffect EF_BEGINSPELL7;
end;
OnTimer3000:
specialeffect EF_BEGINSPELL7;
- if ($@thana_summon == 6) {
- stopnpctimer;
- }
- else {
- stopnpctimer;
- initnpctimer;
- }
+ stopnpctimer;
+ if ($@thana_summon != 6) initnpctimer;
end;
OnDisable:
@@ -2323,34 +2307,17 @@ OnEnable:
end;
OnTimer500:
- specialeffect EF_BEGINSPELL3;
- end;
-
OnTimer1000:
- specialeffect EF_BEGINSPELL3;
- end;
-
OnTimer1500:
- specialeffect EF_BEGINSPELL3;
- end;
-
OnTimer2000:
- specialeffect EF_BEGINSPELL3;
- end;
-
OnTimer2500:
specialeffect EF_BEGINSPELL3;
end;
OnTimer3000:
specialeffect EF_BEGINSPELL3;
- if ($@thana_summon == 6) {
- stopnpctimer;
- }
- else {
- stopnpctimer;
- initnpctimer;
- }
+ stopnpctimer;
+ if ($@thana_summon != 6) initnpctimer;
end;
OnDisable:
@@ -2365,34 +2332,17 @@ OnEnable:
end;
OnTimer500:
- specialeffect EF_BEGINSPELL5;
- end;
-
OnTimer1000:
- specialeffect EF_BEGINSPELL5;
- end;
-
OnTimer1500:
- specialeffect EF_BEGINSPELL5;
- end;
-
OnTimer2000:
- specialeffect EF_BEGINSPELL5;
- end;
-
OnTimer2500:
specialeffect EF_BEGINSPELL5;
end;
OnTimer3000:
specialeffect EF_BEGINSPELL5;
- if ($@thana_summon == 6) {
- stopnpctimer;
- }
- else {
- stopnpctimer;
- initnpctimer;
- }
+ stopnpctimer;
+ if ($@thana_summon != 6) initnpctimer;
end;
OnDisable:
@@ -2408,34 +2358,17 @@ OnEnable:
end;
OnTimer500:
- specialeffect EF_BEGINSPELL4;
- end;
-
OnTimer1000:
- specialeffect EF_BEGINSPELL4;
- end;
-
OnTimer1500:
- specialeffect EF_BEGINSPELL4;
- end;
-
OnTimer2000:
- specialeffect EF_BEGINSPELL4;
- end;
-
OnTimer2500:
specialeffect EF_BEGINSPELL4;
end;
OnTimer3000:
specialeffect EF_BEGINSPELL4;
- if ($@thana_summon == 6) {
- stopnpctimer;
- }
- else {
- stopnpctimer;
- initnpctimer;
- }
+ stopnpctimer;
+ if ($@thana_summon != 6) initnpctimer;
end;
OnDisable:
@@ -2451,34 +2384,17 @@ OnEnable:
end;
OnTimer500:
- specialeffect EF_BEGINSPELL2;
- end;
-
OnTimer1000:
- specialeffect EF_BEGINSPELL2;
- end;
-
OnTimer1500:
- specialeffect EF_BEGINSPELL2;
- end;
-
OnTimer2000:
- specialeffect EF_BEGINSPELL2;
- end;
-
OnTimer2500:
specialeffect EF_BEGINSPELL2;
end;
OnTimer3000:
specialeffect EF_BEGINSPELL2;
- if ($@thana_summon == 6) {
- stopnpctimer;
- }
- else {
- stopnpctimer;
- initnpctimer;
- }
+ stopnpctimer;
+ if ($@thana_summon != 6) initnpctimer;
end;
OnDisable:
@@ -2502,9 +2418,7 @@ OnTouch:
donpcevent "tt_effect5::OnDisable";
hideonnpc "to_the_boss_room_tt";
}
- else {
- warp "thana_boss",136,116;
- }
+ else warp "thana_boss",136,116;
end;
}
@@ -2813,29 +2727,11 @@ OnTimer5000:
end;
OnTimer60000:
- mapwarp "thana_boss","tha_t12",130,47;
- end;
-
OnTimer1000000:
- mapwarp "thana_boss","tha_t12",130,47;
- end;
-
OnTimer2000000:
- mapwarp "thana_boss","tha_t12",130,47;
- end;
-
OnTimer3000000:
- mapwarp "thana_boss","tha_t12",130,47;
- end;
-
OnTimer4000000:
- mapwarp "thana_boss","tha_t12",130,47;
- end;
-
OnTimer5000000:
- mapwarp "thana_boss","tha_t12",130,47;
- end;
-
OnTimer6000000:
mapwarp "thana_boss","tha_t12",130,47;
end;