1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
|
// TMW-2 Script
// Author:
// Jesusalva
// Description:
// Vault Utilities
function script getvaultid {
// FIXME: Make this False
if ($BETASERVER && !debug)
return ##VAULT;
else
return 0;
}
function script getvaultexp {
.@exp=getarg(0);
if (.@exp > 100)
Exception("ILLEGAL VAULT EXPERIENCE, FIXME URGENTLY. STOPPING SCRIPT BY FORCE WHILE DOING NOTHING.",
RB_DEBUGMES | RB_IRCBROADCAST | RB_GLOBALANNOUNCE | RB_ISFATAL);
if (getvaultid()) {
##VAULT_EXP+=.@exp;
consoleinfo("Granting %d Soul Exp to %d under the Moubootaur's authority.",
.@exp, ##VAULT);
}
return;
}
function script export_vault {
// Send updates to Vault API
if (getvaultid()) {
.@api$=json_encode("UID", ##VAULT,
"GID", getcharid(3),
"VAR1N", "CRQUEST",
"VAR1V", ##01_CRQUEST,
//"VAR2N", "CRWORLD",
//"VAR2V", ##01_CRWORLD,
"VEXP", ##VAULT_EXP,
"GOTO", ##VAULT_GOTO,
"MLTO", ##VAULT_MLTO);
##VAULT_EXP=0;
api_send(API_FLUSHVAULT, .@api$);
}
return;
}
// MirrorLakeSendTo(World, Lake)
function script MirrorLakeSendTo {
.@w=getarg(0);
.@t=getarg(1);
##VAULT_GOTO=.@w;
##VAULT_MLTO=.@t;
closeclientdialog;
dispbottom l("Darkness fills your vision...");
export_vault();
sleep2(500);
specialeffect FX_CIRCLE, SELF, getcharid(3);
sleep2(500);
specialeffect FX_MGSHIELD, SELF, getcharid(3);
sleep2(500);
kick(getcharid(3), 7); // 7 is not a valid kick reason
//atcommand("@kick "+strcharinfo(0));
end;
}
// BonusEXP({mobId})
function script BonusEXP {
// Only applies if you are not in TOP 3
if (BaseLevel >= TOP3AVERAGELVL())
return;
// Permanent Level Boost
if (#ADD_LVL) {
.@mobId=getarg(0, killedrid);
.@exp = min(#ADD_LVL, getmonsterinfo(.@mobId, MOB_BASEEXP) * 2);
getexp .@exp, 0;
#ADD_LVL-=.@exp;
/*
if ((readparam(BaseExp)+.@exp > readparam(NextBaseExp))) {
do {
if (BaseLevel >= TOP3AVERAGELVL()) break; // Boundaries
.@v=readparam(NextBaseExp)-readparam(BaseExp);
getexp .@v, 0;
#ADD_LVL-=.@v;
} while (readparam(BaseExp)+.@exp > readparam(NextBaseExp));
}
*/
}
return;
}
|