summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--world/map/db/mob_db_over_100.txt2
-rw-r--r--world/map/npc/commands/numa.txt13
-rw-r--r--world/map/npc/functions/doomsday.txt140
-rw-r--r--world/map/npc/scripts.conf1
4 files changed, 156 insertions, 0 deletions
diff --git a/world/map/db/mob_db_over_100.txt b/world/map/db/mob_db_over_100.txt
index cedb4f13..c085904b 100644
--- a/world/map/db/mob_db_over_100.txt
+++ b/world/map/db/mob_db_over_100.txt
@@ -40,3 +40,5 @@
1135, LovelyMaggot, LovelyMaggot, 1, 50, 0, 1, 1, 1, 69, 6969, 0, 5, 5, 5, 1, 0, 6, 5, 1, 1, 1, 3, 21, 133, 200, 1872, 672, 480, 505, 400, 501, 70, 518, 200, 533, 75, 502, 30, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
1136, LesserGhost, LesserGhost, 1, 1, 0, 1, 1, 0, 150, 300, 0, 0, 0, 0, 0, 0, 0, 0, 2, 2, 1, 1, 29, 131, 340, 1800, 672, 950, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 4, 20
1137, Tormenta, Tormenta, 200, 18000, 60, 500000, 5000, 5, 360, 374, 48, 90, 1, 32, 60, 255, 255, 255, 31, 30, 1, 0, 69, 181, 210, 1200, 672, 50, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
+//ID, Name, Jname, LV, HP, SP, EXP, JEXP, Range1, ATK1, ATK2, DEF, MDEF, STR, AGI, VIT, INT, DEX, LUK, Range2, Range3, Scale, Race, Element,Mode, Speed, Adelay, Amotion,Dmotion,Drop1id,Drop1per,Drop2id,Drop2%, Drop3id,Drop3%, Drop4id,Drop4%, Drop5id,Drop5%, Drop6id,Drop6%, Drop7id,Drop7%, Drop8id,Drop8%, Item1, Item2, MEXP, ExpPer, MVP1id, MVP1per,MVP2id, MVP2per,MVP3id, MVP3per,mutationcount,mutationstrength
+1138, ManaGuard, ManaGuardian, 180, 20000, 280, 21000, 5000, 2, 360, 374, 28, 70, 31, 22, 90, 127, 255, 245, 31, 30, 1, 0, 69, 181, 210, 1200, 672, 50, 759, 1, 5237, 20, 1253, 5, 720, 100, 825, 500, 868, 20, 1172, 15, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
diff --git a/world/map/npc/commands/numa.txt b/world/map/npc/commands/numa.txt
index 78746a26..5d6f64f0 100644
--- a/world/map/npc/commands/numa.txt
+++ b/world/map/npc/commands/numa.txt
@@ -103,6 +103,7 @@ L_ChooseContinent:
next;
menu
"Argeas", L_Argeas,
+ "World", L_World,
"Close", L_Return;
L_Argeas:
@@ -121,6 +122,14 @@ L_Woodland:
"Choose an area", L_Argeas,
"Close", L_Return;
+L_World:
+ mes "Choose an event.";
+ next;
+ menu
+ "Doomsday", L_Doomsday,
+ "Choose a continent", L_ChooseContinent,
+ "Close", L_Return;
+
L_Return:
return;
@@ -129,4 +138,8 @@ L_Return:
L_Valia:
callfunc "IlliaDebug";
goto L_Return;
+
+L_Doomsday:
+ callfunc "DoomsdayDebug";
+ goto L_Return;
}
diff --git a/world/map/npc/functions/doomsday.txt b/world/map/npc/functions/doomsday.txt
new file mode 100644
index 00000000..db8eca50
--- /dev/null
+++ b/world/map/npc/functions/doomsday.txt
@@ -0,0 +1,140 @@
+// Evol script
+// Controls Doomsday Event
+//
+// A really long event (months), controlling and being written by
+// every event which happens since doomsday program officialy started
+// in Halloween 2019 with Tormenta's release.
+//
+// This file history is written by GMs and players as the events happen
+// and therefore it is not possible to predict or add code for things which
+// are too far away from happening.
+//
+// Please keep Doomsday System simple.
+// Revert it to anything to stage once it is over.
+// It can be epic. But it doesn't needs to be.
+// But above all, this should NOT affect the merge.
+// The event purpose is to give players background history.
+
+function|script|DoomsdayDebug
+{
+ mes "$DOOMSDAY: "+$DOOMSDAY; // Event Status
+ mes "$DOOMSDAY_CNT: "+$DOOMSDAY_CNT; // Meaning Varies
+ next;
+ // Only GM 80 and above can modify Doomsday
+ // ...Yes, G_ADMIN is 80 while G_SYSOP is 99.
+ if (GM < G_ADMIN) goto L_Close;
+ mes "Setting $DOOMSDAY event state";
+ menu
+ "[0] Tormenta's Seal",L_Seal,
+ "[1] Jande's Army",L_Army,
+ "[-] Close",L_Close;
+
+L_Close:
+ return;
+
+L_Seal:
+ set $DOOMSDAY, 0;
+ donpcevent "Doomsday::OnJanitor";
+ gmlog strcharinfo(0) + " changed doomsday to Act 1: Tormenta's Seal.";
+ return;
+
+L_Army:
+ set $DOOMSDAY, 1;
+ donpcevent "Doomsday::OnJanitor";
+ gmlog strcharinfo(0) + " changed doomsday to Act 2: Jande's Army.";
+ return;
+}
+
+// Doomsday script controller
+-|script|Doomsday|32767
+{
+ close;
+
+// Destroy any artifact as doomsday mode changes
+OnJanitor:
+ // TODO: Kill monsters?
+ setnpctimer 0;
+ stopnpctimer;
+ goto OnInit;
+
+// Check for our current doomsday state
+OnInit:
+ if ($DOOMSDAY == 1)
+ goto L_Doomsday1;
+ // goto L_Check2;
+ end;
+
+L_Doomsday1:
+ // 1138 - Mana Guardian
+ // Argaes Invasion (1)
+ areamonster "017-1", 169, 49, 198, 77, "", 1138, 1, "Doomsday::OnDeathMapname";
+ // Argaes Invasion (2)
+ areamonster "012-1", 20, 47, 74, 77, "", 1138, 3, "Doomsday::OnDeathMapname";
+ // Argaes Invasion (3)
+ areamonster "057-1", 115, 50, 140, 75, "", 1138, 4, "Doomsday::OnDeathMapname";
+ // Kaizei Invasion (I)
+ areamonster "046-1", 58, 49, 92, 70, "", 1138, 2, "Doomsday::OnDeathMapname";
+ // Kaizei Invasion (II)
+ areamonster "034-1", 83, 51, 121, 98, "", 1138, 6, "Doomsday::OnDeathMapname";
+ // Tonori Invasion
+ areamonster "003-4", 20, 20, 85, 60, "", 1138, 7, "Doomsday::OnDeathMapname";
+ end;
+
+L_Doomsday1Respawn:
+ // Argaes Invasion (1)
+ set $@DoomsdayMc, mobcount("017-1", "Doomsday::OnDeathMapname")+1;
+ if ($@DoomsdayMc < 1)
+ areamonster "017-1", 169, 49, 198, 77, "", 1138, 1-$@DoomsdayMc, "Doomsday::OnDeathMapname";
+
+ // Argaes Invasion (2)
+ set $@DoomsdayMc, mobcount("012-1", "Doomsday::OnDeathMapname")+1;
+ if ($@DoomsdayMc < 3)
+ areamonster "012-1", 20, 47, 74, 77, "", 1138, 3-$@DoomsdayMc, "Doomsday::OnDeathMapname";
+
+ // Argaes Invasion (3)
+ set $@DoomsdayMc, mobcount("012-1", "Doomsday::OnDeathMapname")+1;
+ if ($@DoomsdayMc < 4)
+ areamonster "057-1", 115, 50, 140, 75, "", 1138, 4-$@DoomsdayMc, "Doomsday::OnDeathMapname";
+
+ // Kaizei Invasion (I)
+ set $@DoomsdayMc, mobcount("046-1", "Doomsday::OnDeathMapname")+1;
+ if ($@DoomsdayMc < 2)
+ areamonster "046-1", 58, 49, 92, 70, "", 1138, 2-$@DoomsdayMc, "Doomsday::OnDeathMapname";
+
+ // Kaizei Invasion (II)
+ set $@DoomsdayMc, mobcount("034-1", "Doomsday::OnDeathMapname")+1;
+ if ($@DoomsdayMc < 6)
+ areamonster "034-1", 83, 51, 121, 98, "", 1138, 6-$@DoomsdayMc, "Doomsday::OnDeathMapname";
+
+ // Tonori Invasion
+ set $@DoomsdayMc, mobcount("003-4", "Doomsday::OnDeathMapname")+1;
+ if ($@DoomsdayMc < 7)
+ areamonster "003-4", 20, 20, 85, 60, "", 1138, 7-$@DoomsdayMc, "Doomsday::OnDeathMapname";
+ // goto L_TimerCheck2;
+ goto L_TimerFinish;
+
+// Respawn logic (5 minutes)
+OnTimer300000:
+ if ($DOOMSDAY == 1)
+ goto L_Doomsday1Respawn;
+ // goto L_TimerCheck2;
+ goto L_TimerFinish;
+
+// Once all timer checks are over
+L_TimerFinish:
+ set $@DoomsdayMc, 0;
+ setnpctimer 0;
+ stopnpctimer;
+ end;
+
+// Puppet labels
+OnDeathMapname:
+ if ($DOOMSDAY == 1)
+ set $DOOMSDAY_CNT, $DOOMSDAY_CNT+1;
+ startnpctimer;
+ end;
+
+}
+
+
+
diff --git a/world/map/npc/scripts.conf b/world/map/npc/scripts.conf
index e8743cd7..ee63f684 100644
--- a/world/map/npc/scripts.conf
+++ b/world/map/npc/scripts.conf
@@ -5,6 +5,7 @@ npc: npc/functions/banker.txt
npc: npc/functions/barber.txt
npc: npc/functions/clear_vars.txt
npc: npc/functions/dailyquest.txt
+npc: npc/functions/doomsday.txt
npc: npc/functions/ferry.txt
npc: npc/functions/miriam.txt
npc: npc/functions/travelers.txt