summaryrefslogtreecommitdiff
path: root/npc/003-10
diff options
context:
space:
mode:
Diffstat (limited to 'npc/003-10')
-rw-r--r--npc/003-10/arnea.txt132
1 files changed, 74 insertions, 58 deletions
diff --git a/npc/003-10/arnea.txt b/npc/003-10/arnea.txt
index a55db1fd0..d25996d5d 100644
--- a/npc/003-10/arnea.txt
+++ b/npc/003-10/arnea.txt
@@ -5,12 +5,7 @@
// Description:
// Arena for Duels and PVP (003-13,31,31)
-003-5,33,37,0 script Arnea NPC_ELF_F,{
- if (DESTROY_ME) {
- DESTROY_ME=0;
- instance_destroy(DESTROY_MY_ID);
- }
-
+003-10,26,60,0 script Arnea NPC_ELF_F,{
// FIXIT code
if (!is_staff()) goto L_Incomplete;
@@ -30,33 +25,26 @@ L_NewArena:
} else {
mesq l("Okay, which arena will you rent? Cost is @@ GP.", .price);
menu
- rif($@ARENA_INSTANCES[0] < 0, l("Arena 1")), -,
- rif($@ARENA_INSTANCES[1] < 0, l("Arena 2")), -,
- rif($@ARENA_INSTANCES[2] < 0, l("Arena 3")), -,
- rif($@ARENA_INSTANCES[3] < 0, l("Arena 4")), -,
- rif($@ARENA_INSTANCES[4] < 0, l("Arena 5")), -,
+ rif(Zeny > 1000, l("Rent arena")), -,
l("Give Up"), L_Quit;
- mes (@menu-1);
- .@ARENA_INSTID = instance_create("003-13@arenax"+(@menu), 0, IOT_NONE);
- if (.@ARENA_INSTID >= 0)
- {
- mes "new instance id: " + str(.@ARENA_INSTID);
- .@instanceMapName$ = instance_attachmap("003-13", .@ARENA_INSTID, 0, "003-13@a" + (@menu-1));
- if (.@instanceMapName$ == "")
- {
- mes "Error: instance attach map error";
- } else {
- mes "Attached instance map name: " + .@instanceMapName$;
- instance_set_timeout(1000000, 1000000, .@ARENA_INSTID);
- instance_init(.@ARENA_INSTID);
- set Zeny, Zeny-1000;
- $@ARENA_INSTANCES[@menu-1]=getcharid(3);
- }
- } else {
- mes l("An error happened.");
- }
- }
+ // Register to HTTable $@ARENAS (or override existing entry) your ID and a password
+ .@PASSWORD=getcharid(0)**1.137;
+ htput($@ARENAS, .@PASSWORD, getcharid(0));
+
+ // XXX - Important Note - XXX
+ // map name MUST be only 4 chars long (eg. "abcd") on char instances
+ .@ID=getcharid(0);
+ .@MAP$="AREN@"+str(.@ID);
+
+ // Create the arena
+ .@INSTID = instance_create("003-10@"+(.@ID), getcharid(3), IOT_CHAR);
+ .@instanceMapName$ = instance_attachmap("003-13", .@INSTID, 0, .@MAP$);
+ instance_set_timeout(1800, 1800, .@INSTID);
+ instance_init(.@INSTID);
+ dispbottom l("Arena created, it can be used for 10 minutes.");
+ dispbottom l("Room password: @@", .@PASSWORD);
+
goto L_Quit;
@@ -74,28 +62,23 @@ L_Info:
L_JoinArena:
mes "";
mesn;
- if (Zeny < .price) {
- mesq l("You need @@ GP to use this arena.", .price);
- } else {
- mesq l("Okay, which arena will you join? Cost is @@ GP.", .price);
- //menu
- // rif(has_instance2("003-5@0") >= 0, l("Arena 1")), -,
- // rif(has_instance2("003-5@1") >= 0, l("Arena 2")), -,
- // rif(has_instance2("003-5@2") >= 0, l("Arena 3")), -,
- // rif(has_instance2("003-5@3") >= 0, l("Arena 4")), -,
- // rif(has_instance2("003-5@4") >= 0, l("Arena 5")), -,
- // l("Give Up"), L_Quit;
- menu
- rif($@ARENA_INSTANCES[0] > 0, l("Arena 1")), -,
- rif($@ARENA_INSTANCES[1] > 0, l("Arena 2")), -,
- rif($@ARENA_INSTANCES[2] > 0, l("Arena 3")), -,
- rif($@ARENA_INSTANCES[3] > 0, l("Arena 4")), -,
- rif($@ARENA_INSTANCES[4] > 0, l("Arena 5")), -,
- l("Give Up"), L_Quit;
- warp "003-13@a"+(@menu-1), 31,31;
- set Zeny, Zeny-.price;
- //instance_warpall("003-13@a"+@menu, 30, 31); // Only use while in instance
+ mesq l("Okay, to join an arena, you need the unique password. Leave blank if you don't know.");
+
+ input .@user_password;
+ .@m = htget($@ARENAS, .@user_password, -1);
+ if (.@m > 0) {
+ if(has_instance2("003-10@"+.@m)) {
+ warp "AREN@"+str(.@m), 31,31;
+ } else {
+ mes "";
+ mesn;
+ mesq l("Sorry, that arena is already closed.");
+ next;
+ mesn;
+ mesq l("All arenas stay open for only 30 minutes after being purchased.");
+ }
}
+
close;
@@ -122,14 +105,11 @@ OnInit:
.sex = G_FEMALE;
.distance = 5;
- .alwaysVisible = true;
+ //.alwaysVisible = true; // This is dumb, why Jesusalva put it here?
.price=1000;
- // test instance id
- setarray $@ARENA_INSTANCES, -1,-1,-1,-1,-1; // Controls Owners
- setarray $@ARENA_INFOS$, "","","","",""; // Controls Owners
- // Temporary fix
- disablenpc "Arnea";
+ // create hashtable
+ $@ARENAS = htnew();
end;
OnInstanceInit:
@@ -143,3 +123,39 @@ OnInstanceInit:
end;
}
+
+
+ /*
+ mes (@menu-1);
+ .@ARENA_INSTID = instance_create("003-13@arenax"+(@menu), 0, IOT_NONE);
+ if (.@ARENA_INSTID >= 0)
+ {
+ mes "new instance id: " + str(.@ARENA_INSTID);
+ .@instanceMapName$ = instance_attachmap("003-13", .@ARENA_INSTID, 0, "003-13@a" + (@menu-1));
+ if (.@instanceMapName$ == "")
+ {
+ mes "Error: instance attach map error";
+ } else {
+ mes "Attached instance map name: " + .@instanceMapName$;
+ instance_set_timeout(1000000, 1000000, .@ARENA_INSTID);
+ instance_init(.@ARENA_INSTID);
+ set Zeny, Zeny-1000;
+ $@ARENA_INSTANCES[@menu-1]=getcharid(3);
+ }
+ } else {
+ mes l("An error happened.");
+ }
+ }
+
+ menu
+ rif($@ARENA_INSTANCES[0] > 0, l("Arena 1")), -,
+ rif($@ARENA_INSTANCES[1] > 0, l("Arena 2")), -,
+ rif($@ARENA_INSTANCES[2] > 0, l("Arena 3")), -,
+ rif($@ARENA_INSTANCES[3] > 0, l("Arena 4")), -,
+ rif($@ARENA_INSTANCES[4] > 0, l("Arena 5")), -,
+ l("Give Up"), L_Quit;
+ warp "003-13@a"+(@menu-1), 31,31;
+ set Zeny, Zeny-.price;
+ //instance_warpall("003-13@a"+@menu, 30, 31); // Only use while in instance
+ */
+