summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJesusaves <cpntb1@ymail.com>2021-01-27 17:40:58 -0300
committerJesusaves <cpntb1@ymail.com>2021-01-27 17:40:58 -0300
commitbf68fda600acbbc3e632a3bef2d8fd3f70d71d2e (patch)
treeb707791f7b086b60dc77ca4a76824f2ab57572b3
parent35b14b4ee5625d3896311c42b15ccf68d55e6477 (diff)
downloadserverdata-bf68fda600acbbc3e632a3bef2d8fd3f70d71d2e.tar.gz
serverdata-bf68fda600acbbc3e632a3bef2d8fd3f70d71d2e.tar.bz2
serverdata-bf68fda600acbbc3e632a3bef2d8fd3f70d71d2e.tar.xz
serverdata-bf68fda600acbbc3e632a3bef2d8fd3f70d71d2e.zip
Fungus' drops and the Rum Making Barrel (Fortress Town Utility)
-rw-r--r--db/re/mob_db.conf19
-rw-r--r--npc/025-1/_import.txt1
-rw-r--r--npc/025-1/ctrl.c2
-rw-r--r--npc/025-1/rum.txt181
4 files changed, 202 insertions, 1 deletions
diff --git a/db/re/mob_db.conf b/db/re/mob_db.conf
index 539504c8e..94768d66c 100644
--- a/db/re/mob_db.conf
+++ b/db/re/mob_db.conf
@@ -10519,7 +10519,6 @@ mob_db: (
All: 2000
}
},
-// WIP FIXME TODO
{
Id: 1409
SpriteName: "Tengu"
@@ -11030,6 +11029,9 @@ mob_db: (
DamageMotion: 200
ViewRange: 7
ChaseRange: 11
+ Drops: {
+ Fungus: 200
+ }
},
{
Id: 1422
@@ -11068,6 +11070,9 @@ mob_db: (
DamageMotion: 200
ViewRange: 7
ChaseRange: 11
+ Drops: {
+ Fungus: 220
+ }
},
{
Id: 1423
@@ -11106,6 +11111,9 @@ mob_db: (
DamageMotion: 200
ViewRange: 7
ChaseRange: 11
+ Drops: {
+ Fungus: 180
+ }
},
{
Id: 1424
@@ -11144,6 +11152,9 @@ mob_db: (
DamageMotion: 200
ViewRange: 7
ChaseRange: 11
+ Drops: {
+ Fungus: 80
+ }
},
{
Id: 1425
@@ -11220,6 +11231,9 @@ mob_db: (
DamageMotion: 200
ViewRange: 7
ChaseRange: 11
+ Drops: {
+ Fungus: 40
+ }
},
{
Id: 1427
@@ -11295,6 +11309,9 @@ mob_db: (
DamageMotion: 200
ViewRange: 7
ChaseRange: 11
+ Drops: {
+ Fungus: 10
+ }
},
{
Id: 1429
diff --git a/npc/025-1/_import.txt b/npc/025-1/_import.txt
index b5be1c942..f225107b2 100644
--- a/npc/025-1/_import.txt
+++ b/npc/025-1/_import.txt
@@ -9,6 +9,7 @@
"npc/025-1/drahcir.txt",
"npc/025-1/ihclot.txt",
"npc/025-1/phoenix.txt",
+"npc/025-1/rum.txt",
"npc/025-1/salohcin.txt",
"npc/025-1/selim.txt",
"npc/025-1/teleporter.txt",
diff --git a/npc/025-1/ctrl.c b/npc/025-1/ctrl.c
index 06507aa0e..03997d62b 100644
--- a/npc/025-1/ctrl.c
+++ b/npc/025-1/ctrl.c
@@ -51,6 +51,7 @@ function script FTCleanup {
enablenpc "Xovilam";
enablenpc "Drahcir";
enablenpc "Selim";
+ enablenpc "Rum Barrel";
enablenpc "Commander Povo";
enablenpc "Commander Cadis";
enablenpc "Phoenix Rebirth";
@@ -64,6 +65,7 @@ function script FTCleanup {
disablenpc "Xovilam";
disablenpc "Drahcir";
disablenpc "Selim";
+ disablenpc "Rum Barrel";
disablenpc "Commander Povo";
disablenpc "Commander Cadis";
disablenpc "Phoenix Rebirth";
diff --git a/npc/025-1/rum.txt b/npc/025-1/rum.txt
new file mode 100644
index 000000000..935582eb3
--- /dev/null
+++ b/npc/025-1/rum.txt
@@ -0,0 +1,181 @@
+// TMW2 Scripts
+// Author:
+// Jesusalva
+// Description:
+// Crazyfefe Rum
+// Variables:
+// FORTRESS_DATE = When the Rum started being done
+// FORTRESS_DONE = When the Rum will be ready
+// FORTRESS_AMMO = How much Rum you're trying to make
+// Success Rate is based on how much you're trying to do and how long ago that was
+
+025-1,106,56,0 script Rum Barrel NPC_NO_SPRITE,{
+ goto L_Main;
+ // rumbarrel_chance()
+ // Returns chance (0~10,000) to successfully obtain sake
+ // FORTRESS_DONE/FORTRESS_DATE is taken in account
+ function rumbarrel_chance {
+ .@max=10000;
+ .@base=FORTRESS_DATE;//-(FORTRESS_DONE-FORTRESS_DATE);
+ // .@c = how much time is left until completion
+ // .@d = original amount of time required
+ // .@e = Current time
+ .@c=FORTRESS_DONE-.@base; //-gettimetick(2);
+ .@d=FORTRESS_DATE-.@base; //-FORTRESS_DONE;
+ .@e=gettimetick(2)-.@base;
+
+ // We must divide everything by 10 to cause imprecision
+ // aka. don't cause overflow bug
+ .@c=.@c/10;
+ .@d=.@d/10;
+ .@e=.@e/10;
+
+ //debugmes "%d - %d - %d", .@d, .@e, .@c;
+ //debugmes "Start - Now - Finish";
+ if (.@c == 0)
+ return .@max;
+ if ($@GM_OVERRIDE) debugmes "Ratio: %d/%d = %d", .@e, .@c, (.@e*.@max)/.@c;
+ return min(10000, (.@e*.@max)/.@c);
+ }
+
+L_Main:
+ if (!FORTRESS_DATE) {
+ mesn;
+ mesc l("Do you want to make %s?", l("Rum"));
+ mesc l("This barrel is a courtesy from Dimond Cove Inn.");
+ next;
+ select
+ l("Information"),
+ l("Yes"),
+ l("No");
+ mes "";
+
+ switch (@menu) {
+ case 1:
+ mesc l("Produced item:");
+ mesc l("@@", getitemlink(CrazyRum));
+ mesc l("%s (rare)", getitemlink(WhiskeyAle));
+ mes "";
+ mesc l("Cost per %s glass:", l("twelve"));
+ mesc l("* @@/@@ @@", countitem(ArtichokeHerb), 25, getitemlink(ArtichokeHerb));
+ mesc l("* @@/@@ @@", countitem(Fungus), 25, getitemlink(Fungus));
+ mesc l("* @@/@@ @@", countitem(RedApple), 25, getitemlink(RedApple));
+ mesc l("* @@/@@ @@", countitem(Beer), 5, getitemlink(Beer));
+ mesc l("* @@/@@ @@", countitem(Milk), 25, getitemlink(Milk));
+ mesc l("* @@/@@ @@", countitem(ShadowHerb), 100, getitemlink(ShadowHerb));
+ mesc l("* @@ Water Bottle", 1);
+ next;
+ break;
+ case 2:
+ mesc l("How many batches do you want to produce? (max. 5)");
+ input .@glass_count;
+ if (.@glass_count < 1 ||
+ .@glass_count > 5 ||
+ countitem(ArtichokeHerb) < 25*.@glass_count ||
+ countitem(Fungus) < 25*.@glass_count ||
+ countitem(RedApple) < 25*.@glass_count ||
+ countitem(Beer) < 5*.@glass_count ||
+ countitem(Milk) < 25*.@glass_count ||
+ countitem(ShadowHerb) < 100*.@glass_count
+ ) {
+ mesc l("Not enough ingredients or invalid amount."), 1;
+ break;
+ }
+ mesc l("Which water will you use?");
+ mesc l("The bottom-most the water, the better the bonus.");
+ menuint
+ l("Cancel"), -1,
+ rif(countitem(BottleOfSewerWater) >= .@glass_count, l("Sewer Water")), 0,
+ rif(countitem(BottleOfSeaWater) >= .@glass_count, l("Sea Water")), 3600,
+ rif(countitem(BottleOfTonoriWater) >= .@glass_count, l("Tonori Water")), 11760,
+ rif(countitem(BottleOfWoodlandWater) >= .@glass_count, l("Woodland Water")), 12000,
+ rif(countitem(BottleOfDivineWater) >= .@glass_count, l("Divine Water")), 21600;
+ mes "";
+ if (@menuret < 0)
+ break;
+ switch (@menuret) {
+ case 0:
+ .@bonus=@menuret;
+ .@water=BottleOfSewerWater;
+ break;
+ case 3600:
+ .@bonus=@menuret;
+ .@water=BottleOfSeaWater;
+ break;
+ case 11760:
+ .@bonus=@menuret;
+ .@water=BottleOfTonoriWater;
+ break;
+ case 12000:
+ .@bonus=@menuret;
+ .@water=BottleOfWoodlandWater;
+ break;
+ case 21600:
+ .@bonus=@menuret;
+ .@water=BottleOfDivineWater;
+ break;
+ default:
+ mesc l("Error, invalid return code, blame Saulc"), 1;
+ mes "==== SCRIPT ABORTED";
+ close;
+ }
+
+ // Save data
+ delitem ArtichokeHerb, .@glass_count*25;
+ delitem Fungus, .@glass_count*25;
+ delitem RedApple, .@glass_count*25;
+ delitem Beer, .@glass_count*5;
+ delitem Milk, .@glass_count*25;
+ delitem ShadowHerb, .@glass_count*100;
+ delitem .@water, .@glass_count;
+ FORTRESS_AMMO=.@glass_count;
+ FORTRESS_DATE=gettimetick(2);
+ FORTRESS_DONE=gettimetick(2)-.@bonus+.mintime;
+ FORTRESS_DONE+=.cuptime*FORTRESS_AMMO;
+ break;
+ case 3:
+ close;
+ break;
+ }
+ goto L_Main;
+ } else {
+ mesn;
+ mesc l("Your request for @@ @@ are being fermented for @@.", FORTRESS_AMMO, getitemlink(CrazyRum), FuzzyTime(FORTRESS_DATE));
+ next;
+ inventoryplace CrazyRum, FORTRESS_AMMO;
+ mesn;
+ mes l("Trying to retrieve it now will have @@ % chance to be successful.", rumbarrel_chance()/100);
+ mes l("Attempt to retrieve it now?");
+ next;
+ if (askyesno() == ASK_YES) {
+ if (rand(1000,10000) < rumbarrel_chance()) {
+ mesc l("Success!"), 3;
+ if (false)
+ getitem WhiskeyAle, FORTRESS_AMMO*.cupammo;
+ else
+ getitem CrazyRum, FORTRESS_AMMO*.cupammo;
+ } else {
+ mesc l("The %s wasn't ready yet and you lost it...", l("Rum")), 1;
+ }
+ FORTRESS_DATE=0;
+ FORTRESS_AMMO=0;
+ }
+ }
+ close;
+
+OnInit:
+ .sex = G_OTHER;
+ .distance = 4;
+
+ // Time to make each batch (48 hours)
+ .cuptime=(60*60*48);
+ // Base time to make any amount of cups (120 hours - five days)
+ .mintime=(60*60*120);
+ // Amount of cups
+ .cupammo=12;
+ end;
+
+}
+
+
+