summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--db/re/item_db.conf2
-rw-r--r--npc/items/alcohol.txt33
2 files changed, 19 insertions, 16 deletions
diff --git a/db/re/item_db.conf b/db/re/item_db.conf
index be69c6082..1542b44d1 100644
--- a/db/re/item_db.conf
+++ b/db/re/item_db.conf
@@ -778,7 +778,7 @@ item_db: (
UseEffect: "EFFECT_HEAL"
Script: <"
@taste = 8;
- @Alcohol = 32;
+ @Alcohol = 16;
doevent "alcohol_sc::OnUse";
">
},
diff --git a/npc/items/alcohol.txt b/npc/items/alcohol.txt
index b5d187f67..cfe6258b3 100644
--- a/npc/items/alcohol.txt
+++ b/npc/items/alcohol.txt
@@ -55,26 +55,22 @@ OnUse:
.@bonus=getareausers(.@m$, .@x-10, .@y-10, .@x+10, .@y+10)-1;
@taste+=min(@taste*2, .@bonus);
- // Put the delay in ms. Each Alcohol point is 10 minutes.
+ // Alcohol EXP Bonus - ponderate average, so having more VIT doesn't means
+ // more experience - only more time (be careful when mixing alcohol!)
+ .@v=remaining_bonus(SC_CASH_PLUSEXP, true);
+ .@t=remaining_bonus(SC_CASH_PLUSEXP, false)/1000;
+
+ if (.@t) .@val1 = ponderate_avg(@taste, @Alcohol, .@v, .@t);
+ else .@val1 = @taste;
+
+ // Put the delay in ms.
.@delay = remaining_bonus(SC_CASH_PLUSEXP, false);
- .@delay += @Alcohol*.@deltatime;
- // Alcohol EXP Bonus sums to previous exp bonus
- .@val1 = remaining_bonus(SC_CASH_PLUSEXP, true);
- .@val1 += @taste;
+ .@delay = .@t + @Alcohol*.@deltatime;
- // Reset EXP Bonus
+ // Reset EXP Bonus based on the new cumulative delay and average exp bonus
sc_end SC_CASH_PLUSEXP;
sc_start SC_CASH_PLUSEXP, .@delay, .@val1;
- // Same goes for attack speed debuff
- // Except malus is recalculated
- .@delay = remaining_bonus(SC_ATTHASTE_INFINITY, false)+@Alcohol*.@deltatime;
- .@val1 = (ALC_THRESHOLD+@Alcohol)/2;
-
- // Reset Attack Speed Debuff
- sc_end SC_ATTHASTE_INFINITY;
- sc_start SC_ATTHASTE_INFINITY, .@delay, -.@val1;
-
// Recalculate Alcohol Threshold and time
ALC_THRESHOLD+=@Alcohol;
if (ALC_DELAYTIME < gettimetick(2))
@@ -83,6 +79,13 @@ OnUse:
// Debug comment if you need to check stuff
//debugmes "%d %d | %d %d | f t ", remaining_bonus(SC_CASH_PLUSEXP, false), remaining_bonus(SC_CASH_PLUSEXP, true), remaining_bonus(SC_ATTHASTE_INFINITY, false), remaining_bonus(SC_ATTHASTE_INFINITY, true);
+
+ // For debuff I'll use inc_sc_bonus utilities (exp gain = atk speed loss)
+ @min=-remaining_bonus(SC_CASH_PLUSEXP, true);
+ @max=-remaining_bonus(SC_CASH_PLUSEXP, true);
+ @type=SC_ATTHASTE_INFINITY;
+ @delay=@Alcohol*(.@deltatime/1000);
+ doevent "inc_sc_bonus::OnUse";
close;
}