summaryrefslogtreecommitdiff
path: root/world/map/npc/mobs/miner_mania.txt
diff options
context:
space:
mode:
Diffstat (limited to 'world/map/npc/mobs/miner_mania.txt')
-rw-r--r--world/map/npc/mobs/miner_mania.txt295
1 files changed, 295 insertions, 0 deletions
diff --git a/world/map/npc/mobs/miner_mania.txt b/world/map/npc/mobs/miner_mania.txt
new file mode 100644
index 00000000..445c82e0
--- /dev/null
+++ b/world/map/npc/mobs/miner_mania.txt
@@ -0,0 +1,295 @@
+
+///////////////////////////////////////////////////////////////////////////////
+// Miner Mania
+-|script|Miner_Mania|32767
+{
+ close;
+
+OnInit:
+/*
+- 1 tick = 1 sec
+
+- If $@bif/slime_mine_maps_x0/y0/x1/y1 = -1 the matching min/max corner value is taken x0 = 0, y0 = 0, x1 = max x, y1 = max y
+
+- $@bifs_big and $@bifs_small must always have the same size as $@bifs
+
+- if "error_log: on" is in world/map/conf/battle_local.conf it displays messages like "npc_event: event not found [Miner_Mania::OnBifMined10]" which clutter the server console
+ but otherwise do no harm, its also possible to make "error_log: off" so they don't get displayed anymore but to be sure include a label with the mapnumber in it like:
+ OnBifMined99:
+ end;
+
+- $@bifs/slimes_multi set after how many ticks this map/spot spawns.
+ For example multi 6 would spawn on 6th tick which is 6 sec on 1 sec tick duration.
+ For example if you have multiple sqares on a map and to not spawn <num of squares> * 1 tick faster than other maps, use multi = num of squares:
+ setarray $@bif_mine_maps$, "009-1", "009-1", "009-1", "009-2", "008-1", "018-1";
+ setarray $@bifs_count, 4, 20, 20, 44, 44, 44;
+ setarray $@bifs_multi, 3, 3, 3, 1, 1, 1;
+ setarray $@bif_mine_maps_x0, 30, 25, 41, -1, -1, -1;
+ setarray $@bif_mine_maps_y0, 34, 39, 39, -1, -1, -1;
+ setarray $@bif_mine_maps_x1, 33, 34, 48, -1, -1, -1;
+ setarray $@bif_mine_maps_y1, 37, 51, 51, -1, -1, -1;
+
+Note:
+ The values used in _mobs.txt are not x0, y0, x1, y1 they are x, y, width, height so they are not compatible with areaspawn since the spawn area extents from x and y in - and + directions
+*/
+
+// .map_nr 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16
+ setarray $@bif_mine_maps$, "002-4", "002-5", "005-3", "006-3", "009-3", "011-4", "011-6", "012-3", "012-4", "013-3", "018-3", "014-3", "017-3", "032-3", "043-3", "043-4", "055-3";
+ setarray $@bifs_count, 10, 10, 15, 15, 20, 20, 25, 20, 35, 20, 30, 10, 10, 15, 15, 20, 15;
+ setarray $@bifs_multi, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2;
+ setarray $@bif_mine_maps_x0, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 30, -1;
+ setarray $@bif_mine_maps_y0, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 23, -1;
+ setarray $@bif_mine_maps_x1, -1, -1, 100, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 173, -1;
+ setarray $@bif_mine_maps_y1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 170, -1;
+ setarray $@bifs, Bif, AmethystBif, DiamondBif, EmeraldBif, RubyBif, SapphireBif, TopazBif;
+ setarray $@bifs_small, SmallBif, SmallAmethystBif, SmallDiamondBif, SmallEmeraldBif, SmallRubyBif, SmallSapphireBif, SmallTopazBif;
+ setarray $@bifs_big, BigBif, BigAmethystBif, BigDiamondBif, BigEmeraldBif, BigRubyBif, BigSapphireBif, BigTopazBif;
+
+// .map_nr 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16
+ setarray $@slime_mine_maps$, "002-4", "002-5", "005-3", "006-3", "009-3", "011-4", "011-6", "012-3", "012-4", "013-3", "018-3", "014-3", "017-3", "032-3", "043-3", "043-4", "055-3";
+ setarray $@slimes_count, 10, 10, 15, 15, 20, 20, 25, 20, 35, 20, 30, 10, 10, 15, 15, 20, 15;
+ setarray $@slimes_multi, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2;
+ setarray $@slime_mine_maps_x0, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 30, -1;
+ setarray $@slime_mine_maps_y0, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 23, -1;
+ setarray $@slime_mine_maps_x1, -1, -1, 100, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 173, -1;
+ setarray $@slime_mine_maps_y1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 170, -1;
+ setarray $@slimes, CopperSlime, SilverSlime, BromenalSlime, GoldSlime, IronSlime, CoalSlime;
+
+// Bifs -----------------------------
+
+ set .map_count, getarraysize($@bif_mine_maps$[0]);
+ set .map_nr, 0;
+
+ freeloop 1; // do not check for infinity loop
+
+ goto L_BifMapInitLoop;
+
+L_BifMapInitLoop:
+
+ if ($@bif_mine_maps_x0[.map_nr] > -1) goto L_BifMapInitLoop_x0Set;
+
+ set $@bif_mine_maps_x0[.map_nr], 0;
+ goto L_BifMapInitLoop_x0Set;
+
+L_BifMapInitLoop_x0Set:
+
+ if ($@bif_mine_maps_y0[.map_nr] > -1) goto L_BifMapInitLoop_y0Set;
+
+ set $@bif_mine_maps_y0[.map_nr], 0;
+ goto L_BifMapInitLoop_y0Set;
+
+L_BifMapInitLoop_y0Set:
+
+ if ($@bif_mine_maps_x1[.map_nr] > -1) goto L_BifMapInitLoop_x1Set;
+
+ set $@bif_mine_maps_x1[.map_nr], getmapmaxx($@bif_mine_maps$[.map_nr]);
+ goto L_BifMapInitLoop_x1Set;
+
+L_BifMapInitLoop_x1Set:
+
+ if ($@bif_mine_maps_y1[.map_nr] > -1) goto L_BifMapInitLoop_y1Set;
+
+ set $@bif_mine_maps_y1[.map_nr], getmapmaxy($@bif_mine_maps$[.map_nr]);
+ goto L_BifMapInitLoop_y1Set;
+
+L_BifMapInitLoop_y1Set:
+
+ if ($@bifs_multi[.map_nr] < 1) set $@bifs_multi[.map_nr], 1;
+ set $@bifs_multi_count[.map_nr], $@bifs_multi[.map_nr];
+
+ set .map_nr, .map_nr + 1;
+ if (.map_nr < .map_count) goto L_BifMapInitLoop;
+
+// Slimes -----------------------------
+
+ set .map_count, getarraysize($@slime_mine_maps$[0]);
+ set .map_nr, 0;
+
+ goto L_SlimeMapInitLoop;
+
+L_SlimeMapInitLoop:
+
+ if ($@slime_mine_maps_x0[.map_nr] > -1) goto L_SlimeMapInitLoop_x0Set;
+
+ set $@slime_mine_maps_x0[.map_nr], 0;
+ goto L_SlimeMapInitLoop_x0Set;
+
+L_SlimeMapInitLoop_x0Set:
+
+ if ($@slime_mine_maps_y0[.map_nr] > -1) goto L_SlimeMapInitLoop_y0Set;
+
+ set $@slime_mine_maps_y0[.map_nr], 0;
+ goto L_SlimeMapInitLoop_y0Set;
+
+L_SlimeMapInitLoop_y0Set:
+
+ if ($@slime_mine_maps_x1[.map_nr] > -1) goto L_SlimeMapInitLoop_x1Set;
+
+ set $@slime_mine_maps_x1[.map_nr], getmapmaxx($@slime_mine_maps$[.map_nr]);
+ goto L_SlimeMapInitLoop_x1Set;
+
+L_SlimeMapInitLoop_x1Set:
+
+ if ($@slime_mine_maps_y1[.map_nr] > -1) goto L_SlimeMapInitLoop_y1Set;
+
+ set $@slime_mine_maps_y1[.map_nr], getmapmaxy($@slime_mine_maps$[.map_nr]);
+ goto L_SlimeMapInitLoop_y1Set;
+
+L_SlimeMapInitLoop_y1Set:
+
+ if ($@slimes_multi[.map_nr] < 1) set $@slimes_multi[.map_nr], 1;
+ set $@slimes_multi_count[.map_nr], $@slimes_multi[.map_nr];
+
+ set .map_nr, .map_nr + 1;
+ if (.map_nr < .map_count) goto L_SlimeMapInitLoop;
+
+ freeloop 0; // re-enable infinity loop check
+
+ initnpctimer;
+
+ end;
+
+OnTimer1000:
+
+// Bifs -----------------------------
+
+ set .map_count, getarraysize($@bif_mine_maps$[0]);
+ set .map_nr, 0;
+
+ freeloop 1; // do not check for infinity loop
+
+ goto L_BifMapLoop;
+
+L_BifMapLoop:
+ set $@bifs_multi_count[.map_nr], $@bifs_multi_count[.map_nr] - 1;
+ if ($@bifs_multi_count[.map_nr] >= 1) goto L_BifContinue;
+
+ set $@bifs_multi_count[.map_nr], $@bifs_multi[.map_nr];
+
+ set .bifs_alive, mobcount($@bif_mine_maps$[.map_nr], "Miner_Mania::OnBifMined" + .map_nr)+1;
+ set .bifs_respawn_count, $@bifs_count[.map_nr] - .bifs_alive;
+
+ if (.bifs_respawn_count < 1) goto L_BifContinue;
+
+ if (rand(GEM_BIF_CHANCE)<1) set .bif, rand(getarraysize($@bifs[0])-1)+1;
+ else set .bif, 0;
+
+ if (rand(BIG_BIF_CHANCE)<1)
+ areamonster $@bif_mine_maps$[.map_nr], $@bif_mine_maps_x0[.map_nr], $@bif_mine_maps_y0[.map_nr], $@bif_mine_maps_x1[.map_nr], $@bif_mine_maps_y1[.map_nr], "", $@bifs_big[.bif], 1, "Miner_Mania::OnBifMined" + .map_nr;
+ elif (rand(NORMAL_BIF_CHANCE)<1)
+ areamonster $@bif_mine_maps$[.map_nr], $@bif_mine_maps_x0[.map_nr], $@bif_mine_maps_y0[.map_nr], $@bif_mine_maps_x1[.map_nr], $@bif_mine_maps_y1[.map_nr], "", $@bifs[.bif], 1, "Miner_Mania::OnBifMined" + .map_nr;
+ else
+ areamonster $@bif_mine_maps$[.map_nr], $@bif_mine_maps_x0[.map_nr], $@bif_mine_maps_y0[.map_nr], $@bif_mine_maps_x1[.map_nr], $@bif_mine_maps_y1[.map_nr], "", $@bifs_small[.bif], 1, "Miner_Mania::OnBifMined" + .map_nr;
+
+ goto L_BifContinue;
+
+L_BifContinue:
+ set .map_nr, .map_nr + 1;
+ if (.map_nr < .map_count) goto L_BifMapLoop;
+
+// Slimes -----------------------------
+
+ set .map_count, getarraysize($@slime_mine_maps$[0]);
+ set .map_nr, 0;
+
+ goto L_SlimeMapLoop;
+
+L_SlimeMapLoop:
+ set $@slimes_multi_count[.map_nr], $@slimes_multi_count[.map_nr] - 1;
+ if ($@slimes_multi_count[.map_nr] >= 1) goto L_SlimeContinue;
+
+ set $@slimes_multi_count[.map_nr], $@slimes_multi[.map_nr];
+
+ set .slimes_alive, mobcount($@slime_mine_maps$[.map_nr], "Miner_Mania::OnSlimeSlain" + .map_nr)+1;
+ set .slimes_respawn_count, $@slimes_count[.map_nr] - .slimes_alive;
+
+ if (.slimes_respawn_count < 1) goto L_SlimeContinue;
+
+ set .slime, rand(getarraysize($@slimes[0]));
+
+ areamonster $@slime_mine_maps$[.map_nr], $@slime_mine_maps_x0[.map_nr], $@slime_mine_maps_y0[.map_nr], $@slime_mine_maps_x1[.map_nr], $@slime_mine_maps_y1[.map_nr], "", $@slimes[.slime], 1, "Miner_Mania::OnSlimeSlain" + .map_nr;
+
+ goto L_SlimeContinue;
+
+L_SlimeContinue:
+ set .map_nr, .map_nr + 1;
+ if (.map_nr < .map_count) goto L_SlimeMapLoop;
+
+ freeloop 0; // re-enable infinity loop check
+
+ stopnpctimer;
+ setnpctimer 0;
+ startnpctimer;
+
+ end;
+
+OnBifMined0:
+ end;
+OnBifMined1:
+ end;
+OnBifMined2:
+ end;
+OnBifMined3:
+ end;
+OnBifMined4:
+ end;
+OnBifMined5:
+ end;
+OnBifMined6:
+ end;
+OnBifMined7:
+ end;
+OnBifMined8:
+ end;
+OnBifMined9:
+ end;
+OnBifMined10:
+ end;
+OnBifMined11:
+ end;
+OnBifMined12:
+ end;
+OnBifMined13:
+ end;
+OnBifMined14:
+ end;
+OnBifMined15:
+ end;
+OnBifMined16:
+ end;
+
+OnSlimeSlain0:
+ end;
+OnSlimeSlain1:
+ end;
+OnSlimeSlain2:
+ end;
+OnSlimeSlain3:
+ end;
+OnSlimeSlain4:
+ end;
+OnSlimeSlain5:
+ end;
+OnSlimeSlain6:
+ end;
+OnSlimeSlain7:
+ end;
+OnSlimeSlain8:
+ end;
+OnSlimeSlain9:
+ end;
+OnSlimeSlain10:
+ end;
+OnSlimeSlain11:
+ end;
+OnSlimeSlain12:
+ end;
+OnSlimeSlain13:
+ end;
+OnSlimeSlain14:
+ end;
+OnSlimeSlain15:
+ end;
+OnSlimeSlain16:
+ end;
+}