diff options
author | Jesusaves <cpntb1@ymail.com> | 2021-04-09 13:33:57 -0300 |
---|---|---|
committer | Jesusaves <cpntb1@ymail.com> | 2021-04-09 13:33:57 -0300 |
commit | cf18ce071c79ae37e14ea38943e0b1d88da70a7b (patch) | |
tree | f9159c9b60b3018300dd22ffba0d797bc5e828e5 /npc/magic/level2-summon-snakes.txt | |
parent | 8a4bf716002a017de77fe7df301ef8e4aaf00a2e (diff) | |
download | serverdata-cf18ce071c79ae37e14ea38943e0b1d88da70a7b.tar.gz serverdata-cf18ce071c79ae37e14ea38943e0b1d88da70a7b.tar.bz2 serverdata-cf18ce071c79ae37e14ea38943e0b1d88da70a7b.tar.xz serverdata-cf18ce071c79ae37e14ea38943e0b1d88da70a7b.zip |
Override
Diffstat (limited to 'npc/magic/level2-summon-snakes.txt')
-rwxr-xr-x | npc/magic/level2-summon-snakes.txt | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/npc/magic/level2-summon-snakes.txt b/npc/magic/level2-summon-snakes.txt new file mode 100755 index 00000000..a5add6f2 --- /dev/null +++ b/npc/magic/level2-summon-snakes.txt @@ -0,0 +1,57 @@ +- script summon-snakes NPC32767,{ + end; + +OnCast: + if(call("magic_checks")) end; + if (Sp < 40) end; + if (getskilllv(SKILL_MAGIC) < .level) end; + if (getskilllv(.school) < .level) end; + if (countitem("DarkCrystal") < 1 || countitem("SnakeEgg") < 1) end; + if (OrumQuest <= 40) end; + delitem "DarkCrystal", 1; + delitem "SnakeEgg", 1; + set @_M_BLOCK, 1; // block casting, until the timer clears it + addtimer 15000, "Magic Timer::OnClear"; // set the new debuff + callfunc "adjust_spellpower"; + Sp = Sp - 40; + misceffect FX_MAGIC_DARKRED, strcharinfo(0); + misceffect FX_PENTAGRAM_BUILDUP, strcharinfo(0); + callfunc "magic_exp"; + .@puppet$ = "#"+strnpcinfo(0)+"#"+BL_ID; + .@puppet = puppet(getmapname(), POS_X, POS_Y, .@puppet$, 127); + if (.@puppet < 1) end; + .count = (@spellpower/300)+1, .@puppet; + .master = BL_ID, .@puppet; + .lifetime = @spellpower*80, .@puppet; + addnpctimer 4000-(@spellpower*9), .@puppet$+"::OnSummon"; + addnpctimer 6000, .@puppet$+"::OnDestroy"; + end; + +OnSummon: + if(get(Hp, .master) < 1) destroy; // destroy if master is missing + if(getmap(.master) != strnpcinfo(3)) destroy; // destroy if master left the map + specialeffect FX_PENTAGRAM_BURST; + .@i = 0; + .@x = getnpcx(); + .@y = getnpcy(); + .@map$ = strnpcinfo(3); + callsub S_SummonAll; + end; + +OnDestroy: + destroy; + +S_SummonAll: + summon .@map$, rand(.@x-2,.@x+2), rand(.@y-2,.@y+2), .master, 1010, 2, .lifetime; + .@i = .@i + 1; + if (.@i < .count) goto S_SummonAll; + destroy; + +OnInit: + .school = SKILL_MAGIC_DARK; + set .invocation$, chr(MAGIC_SYMBOL) + "halhiss"; // used in npcs that refer to this spell + void call("magic_register", "OnCast"); + .level = 2; + .exp_gain = 3; + end; +} |