diff options
-rw-r--r-- | db/const.txt | 1 | ||||
-rw-r--r-- | db/quest_db.txt | 3 | ||||
-rw-r--r-- | db/re/item_db.txt | 20 | ||||
-rw-r--r-- | db/sc_config.txt | 799 | ||||
-rw-r--r-- | npc/re/guild/invest_main.txt | 1678 | ||||
-rw-r--r-- | npc/re/guild/invest_npc.txt | 66 | ||||
-rw-r--r-- | npc/re/instances/HazyForest.txt | 16 | ||||
-rw-r--r-- | npc/re/mobs/dungeons/gld_dun.txt | 52 | ||||
-rw-r--r-- | npc/re/mobs/dungeons/gld_re.txt | 100 | ||||
-rw-r--r-- | npc/re/scripts_monsters.conf | 2 | ||||
-rw-r--r-- | npc/re/warps/guildcastles.txt | 43 | ||||
-rw-r--r-- | src/common/mmo.h | 7 | ||||
-rw-r--r-- | src/config/const.h | 7 | ||||
-rw-r--r-- | src/map/atcommand.c | 27 | ||||
-rw-r--r-- | src/map/battle.c | 28 | ||||
-rw-r--r-- | src/map/clif.c | 59 | ||||
-rw-r--r-- | src/map/intif.c | 4 | ||||
-rw-r--r-- | src/map/mail.c | 26 | ||||
-rw-r--r-- | src/map/mail.h | 29 | ||||
-rw-r--r-- | src/map/map.c | 4 | ||||
-rw-r--r-- | src/map/npc.c | 3 | ||||
-rw-r--r-- | src/map/pc.c | 12 | ||||
-rw-r--r-- | src/map/pc.h | 2 | ||||
-rw-r--r-- | src/map/script.c | 191 | ||||
-rw-r--r-- | src/map/script.h | 12 | ||||
-rw-r--r-- | src/map/skill.c | 19 | ||||
-rw-r--r-- | src/map/status.c | 18 | ||||
-rw-r--r-- | src/map/status.h | 2 | ||||
-rw-r--r-- | src/map/trade.c | 35 | ||||
-rw-r--r-- | src/map/trade.h | 21 | ||||
-rw-r--r-- | src/map/unit.c | 2 |
31 files changed, 2621 insertions, 667 deletions
diff --git a/db/const.txt b/db/const.txt index 692958a92..a5e52cb38 100644 --- a/db/const.txt +++ b/db/const.txt @@ -1289,6 +1289,7 @@ SC_KINGS_GRACE 557 SC_TELEKINESIS_INTENSE 558 SC_OFFERTORIUM 559 SC_FRIGG_SONG 560 +SC_MONSTER_TRANSFORM 563 e_gasp 0 e_what 1 diff --git a/db/quest_db.txt b/db/quest_db.txt index 025a9e6ec..6b4108ad6 100644 --- a/db/quest_db.txt +++ b/db/quest_db.txt @@ -997,6 +997,9 @@ 7345,0,0,0,0,0,0,0,"List of Errands" 7346,0,0,0,0,0,0,0,"List of Errands" +// Hall of Abyss +7349,1800,0,0,0,0,0,0,"Vote" + // Port Malaya 7350,0,0,0,0,0,0,0,"Cautious Village" 7351,0,0,0,0,0,0,0,"Better than My Old Button" diff --git a/db/re/item_db.txt b/db/re/item_db.txt index 94a988e12..7696af4cb 100644 --- a/db/re/item_db.txt +++ b/db/re/item_db.txt @@ -5899,6 +5899,14 @@ 12646,Fried_Octopus_Legs,Fried Octopus Legs,2,20,,30,,,,,,,,,,,,,{},{},{} 12647,Sea_Ink,Sea Ink,2,20,,30,,,,,,,,,,,,,{},{},{} // +12658,Transformation_Scroll(Deviruchi),Transformation Scroll(Deviruchi),2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{ sc_start4 SC_MONSTER_TRANSFORM,1200000,1109,0,0,0; },{},{} +12659,Transformation_Scroll(Raydric),Transformation Scroll(Raydric),2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{ sc_start4 SC_MONSTER_TRANSFORM,1200000,1276,0,0,0; },{},{} +12660,Transformation_Scroll(Mavka),Transformation Scroll(Mavka),2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{ sc_start4 SC_MONSTER_TRANSFORM,1200000,1884,0,0,0; },{},{} +12661,Transformation_Scroll(Marduk),Transformation Scroll(Marduk),2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{ sc_start4 SC_MONSTER_TRANSFORM,1200000,1140,0,0,0; },{},{} +12662,Transformation_Scroll(Banshee),Transformation Scroll(Banshee),2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{ sc_start4 SC_MONSTER_TRANSFORM,1200000,1867,0,0,0; },{},{} +12663,Transformation_Scroll(Poring),Transformation Scroll(Poring),2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{ sc_start4 SC_MONSTER_TRANSFORM,1200000,1002,0,0,0; },{},{} +12664,Transformation_Scroll(Golem),Transformation Scroll(Golem),2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{ sc_start4 SC_MONSTER_TRANSFORM,1200000,1040,0,0,0; },{},{} +// 12699,Tikbalang_Belt,Tikbalang Belt,2,20,,50,,,,,0xFFFFFFFF,7,2,,,,,,{ pet 2313; },{},{} 12700,Upside_Down_Shirt,Upside Down Shirt,2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{ warp "malaya",242,211; },{},{} 12701,Old_Blue_Box_F,Old Blue Box,2,0,,10,,,,,0xFFFFFFFF,7,2,,,,,,{},{},{} @@ -7586,13 +7594,13 @@ 17030,St_Pat_Hat_box,St Pat Hat box,18,20,,100,,,,,0xFFFFFFFF,7,2,,,,,,{ getitem 18565,1; },{},{} 17035,Energetic_Pisces_Scroll,Energetic Pisces Scroll,2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{},{},{} 17036,Energetic_Pisces_Box,Energetic Pisces Box,2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{},{},{} -17037,Trans_Box_Devi,Trans Box Devi,2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{},{},{} -17038,Trans_Box_Ray_Arch,Trans Box Ray Arch,2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{},{},{} -17039,Trans_Box_Mavka,Trans Box Mavka,2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{},{},{} -17040,Trans_Box_Marduk,Trans Box Marduk,2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{},{},{} -17041,Trans_Box_Banshee,Trans Box Banshee,2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{},{},{} +17037,Trans_Box_Devi,Trans Box Devi,2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{ getitem 12658,10; },{},{} +17038,Trans_Box_Ray_Arch,Trans Box Ray Arch,2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{ getitem 12659,10; },{},{} +17039,Trans_Box_Mavka,Trans Box Mavka,2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{ getitem 12660,10; },{},{} +17040,Trans_Box_Marduk,Trans Box Marduk,2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{ getitem 12661,10; },{},{} +17041,Trans_Box_Banshee,Trans Box Banshee,2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{ getitem 12662,10; },{},{} 17042,Trans_Box_Poring,Trans Box Poring,18,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{ getitem 12663,10; },{},{} -17043,Trans_Box_Golem,Trans Box Golem,2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{},{},{} +17043,Trans_Box_Golem,Trans Box Golem,2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{ getitem 12664,10; },{},{} 17050,Aries_Scroll,Aries Scroll,2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{},{},{} 17051,Aries_Scroll_Box,Aries Scroll Box,2,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{},{},{} 17052,Holy_Mom_Blaze_Box,Holy Mom Blaze Box,18,20,,10,,,,,0xFFFFFFFF,7,2,,,,,,{ getitem 6472,1; },{},{} diff --git a/db/sc_config.txt b/db/sc_config.txt index 2da6f3147..06de0bdf6 100644 --- a/db/sc_config.txt +++ b/db/sc_config.txt @@ -3,405 +3,408 @@ // Structure of Database: // SC_NAME, flag // -// flag 0x1 - SC cannot be removed by death. -// 0x2 - SC cannot be saved. -// 0x4 - SC cannot be reset by dispell. -// 0x8 - SC cannot be reset by clearance. -// 0x10 - SC considered as buff and be removed by Hermode and etc. -// 0x20 - SC considered as debuff and be removed by Gospel and etc. -// 0x40 - SC cannot be reset when MADO Gear is taken off. +// flag 1 - SC cannot be removed by death. +// 2 - SC cannot be saved. +// 4 - SC cannot be reset by dispell. +// 8 - SC cannot be reset by clearance. +// 16 - SC considered as buff and be removed by Hermode and etc. +// 32 - SC considered as debuff and be removed by Gospel and etc. +// 64 - SC cannot be reset when MADO Gear is taken off. +//Example: +//SC_ENDURE, 21 //SC_ENDURE: cannot be removed by death and dispell and cosidered as buff. (16 + 4 + 1 = 21) -SC_PROVOKE, 0x20 -SC_ENDURE, 0x15 -SC_TWOHANDQUICKEN, 0x18 -SC_CONCENTRATION, 0x10 -SC_ENCHANTPOISON, 0x10 -SC_POISONREACT, 0x10 -SC_QUAGMIRE, 0x2A -SC_ANGELUS, 0x10 -SC_BLESSING, 0x50 -SC_INC_AGI, 0x50 -SC_DEC_AGI, 0x22 -SC_SLOWPOISON, 0x18 -SC_IMPOSITIO, 0x10 -SC_SUFFRAGIUM, 0x10 -SC_ASPERSIO, 0x50 -SC_BENEDICTIO, 0x1A -SC_KYRIE, 0x10 -SC_MAGNIFICAT, 0x12 -SC_GLORIA, 0x10 -SC_LEXAETERNA, 0x12 -SC_ADRENALINE, 0x10 -SC_WEAPONPERFECT, 0x10 -SC_OVERTHRUST, 0x10 -SC_MAXIMIZEPOWER, 0x10 -SC_TRICKDEAD, 0x1A -SC_SHOUT, 0x10 -SC_ENERGYCOAT, 0x10 -SC_ATTHASTE_POTION1, 0x18 -SC_ATTHASTE_POTION2, 0x18 -SC_ATTHASTE_POTION3, 0x10 -//SC_MOVHASTE_POTION, 0x1A -//SC_POSTDELAY, 0x1D -SC_BARRIER, 0x10 -SC_NOEQUIPWEAPON, 0x1E -SC_NOEQUIPSHIELD, 0x1E -SC_NOEQUIPARMOR, 0x1E -SC_NOEQUIPHELM, 0x1E -SC_PROTECTWEAPON, 0x1C -SC_PROTECTSHIELD, 0x1C -SC_PROTECTARMOR, 0x1C -SC_PROTECTHELM, 0x1C -SC_AUTOGUARD, 0x18 -SC_REFLECTSHIELD, 0x18 -SC_DEVOTION, 0x12 -SC_PROVIDENCE, 0x12 -SC_DEFENDER, 0x10 -SC_MAGICROD, 0x1A -//SC_WEAPONPROPERTY, 0x18 -SC_AUTOSPELL, 0x15 -//SC_SPECIALZONE, 0x1A -//SC_MASK, 0x1A -SC_SPEARQUICKEN, 0x10 -SC_BLADESTOP, 0x1A -SC_EXPLOSIONSPIRITS, 0x1A -SC_STEELBODY, 0x12 -SC_PROPERTYFIRE, 0x1D -SC_PROPERTYWATER, 0x1D -SC_PROPERTYWIND, 0x1D -SC_PROPERTYGROUND, 0x1D -SC_STOP, 0x1A -SC_PROPERTYUNDEAD, 0x1A -//SC_STATUSONE, 0x1A -SC_AURABLADE, 0x12 -SC_PARRYING, 0x1A -SC_LKCONCENTRATION, 0x12 -SC_TENSIONRELAX, 0x1A -SC_BERSERK, 0x12 -SC_SACRIFICE, 0x1A -SC_GOSPEL, 0x22 -SC_ASSUMPTIO, 0x10 -SC_BASILICA, 0x1A -//SC_GROUNDMAGIC, 0x1A //is divided to SC_VOLCANO, 0xSC_DELUGE, 0xSC_VIOLENTGALE -SC_VOLCANO, 0x1A -SC_DELUGE, 0x1A -SC_VIOLENTGALE, 0x1A -SC_MAGICPOWER, 0x12 -SC_EDP, 0x17 -SC_TRUESIGHT, 0x12 -SC_WINDWALK, 0x12 -SC_MELTDOWN, 0x17 -SC_CARTBOOST, 0x17 -SC_BLOODING, 0x1A -SC_JOINTBEAT, 0x2A -SC_MINDBREAKER, 0x12 -SC_MEMORIZE, 0x12 -SC_FOGWALL, 0x1A -SC_SPIDERWEB, 0x2F -//SC_SUB_WEAPONPROPERTY, 0x17 -SC_RUN, 0x1A -SC_STRUP, 0x1A -SC_PROPERTYDARK, 0x1A -SC_ADRENALINE2, 0x12 -SC_PROPERTYTELEKINESIS, 0x1A -SC_SOULLINK, 0x1A -SC_PLUSATTACKPOWER, 0x58 -SC_PLUSMAGICPOWER, 0x58 -SC_KAITE, 0x1A -SC_KAAHI, 0x1A -SC_KAUPE, 0x1A -SC_ONEHANDQUICKEN, 0x1A -//SC_GDSKILL_POSTDELAY, 0x1D -SC_PRESERVE, 0x12 -SC_CHASEWALK2, 0x1A -//SC_MOVESLOW_POTION, 0x1A -SC_DOUBLECASTING, 0x1A -SC_GRAVITATION, 0x1A -SC_OVERTHRUSTMAX, 0x12 -SC_TAROTCARD, 0x2A -SC_CR_SHRINK, 0x17 -SC_WZ_SIGHTBLASTER, 0x17 -SC_RG_CCONFINE_M, 0x1F -SC_RG_CCONFINE_S, 0x1F -SC_NJ_UTSUSEMI, 0x1A -SC_NJ_BUNSINJYUTSU, 0x1A -SC_NJ_SUITON, 0x2F -//SC_MENTAL, 0x1A -//SC_EXPMEMORY, 0x1A -//SC_PERFORMANCE, 0x1A -//SC_GAIN, 0x1A -//SC_DRIFT, 0x1A -//SC_WALLSHIFT, 0x1A -//SC_REINCARNATION, 0x1A -//SC_DENERGY, 0x1A -//SC_DAURA, 0x1A -//SC_DFREEZER, 0x1A -//SC_DPUNISH, 0x1A -//SC_DBARRIER, 0x1A -//SC_DWARNING, 0x1A -//SC_MOUSEWHEEL, 0x1E -//SC_DACCEL, 0x1A -//SC_DBLOCK, 0x1A -SC_FOOD_STR, 0x1C -SC_FOOD_AGI, 0x1C -SC_FOOD_VIT, 0x1C -SC_FOOD_DEX, 0x1C -SC_FOOD_INT, 0x1C -SC_FOOD_LUK, 0x1C -SC_FOOD_BASICAVOIDANCE, 0x58 -SC_FOOD_BASICHIT, 0x58 -//SC_FOOD_CRITICALSUCCESSVALUE, 0x18 -SC_CASH_PLUSEXP, 0x1D -SC_CASH_DEATHPENALTY, 0x1D -SC_CASH_RECEIVEITEM, 0x1D -SC_CASH_BOSS_ALARM, 0x1E -//SC_DA_ENERGY, 0x1A -//SC_DA_FIRSTSLOT, 0x1A -//SC_DA_HEADDEF, 0x1A -//SC_DA_SPACE, 0x1E -//SC_DA_ITEMREBUILD, 0x1E -//SC_DA_ILLUSION, 0x1A -//SC_DA_EARPLUG, 0x1E -//SC_DA_CONTRACT, 0x1D -//SC_DA_BLACK, 0x1E -//SC_DA_MAGICCART, 0x1A -//SC_CRYSTAL, 0x1E -//SC_DA_REBUILD, 0x1D -//SC_DA_EDARKNESS, 0x1A -//SC_DA_EGUARDIAN, 0x1A -//SC_DA_TIMEOUT, 0x1A -SC_FOOD_STR_CASH, 0x1D -SC_FOOD_AGI_CASH, 0x1D -SC_FOOD_VIT_CASH, 0x1D -SC_FOOD_DEX_CASH, 0x1D -SC_FOOD_INT_CASH, 0x1D -SC_FOOD_LUK_CASH, 0x1D -SC_MER_FLEE, 0x1C -SC_MER_ATK, 0x1C -SC_MER_HP, 0x1C -SC_MER_SP, 0x1C -SC_MER_HIT, 0x1C -SC_SLOWCAST, 0x1F -SC_CRITICALWOUND, 0x17 -SC_MOVHASTE_HORSE, 0x1F -SC_PROTECT_DEF, 0x1C -SC_PROTECT_MDEF, 0x1C -SC_HEALPLUS, 0x5C -SC_S_LIFEPOTION, 0x5C -SC_L_LIFEPOTION, 0x5C -SC_CRITICALPERCENT, 0x5C -SC_PLUSAVOIDVALUE, 0x5C -//SC_ATKER_ASPD, 0x1C -//SC_TARGET_ASPD, 0x5C -//SC_ATKER_MOVESPEED, 0x1C -SC_ATKER_BLOOD, 0x1C -SC_TARGET_BLOOD, 0x1E -SC_ARMOR_PROPERTY, 0x1D -//SC_REUSE_LIMIT_A, 0x1D -SC_HELLPOWER, 0x1D -//SC_STEAMPACK, 0x5C -//SC_REUSE_LIMIT_B, 0x1D -//SC_REUSE_LIMIT_C, 0x1D -//SC_REUSE_LIMIT_D, 0x1D -//SC_REUSE_LIMIT_E, 0x1D -//SC_REUSE_LIMIT_F, 0x1D -SC_CASH_PLUSONLYJOBEXP, 0x1D -SC_PARTYFLEE, 0x18 -//SC_ANGEL_PROTECT, 0x18 -//SC_ENDURE_MDEF, 0x15 -SC_ENCHANTBLADE, 0x10 -SC_DEATHBOUND, 0x1E -SC_REFRESH, 0x16 -SC_GIANTGROWTH, 0x14 -SC_STONEHARDSKIN, 0x17 -SC_VITALITYACTIVATION, 0x14 -SC_FIGHTINGSPIRIT, 0x14 -SC_ABUNDANCE, 0x14 -//SC_REUSE_MILLENNIUMSHIELD, 0x1D -//SC_REUSE_CRUSHSTRIKE, 0x1D -//SC_REUSE_REFRESH, 0x1D -//SC_REUSE_STORMBLAST, 0x1D -SC_EPICLESIS, 0x1D -SC_ORATIO, 0x14 -SC_LAUDAAGNUS, 0x14 -SC_LAUDARAMUS, 0x14 -SC_CLOAKINGEXCEED, 0x1E -SC_HALLUCINATIONWALK, 0x1C -SC_HALLUCINATIONWALK_POSTDELAY, 0x1F -SC_RENOVATIO, 0x14 -SC_WEAPONBLOCKING, 0x1C -//SC_WEAPONBLOCKING_POSTDELAY, 0x1F -SC_ROLLINGCUTTER, 0x1E -SC_EXPIATIO, 0x14 -SC_POISONINGWEAPON, 0x1C -SC_TOXIN, 0x14 -SC_PARALYSE, 0x14 -SC_VENOMBLEED, 0x14 -SC_MAGICMUSHROOM, 0x14 -SC_DEATHHURT, 0x14 -SC_PYREXIA, 0x14 -SC_OBLIVIONCURSE, 0x14 -SC_LEECHESEND, 0x14 -SC_DUPLELIGHT, 0x14 -SC_FEARBREEZE, 0x1C -SC_ELECTRICSHOCKER, 0x1E -SC_MARSHOFABYSS, 0x14 -SC_RECOGNIZEDSPELL, 0x14 -//SC_WUGRIDER, 0x1D -SC_WUGDASH, 0x1E -SC_WUGBITE, 0x1E -SC_CAMOUFLAGE, 0x1E -SC_ACCELERATION, 0x1C -SC_HOVERING, 0x1C -SC_SUMMON1, 0x18 -SC_SUMMON2, 0x18 -SC_SUMMON3, 0x18 -SC_SUMMON4, 0x18 -SC_SUMMON5, 0x18 -//SC_MVPCARD_TAOGUNKA, 0x1C -//SC_MVPCARD_MISTRESS, 0x1C -//SC_MVPCARD_ORCHERO, 0x1C -//SC_MVPCARD_ORCLORD, 0x1C -SC_OVERHEAT_LIMITPOINT, 0x1C -SC_OVERHEAT, 0x1C -SC_SHAPESHIFT, 0x1C -SC_INFRAREDSCAN, 0x1C -SC_MAGNETICFIELD, 0x1E -SC_NEUTRALBARRIER, 0x1E -SC_NEUTRALBARRIER_MASTER, 0x1E -SC_STEALTHFIELD_MASTER, 0x1E -SC_MANU_ATK, 0x1C -SC_MANU_DEF, 0x1C -SC_SPL_ATK, 0x1C -SC_SPL_DEF, 0x1C -SC__REPRODUCE, 0x1C -SC_MANU_MATK, 0x1C -SC_SPL_MATK, 0x1C -//SC_STR_SCROLL, 0x1D -//SC_INT_SCROLL, 0x1D -SC_FORCEOFVANGUARD, 0x1C -//SC_BUCHEDENOEL, 0x1C -SC__AUTOSHADOWSPELL, 0x10 -SC__SHADOWFORM, 0x1E -SC_RAID, 0x1C -SC_SHIELDSPELL_DEF, 0x10 -SC_SHIELDSPELL_MDEF, 0x10 -SC_SHIELDSPELL_REF, 0x10 -SC__BODYPAINT, 0x14 -SC_EXEEDBREAK, 0x1C -SC_ADORAMUS, 0x10 -SC_PRESTIGE, 0x10 -SC__INVISIBILITY, 0x1E -SC__DEADLYINFECT, 0x14 -SC_BANDING, 0x1C -SC_BANDING_DEFENCE, 0x1C -SC_EARTHDRIVE, 0x14 -SC_INSPIRATION, 0x1C -SC__ENERVATION, 0x10 -SC__GROOMY, 0x10 -SC_RAISINGDRAGON, 0x1E -SC__IGNORANCE, 0x10 -SC__LAZINESS, 0x10 -SC_LIGHTNINGWALK, 0x1C -//SC_ACARAJE, 0x18 -SC__UNLUCKY, 0x10 -SC_CURSEDCIRCLE_ATKER, 0x1C -SC_CURSEDCIRCLE_TARGET, 0x1C -SC__WEAKNESS, 0x10 -SC_CRESCENTELBOW, 0x1C -//SC_NOEQUIPACCESSARY, 0x1E -SC__STRIPACCESSARY, 0x1C -SC__MANHOLE, 0x5E -//SC_POPECOOKIE, 0x1C -SC__BLOODYLUST, 0x20 -SC_SWING, 0x1C -SC_SYMPHONY_LOVE, 0x1C -SC_PROPERTYWALK, 0x12 -SC_SPELLFIST, 0x10 -SC_NETHERWORLD, 0x10 -SC_SIREN, 0x10 -SC_DEEP_SLEEP, 0x22 -SC_SIRCLEOFNATURE, 0x10 -SC_GLOOMYDAY, 0x10 -SC_GLOOMYDAY_SK, 0x10 -SC_SONG_OF_MANA, 0x10 -SC_DANCE_WITH_WUG, 0x10 -SC_RUSH_WINDMILL, 0x1C -SC_ECHOSONG, 0x1C -SC_HARMONIZE, 0x10 -SC_MOONLIT_SERENADE, 0x1C -SC_SATURDAY_NIGHT_FEVER, 0x10 -SC_SITDOWN_FORCE, 0x1C -SC_ANALYZE, 0x1C -SC_LERADS_DEW, 0x1C -SC_MELODYOFSINK, 0x1C -SC_BEYOND_OF_WARCRY, 0x1C -SC_UNLIMITED_HUMMING_VOICE, 0x1C -SC_WARMER, 0x2 -SC_VENOMIMPRESS, 0x4 -SC_FROSTMISTY, 0x20 -//SC_ASSUMPTIO2, 0x10 -//SC_GN_TRAINING_SWORD, 0x1F -//SC_GN_REMODELING_CART, 0x1F -SC_STOMACHACHE, 0x20 -SC_MYSTERIOUS_POWDER, 0x20 -//SC_ELEMENTAL_AGGRESSIVE, 0x2 -//SC_ELEMENTAL_WAIT, 0x2 -//SC_ELEMENTAL_PASSIVE, 0x2 -//SC_ELEMENTAL_DEFENSIVE, 0x2 -SC_WATER_BARRIER, 0x2 -SC_ZEPHYR, 0x2 -SC_POWER_OF_GAIA, 0x2 -SC_FIRE_INSIGNIA, 0x2 -SC_WATER_INSIGNIA, 0x2 -SC_WIND_INSIGNIA, 0x2 -SC_EARTH_INSIGNIA, 0x2 -//SC_MORA_BUFF, 0x2 -//SC_REUSE_LIMIT_G, 0x1D -//SC_REUSE_LIMIT_H, 0x1D -SC_NEEDLE_OF_PARALYZE, 0x1 -SC_PAIN_KILLER, 0x1 -//SC_G_LIFEPOTION, 0x44 -//SC_VITALIZE_POTION, 0x4 -SC_LIGHT_OF_REGENE, 0x1 -//SC_SONIC_CLAW_POSTDELAY, 0x2 -//SC_SILVERVEIN_RUSH_POSTDELAY, 0x2 -//SC_MIDNIGHT_FRENZY_POSTDELAY, 0x2 -//SC_TINDER_BREAKER, 0x2 -//SC_TINDER_BREAKER_POSTDELAY, 0x2 -//SC_CBC, 0x2 -//SC_CBC_POSTDELAY, 0x2 -//SC_EQC, 0x2 -//SC_MAGIC_CANDY, 0x5C -//SC_ALL_RIDING_REUSE_LIMIT, 0x1 -//SC_HANDICAPSTATE_DEEP_SLEEP, 0x50 +SC_PROVOKE, 32 +SC_ENDURE, 21 +SC_TWOHANDQUICKEN, 24 +SC_CONCENTRATION, 16 +SC_ENCHANTPOISON, 16 +SC_POISONREACT, 16 +SC_QUAGMIRE, 42 +SC_ANGELUS, 16 +SC_BLESSING, 80 +SC_INC_AGI, 80 +SC_DEC_AGI, 34 +SC_SLOWPOISON, 24 +SC_IMPOSITIO, 16 +SC_SUFFRAGIUM, 16 +SC_ASPERSIO, 80 +SC_BENEDICTIO, 26 +SC_KYRIE, 16 +SC_MAGNIFICAT, 18 +SC_GLORIA, 16 +SC_LEXAETERNA, 18 +SC_ADRENALINE, 16 +SC_WEAPONPERFECT, 16 +SC_OVERTHRUST, 16 +SC_MAXIMIZEPOWER, 16 +SC_TRICKDEAD, 26 +SC_SHOUT, 16 +SC_ENERGYCOAT, 16 +SC_ATTHASTE_POTION1, 24 +SC_ATTHASTE_POTION2, 24 +SC_ATTHASTE_POTION3, 16 +//SC_MOVHASTE_POTION, 26 +//SC_POSTDELAY, 29 +SC_BARRIER, 16 +SC_NOEQUIPWEAPON, 30 +SC_NOEQUIPSHIELD, 30 +SC_NOEQUIPARMOR, 30 +SC_NOEQUIPHELM, 30 +SC_PROTECTWEAPON, 28 +SC_PROTECTSHIELD, 28 +SC_PROTECTARMOR, 28 +SC_PROTECTHELM, 28 +SC_AUTOGUARD, 24 +SC_REFLECTSHIELD, 24 +SC_DEVOTION, 18 +SC_PROVIDENCE, 18 +SC_DEFENDER, 16 +SC_MAGICROD, 26 +//SC_WEAPONPROPERTY, 24 +SC_AUTOSPELL, 21 +//SC_SPECIALZONE, 26 +//SC_MASK, 26 +SC_SPEARQUICKEN, 16 +SC_BLADESTOP, 26 +SC_EXPLOSIONSPIRITS, 26 +SC_STEELBODY, 18 +SC_PROPERTYFIRE, 29 +SC_PROPERTYWATER, 29 +SC_PROPERTYWIND, 29 +SC_PROPERTYGROUND, 29 +SC_STOP, 26 +SC_PROPERTYUNDEAD, 26 +//SC_STATUSONE, 26 +SC_AURABLADE, 18 +SC_PARRYING, 26 +SC_LKCONCENTRATION, 18 +SC_TENSIONRELAX, 26 +SC_BERSERK, 18 +SC_SACRIFICE, 26 +SC_GOSPEL, 34 +SC_ASSUMPTIO, 16 +SC_BASILICA, 26 +//SC_GROUNDMAGIC, 26 //is divided to SC_VOLCANO, 0xSC_DELUGE, 0xSC_VIOLENTGALE +SC_VOLCANO, 26 +SC_DELUGE, 26 +SC_VIOLENTGALE, 26 +SC_MAGICPOWER, 18 +SC_EDP, 23 +SC_TRUESIGHT, 18 +SC_WINDWALK, 18 +SC_MELTDOWN, 23 +SC_CARTBOOST, 23 +SC_BLOODING, 26 +SC_JOINTBEAT, 42 +SC_MINDBREAKER, 18 +SC_MEMORIZE, 18 +SC_FOGWALL, 26 +SC_SPIDERWEB, 47 +//SC_SUB_WEAPONPROPERTY, 23 +SC_RUN, 26 +SC_STRUP, 26 +SC_PROPERTYDARK, 26 +SC_ADRENALINE2, 18 +SC_PROPERTYTELEKINESIS, 26 +SC_SOULLINK, 26 +SC_PLUSATTACKPOWER, 88 +SC_PLUSMAGICPOWER, 88 +SC_KAITE, 26 +SC_KAAHI, 26 +SC_KAUPE, 26 +SC_ONEHANDQUICKEN, 26 +//SC_GDSKILL_POSTDELAY, 29 +SC_PRESERVE, 18 +SC_CHASEWALK2, 26 +//SC_MOVESLOW_POTION, 26 +SC_DOUBLECASTING, 26 +SC_GRAVITATION, 26 +SC_OVERTHRUSTMAX, 18 +SC_TAROTCARD, 42 +SC_CR_SHRINK, 23 +SC_WZ_SIGHTBLASTER, 23 +SC_RG_CCONFINE_M, 31 +SC_RG_CCONFINE_S, 31 +SC_NJ_UTSUSEMI, 26 +SC_NJ_BUNSINJYUTSU, 26 +SC_NJ_SUITON, 47 +//SC_MENTAL, 26 +//SC_EXPMEMORY, 26 +//SC_PERFORMANCE, 26 +//SC_GAIN, 26 +//SC_DRIFT, 26 +//SC_WALLSHIFT, 26 +//SC_REINCARNATION, 26 +//SC_DENERGY, 26 +//SC_DAURA, 26 +//SC_DFREEZER, 26 +//SC_DPUNISH, 26 +//SC_DBARRIER, 26 +//SC_DWARNING, 26 +//SC_MOUSEWHEEL, 30 +//SC_DACCEL, 26 +//SC_DBLOCK, 26 +SC_FOOD_STR, 28 +SC_FOOD_AGI, 28 +SC_FOOD_VIT, 28 +SC_FOOD_DEX, 28 +SC_FOOD_INT, 28 +SC_FOOD_LUK, 28 +SC_FOOD_BASICAVOIDANCE, 88 +SC_FOOD_BASICHIT, 88 +//SC_FOOD_CRITICALSUCCESSVALUE, 24 +SC_CASH_PLUSEXP, 29 +SC_CASH_DEATHPENALTY, 29 +SC_CASH_RECEIVEITEM, 29 +SC_CASH_BOSS_ALARM, 30 +//SC_DA_ENERGY, 26 +//SC_DA_FIRSTSLOT, 26 +//SC_DA_HEADDEF, 26 +//SC_DA_SPACE, 30 +//SC_DA_ITEMREBUILD, 30 +//SC_DA_ILLUSION, 26 +//SC_DA_EARPLUG, 30 +//SC_DA_CONTRACT, 29 +//SC_DA_BLACK, 30 +//SC_DA_MAGICCART, 26 +//SC_CRYSTAL, 30 +//SC_DA_REBUILD, 29 +//SC_DA_EDARKNESS, 26 +//SC_DA_EGUARDIAN, 26 +//SC_DA_TIMEOUT, 26 +SC_FOOD_STR_CASH, 29 +SC_FOOD_AGI_CASH, 29 +SC_FOOD_VIT_CASH, 29 +SC_FOOD_DEX_CASH, 29 +SC_FOOD_INT_CASH, 29 +SC_FOOD_LUK_CASH, 29 +SC_MER_FLEE, 28 +SC_MER_ATK, 28 +SC_MER_HP, 28 +SC_MER_SP, 28 +SC_MER_HIT, 28 +SC_SLOWCAST, 31 +SC_CRITICALWOUND, 23 +SC_MOVHASTE_HORSE, 31 +SC_PROTECT_DEF, 28 +SC_PROTECT_MDEF, 28 +SC_HEALPLUS, 92 +SC_S_LIFEPOTION, 92 +SC_L_LIFEPOTION, 92 +SC_CRITICALPERCENT, 92 +SC_PLUSAVOIDVALUE, 92 +//SC_ATKER_ASPD, 28 +//SC_TARGET_ASPD, 92 +//SC_ATKER_MOVESPEED, 28 +SC_ATKER_BLOOD, 28 +SC_TARGET_BLOOD, 30 +SC_ARMOR_PROPERTY, 29 +//SC_REUSE_LIMIT_A, 29 +SC_HELLPOWER, 29 +//SC_STEAMPACK, 92 +//SC_REUSE_LIMIT_B, 29 +//SC_REUSE_LIMIT_C, 29 +//SC_REUSE_LIMIT_D, 29 +//SC_REUSE_LIMIT_E, 29 +//SC_REUSE_LIMIT_F, 29 +SC_CASH_PLUSONLYJOBEXP, 29 +SC_PARTYFLEE, 24 +//SC_ANGEL_PROTECT, 24 +//SC_ENDURE_MDEF, 21 +SC_ENCHANTBLADE, 16 +SC_DEATHBOUND, 30 +SC_REFRESH, 22 +SC_GIANTGROWTH, 20 +SC_STONEHARDSKIN, 23 +SC_VITALITYACTIVATION, 20 +SC_FIGHTINGSPIRIT, 20 +SC_ABUNDANCE, 20 +//SC_REUSE_MILLENNIUMSHIELD, 29 +//SC_REUSE_CRUSHSTRIKE, 29 +//SC_REUSE_REFRESH, 29 +//SC_REUSE_STORMBLAST, 29 +SC_EPICLESIS, 29 +SC_ORATIO, 20 +SC_LAUDAAGNUS, 20 +SC_LAUDARAMUS, 20 +SC_CLOAKINGEXCEED, 30 +SC_HALLUCINATIONWALK, 28 +SC_HALLUCINATIONWALK_POSTDELAY, 31 +SC_RENOVATIO, 20 +SC_WEAPONBLOCKING, 28 +//SC_WEAPONBLOCKING_POSTDELAY, 31 +SC_ROLLINGCUTTER, 30 +SC_EXPIATIO, 20 +SC_POISONINGWEAPON, 28 +SC_TOXIN, 20 +SC_PARALYSE, 20 +SC_VENOMBLEED, 20 +SC_MAGICMUSHROOM, 20 +SC_DEATHHURT, 20 +SC_PYREXIA, 20 +SC_OBLIVIONCURSE, 20 +SC_LEECHESEND, 20 +SC_DUPLELIGHT, 20 +SC_FEARBREEZE, 28 +SC_ELECTRICSHOCKER, 30 +SC_MARSHOFABYSS, 20 +SC_RECOGNIZEDSPELL, 20 +//SC_WUGRIDER, 29 +SC_WUGDASH, 30 +SC_WUGBITE, 30 +SC_CAMOUFLAGE, 30 +SC_ACCELERATION, 28 +SC_HOVERING, 28 +SC_SUMMON1, 24 +SC_SUMMON2, 24 +SC_SUMMON3, 24 +SC_SUMMON4, 24 +SC_SUMMON5, 24 +//SC_MVPCARD_TAOGUNKA, 28 +//SC_MVPCARD_MISTRESS, 28 +//SC_MVPCARD_ORCHERO, 28 +//SC_MVPCARD_ORCLORD, 28 +SC_OVERHEAT_LIMITPOINT, 28 +SC_OVERHEAT, 28 +SC_SHAPESHIFT, 28 +SC_INFRAREDSCAN, 28 +SC_MAGNETICFIELD, 30 +SC_NEUTRALBARRIER, 30 +SC_NEUTRALBARRIER_MASTER, 30 +SC_STEALTHFIELD_MASTER, 30 +SC_MANU_ATK, 28 +SC_MANU_DEF, 28 +SC_SPL_ATK, 28 +SC_SPL_DEF, 28 +SC__REPRODUCE, 28 +SC_MANU_MATK, 28 +SC_SPL_MATK, 28 +//SC_STR_SCROLL, 29 +//SC_INT_SCROLL, 29 +SC_FORCEOFVANGUARD, 28 +//SC_BUCHEDENOEL, 28 +SC__AUTOSHADOWSPELL, 16 +SC__SHADOWFORM, 30 +SC_RAID, 28 +SC_SHIELDSPELL_DEF, 16 +SC_SHIELDSPELL_MDEF, 16 +SC_SHIELDSPELL_REF, 16 +SC__BODYPAINT, 20 +SC_EXEEDBREAK, 28 +SC_ADORAMUS, 16 +SC_PRESTIGE, 16 +SC__INVISIBILITY, 30 +SC__DEADLYINFECT, 20 +SC_BANDING, 28 +SC_BANDING_DEFENCE, 28 +SC_EARTHDRIVE, 20 +SC_INSPIRATION, 28 +SC__ENERVATION, 16 +SC__GROOMY, 16 +SC_RAISINGDRAGON, 30 +SC__IGNORANCE, 16 +SC__LAZINESS, 16 +SC_LIGHTNINGWALK, 28 +//SC_ACARAJE, 24 +SC__UNLUCKY, 16 +SC_CURSEDCIRCLE_ATKER, 28 +SC_CURSEDCIRCLE_TARGET, 28 +SC__WEAKNESS, 16 +SC_CRESCENTELBOW, 28 +//SC_NOEQUIPACCESSARY, 30 +SC__STRIPACCESSARY, 28 +SC__MANHOLE, 94 +//SC_POPECOOKIE, 28 +SC__BLOODYLUST, 32 +SC_SWING, 28 +SC_SYMPHONY_LOVE, 28 +SC_PROPERTYWALK, 18 +SC_SPELLFIST, 16 +SC_NETHERWORLD, 16 +SC_SIREN, 16 +SC_DEEP_SLEEP, 34 +SC_SIRCLEOFNATURE, 16 +SC_GLOOMYDAY, 16 +SC_GLOOMYDAY_SK, 16 +SC_SONG_OF_MANA, 16 +SC_DANCE_WITH_WUG, 16 +SC_RUSH_WINDMILL, 28 +SC_ECHOSONG, 28 +SC_HARMONIZE, 16 +SC_MOONLIT_SERENADE, 28 +SC_SATURDAY_NIGHT_FEVER, 16 +SC_SITDOWN_FORCE, 28 +SC_ANALYZE, 28 +SC_LERADS_DEW, 28 +SC_MELODYOFSINK, 28 +SC_BEYOND_OF_WARCRY, 28 +SC_UNLIMITED_HUMMING_VOICE, 28 +SC_WARMER, 2 +SC_VENOMIMPRESS, 4 +SC_FROSTMISTY, 32 +//SC_ASSUMPTIO2, 16 +//SC_GN_TRAINING_SWORD, 31 +//SC_GN_REMODELING_CART, 31 +SC_STOMACHACHE, 32 +SC_MYSTERIOUS_POWDER, 32 +//SC_ELEMENTAL_AGGRESSIVE, 2 +//SC_ELEMENTAL_WAIT, 2 +//SC_ELEMENTAL_PASSIVE, 2 +//SC_ELEMENTAL_DEFENSIVE, 2 +SC_WATER_BARRIER, 2 +SC_ZEPHYR, 2 +SC_POWER_OF_GAIA, 2 +SC_FIRE_INSIGNIA, 2 +SC_WATER_INSIGNIA, 2 +SC_WIND_INSIGNIA, 2 +SC_EARTH_INSIGNIA, 2 +//SC_MORA_BUFF, 2 +//SC_REUSE_LIMIT_G, 29 +//SC_REUSE_LIMIT_H, 29 +SC_NEEDLE_OF_PARALYZE, 1 +SC_PAIN_KILLER, 1 +//SC_G_LIFEPOTION, 68 +//SC_VITALIZE_POTION, 4 +SC_LIGHT_OF_REGENE, 1 +//SC_SONIC_CLAW_POSTDELAY, 2 +//SC_SILVERVEIN_RUSH_POSTDELAY, 2 +//SC_MIDNIGHT_FRENZY_POSTDELAY, 2 +//SC_TINDER_BREAKER, 2 +//SC_TINDER_BREAKER_POSTDELAY, 2 +//SC_CBC, 2 +//SC_CBC_POSTDELAY, 2 +//SC_EQC, 2 +//SC_MAGIC_CANDY, 92 +//SC_ALL_RIDING_REUSE_LIMIT, 1 +//SC_HANDICAPSTATE_DEEP_SLEEP, 80 +SC_MONSTER_TRANSFORM, 12 -SC_FULL_THROTTLE, 0x12 -SC_REBOUND, 0x12 -SC_TELEKINESIS_INTENSE, 0x12 +SC_FULL_THROTTLE, 18 +SC_REBOUND, 18 +SC_TELEKINESIS_INTENSE,18 // Unremovable -SC_WEIGHTOVER50, 0x4F -SC_WEIGHTOVER90, 0x4F -SC_XMAS, 0x4D -SC_SUMMER, 0x4D -SC_NOCHAT, 0x4D -SC_FUSION, 0x4D -SC_EARTHSCROLL, 0x4D -SC_STORMKICK_READY, 0x4D -SC_DOWNKICK_READY, 0x4D -SC_COUNTERKICK_READY, 0x4D -SC_TURNKICK_READY, 0x4D -SC_DODGE_READY, 0x4D -SC_JAILED, 0x4D -SC_AUTOTRADE, 0x4D -SC_WHISTLE, 0x4F -SC_ASSNCROS, 0x4F -SC_POEMBRAGI, 0x4F -SC_APPLEIDUN, 0x4F -SC_HUMMING, 0x4F -SC_DONTFORGETME, 0x4F -SC_FORTUNE, 0x4F -SC_SERVICEFORYOU, 0x4F -SC_INCHIT, 0x4D -SC_PUSH_CART, 0x4D
\ No newline at end of file +SC_WEIGHTOVER50, 79 +SC_WEIGHTOVER90, 79 +SC_XMAS, 77 +SC_SUMMER, 77 +SC_NOCHAT, 77 +SC_FUSION, 77 +SC_EARTHSCROLL, 77 +SC_STORMKICK_READY, 77 +SC_DOWNKICK_READY, 77 +SC_COUNTERKICK_READY, 77 +SC_TURNKICK_READY, 77 +SC_DODGE_READY, 77 +SC_JAILED, 77 +SC_AUTOTRADE, 77 +SC_WHISTLE, 79 +SC_ASSNCROS, 79 +SC_POEMBRAGI, 79 +SC_APPLEIDUN, 79 +SC_HUMMING, 79 +SC_DONTFORGETME, 79 +SC_FORTUNE, 79 +SC_SERVICEFORYOU, 79 +SC_INCHIT, 77 +SC_PUSH_CART, 0x4D diff --git a/npc/re/guild/invest_main.txt b/npc/re/guild/invest_main.txt new file mode 100644 index 000000000..e8c2a011a --- /dev/null +++ b/npc/re/guild/invest_main.txt @@ -0,0 +1,1678 @@ +//===== rAthena Script ======================================= +//= Hall of Abyss - Core Scripts +//===== By: ================================================== +//= Euphy +//===== Current Version: ===================================== +//= 1.0 +//===== Compatible With: ===================================== +//= rAthena SVN +//===== Description: ========================================= +//= Expansion for War of Emperium FE. +//= Invest in each realm to unlock new maps: +//= - Guild Dungeon F2, total 20,000,000z. +//= - Hall of Abyss, total 70,000,000z. +//===== Additional Comments: ================================= +//= 1.0 First version. Missing official times. [Euphy] +//============================================================ + +// Global Variables +//============================================================ +// Note: an asterisk (*) represents any realm (prt, pay, gef, alde). +/* +$2011_agit_invest +-- 0: Inactive. +-- 1: Investment in progress. +-- 2: Investment results calculating. +-- 4: Investment calculations complete (only when at least one $*_invest_result is 3). +-- 11-21: Tie, revote required. + +$agit_result_notice +-- 0: Inactive. +-- 1-12: Interim statements (displaying $@vfund_*x) available. + +$agit_result_timer +-- 0: Inactive. +-- 0-59: Time elapsed during investment (in hours). + +$agit_revoting_timer +-- 0: Inactive. +-- 0-29: Time elapsed during revote (in minutes). +-- 30: Revote closed. +-- 31: Revote results calculating. + +$*_invest_result +-- 0: No data. +-- 1: Realm not connected. +-- 2: Guild Dungeon F2 open. +-- 3: Abyss Gate (Hall of Abyss and Gulid Dungeon F2) open. + +$fund_*[01-05] +-- Investment units per guild castle. +$fund_*_extra +-- Investment units per realm. + +$@vfund_*[01-05] +$@vfund_*_extra +-- Investment units, used in interim statements only. +*/ + +// Investment Functions & Controller +//============================================================ +// Note: The time in this section are almost entirely custom. + +- script #invest_timer -1,{ +OnClock0000: // Open investments on Wed (1 hour after WoE) + if (gettime(4) == 3 && !agitcheck()) { + set $2011_agit_invest,1; + donpcevent "#fund_master::OnInvest_start"; + } + end; +OnClock1200: // Close investments on Fri (60 hours after investments open) + if (gettime(4) == 5 && !agitcheck()) { + set $2011_agit_invest,2; + donpcevent "#fund_master::OnInvest_stop"; + } + end; +OnClock1235: // Open dungeons on Fri (at least 31 minutes after investments close) + if (gettime(4) == 5 && !agitcheck()) + donpcevent "#fund_master::OnResult"; + end; +OnClock2000: // Close dungeons on Tues (1 hour before WoE) + if (gettime(4) == 2) + donpcevent "#fund_master::OnReset"; + end; +} + +function script F_Invest_Status { + set .@day, gettime(4); + set .@hour, gettime(3); + set .@minute, gettime(2); + + // Inactive. + if (agitcheck()) + return 0; + + // Open for investments. + if (.@day >= 3 && (.@day < 5 || (.@day == 5 && .@hour <= 12))) + return 1; + + // Investments closed, calculating results. + if (.@day == 5 && .@hour == 12 && .@minute < 35) + return 2; + + // Calculations complete, dungeons open. + if ((.@day == 5 && (.@hour > 12 || (.@hour == 12 && .@minute >= 35))) || .@day > 5 || + .@day < 2 || (.@day == 2 && .@hour < 20)) + return 3; + + // Dungeons closed. + return 0; +} + +//callfunc "F_Invest_Abyss","<variable>","<NPC name>"{,"<addon message>"}; +function script F_Invest_Abyss { + mes "There are 2 ways to invest, by Zeny or the Investment Certificate given out by the Cat Paw Merchant Guild."; + mes "Which way would you like to make your investment?"; + next; + switch(select("Invest with Zeny.:Invest with Investment Certificates.:Cancel")) { + case 1: + mes getarg(1); + mes "So you've decided to invest in Zeny."; + mes "Minimum investment unit is ^4d4dff10,000 Zeny^000000."; + mes "You can invest a maximum of 50 units which is ^4d4dff500,000 Zeny^000000."; + next; + switch(select("1 unit 10,000 Zeny:10 units 100,000 Zeny:50 units 500,000 Zeny:Another amount:Cancel")) { + case 1: + set .@units,1; + break; + case 2: + set .@units,10; + break; + case 3: + set .@units,50; + break; + case 4: + mes getarg(1); + mes "Please enter the amount you want to invest."; + mes "Please choose between 1 to 200."; + mes "Please enter 0 to cancel."; + next; + input .@units; + if (.@units < 0 || .@units > 200) { + mes getarg(1); + mes "You've exceeded the amount per investment."; + mes "Please try again."; + close; + } else if (.@units == 0) { + mes getarg(1); + mes "Canceled."; + close; + } else + break; + case 5: + mes getarg(1); + mes "Canceled."; + close; + } + set .@zeny, .@units * 10000; + if (Zeny < .@zeny) { + mes getarg(1); + mes "You do not have enough money."; + close; + } + mes getarg(1); + mes "You've invested "+.@units+" unit"+((.@units == 1)?"":"s")+" "+((.@units < 100)?.@units:insertchar(""+.@units,",",1))+"0,000 Zeny"+getarg(2,"")+"."; + mes "Not much but this is a small gift. You can exchange it with items in Malangdo."; + set Zeny, Zeny-.@zeny; + setd getarg(0), getd(getarg(0)) + .@units; + getitem 6488,.@units; //Thanks_Invest_Ticket + close; + case 2: + mes getarg(1); + mes "Wow, you've brought Investment Certificates."; + mes "How many certificates will you submit?"; + next; + switch(select("1 Investment Certificate:5 Investment Certificates:Another amount:Cancel")) { + case 1: + set .@tickets,1; + break; + case 2: + set .@tickets,5; + break; + case 3: + mes getarg(1); + mes "Please enter the number of Investment Certificates you want to submit."; + mes "Please choose between 1 to 20."; + mes "Please enter 0 to cancel."; + next; + input .@tickets; + if (.@tickets < 0 || .@tickets > 20) { + mes getarg(1); + mes "You've exceeded the amount per investment."; + mes "Please try again."; + close; + } else if (.@tickets == 0) { + mes getarg(1); + mes "Canceled."; + close; + } else + break; + case 4: + mes getarg(1); + mes "Canceled."; + close; + } + if (countitem(6489) < .@tickets) { + mes getarg(1); + mes "Looks like you have fewer Investment Certificates than you want to submit."; + close; + } + set .@units, .@tickets * 10; + mes getarg(1); + mes .@tickets+" Investment Certificate"+((.@tickets == 1)?" is":"s are")+" the same as an investment of "+.@units+" units ("+((.@units < 100)?.@units:insertchar(""+.@units,",",1))+"0,000z)"+getarg(2,"")+"."; + mes "Not much but this is a small gift. You can exchange it with items in Malangdo."; + delitem 6489,.@tickets; //Cats_Invest_Certif + setd getarg(0), getd(getarg(0)) + .@units; + getitem 6488,.@units; //Thanks_Invest_Ticket + close; + case 3: + mes getarg(1); + mes "Canceled."; + close; + } +} + +// Script Core +//============================================================ +prt_gld,1,1,0 script #fund_master 844,{ + end; +OnInit: + set .@invest_status, callfunc("F_Invest_Status"); + if (.@invest_status == 1) { + set $2011_agit_invest,1; + end; + } + if ((.@invest_status == 2 && $2011_agit_invest == 1) || + (.@invest_status == 3 && ($2011_agit_invest == 1 || $2011_agit_invest == 2))) { + donpcevent "#fund_master::OnCalculate"; + end; + } + end; +OnCalculate_Election: + set .@force_vote,1; +OnCalculate: + setarray .@cas$[0],"prt","pay","gef","alde"; + for(set .@i,0; .@i<4; set .@i,.@i+1) { + // All funds per realm are summed. + set .@funds[.@i], getd("$fund_"+.@cas$[.@i]+"01")+getd("$fund_"+.@cas$[.@i]+"02")+getd("$fund_"+.@cas$[.@i]+"03")+getd("$fund_"+.@cas$[.@i]+"04")+getd("$fund_"+.@cas$[.@i]+"05")+getd("$fund_"+.@cas$[.@i]+"_extra"); + + // 70,000,000z opens Hall of Abyss and F2. + if (.@funds[.@i] >= 7000) { + setd "$"+.@cas$[.@i]+"_invest_result",3; + set .@total_7000,1; + } + // 20,000,000z opens F2 and a chance for Hall of Abyss. + else if (.@funds[.@i] >= 2000) { + setd "$"+.@cas$[.@i]+"_invest_result",2; + set .@total_2000,1; + } + // Anything below that opens nothing. + else + setd "$"+.@cas$[.@i]+"_invest_result",1; + } + // No further actions if 20,000,000z isn't reached. + if (!.@total_2000) + end; + // No further actions if any realm hits 70,000,000z. + if (.@total_7000) { + set $2011_agit_invest,4; + end; + } + // Otherwise, highest investment above 20,000,000z opens Hall of Abyss. + set .@max, .@funds[0]; + for(set .@i,1; .@i<4; set .@i,.@i+1) { + if (.@funds[.@i] > .@max) { + set .@max, .@funds[.@i]; + set .@ele, .@i; + deletearray .@rand$[0], getarraysize(.@rand$); + } else if (.@funds[.@i] == .@max && .@funds[.@i] >= 2000) { + if (!getarraysize(.@rand$)) + set .@rand$[0], .@cas$[.@ele]; + set .@rand$[getarraysize(.@rand$)], .@cas$[.@i]; + } + } + if (.@max < 2000) + end; + if (getarraysize(.@rand$)) { + + // Tie: declare a random winner. + if (!.@force_vote) { + set .@i, rand(getarraysize(.@rand$)); + setd "$"+.@rand$[.@i]+"_invest_result",3; + set $2011_agit_invest,4; + end; + } + + // Tie: initiate a 30-minute election. + set .@str$, implode(.@rand$,"|"); + for(set .@i,0; .@i<4; set .@i,.@i+1) { + if (compare(.@str$,.@cas$[.@i])) + set .@election, .@election | (1<<.@i); + } + switch(.@election) { + case 3: set $2011_agit_invest,11; break; //Prontera|Payon + case 9: set $2011_agit_invest,12; break; //Prontera|Al De Baran + case 5: set $2011_agit_invest,13; break; //Prontera|Geffen + case 10: set $2011_agit_invest,14; break; //Al De Baran|Payon + case 6: set $2011_agit_invest,15; break; //Geffen|Payon + case 12: set $2011_agit_invest,16; break; //Al De Baran|Geffen + case 11: set $2011_agit_invest,17; break; //Prontera|Payon|Al De Baran + case 7: set $2011_agit_invest,18; break; //Prontera|Payon|Geffen + case 13: set $2011_agit_invest,19; break; //Prontera|Al De Baran|Geffen + case 14: set $2011_agit_invest,20; break; //Al De Baran|Payon|Geffen + case 15: set $2011_agit_invest,21; break; //Prontera|Payon|Al De Baran|Geffen + } + if ($2011_agit_invest >= 11) + donpcevent "Revoting Manager#Invest1::OnStart"; + end; + } else { + setd "$"+.@cas$[.@ele]+"_invest_result",3; + set $2011_agit_invest,4; + end; + } + end; +OnInvest_start: + announce "From now on, we are going to start the investments to connect the 'Abyss Gate' in the WOE areas: Valkyrie Realm, Greenwood Lake, Luina, Britoniah.",bc_all,0xFF0000; //FW_NORMAL 10 + set $fund_prt01,0; + set $fund_prt02,0; + set $fund_prt03,0; + set $fund_prt04,0; + set $fund_prt05,0; + set $fund_pay01,0; + set $fund_pay02,0; + set $fund_pay03,0; + set $fund_pay04,0; + set $fund_pay05,0; + set $fund_gef01,0; + set $fund_gef02,0; + set $fund_gef03,0; + set $fund_gef04,0; + set $fund_gef05,0; + set $fund_alde01,0; + set $fund_alde02,0; + set $fund_alde03,0; + set $fund_alde04,0; + set $fund_alde05,0; + donpcevent "Investment_total#fund00::OnEnable"; + end; +OnInvest_stop: + announce "We've finished the investments to connect the 'Abyss Gate'.",bc_all,0xFF0000; //FW_NORMAL 10 + donpcevent "Investment_total#fund00::OnReset"; + donpcevent "#fund_master::OnCalculate_Election"; + end; +OnResult: + announce "We've got the results of the investments for the 'Abyss Gate'. You can check through the Investment Status Board in each WOE area.",bc_all,0xFF0000; //FW_NORMAL 10 + if ($2011_agit_invest == 4) { + set $fund_prt01,0; + set $fund_prt02,0; + set $fund_prt03,0; + set $fund_prt04,0; + set $fund_prt05,0; + set $fund_prt_extra,0; + set $fund_pay01,0; + set $fund_pay02,0; + set $fund_pay03,0; + set $fund_pay04,0; + set $fund_pay05,0; + set $fund_pay_extra,0; + set $fund_gef01,0; + set $fund_gef02,0; + set $fund_gef03,0; + set $fund_gef04,0; + set $fund_gef05,0; + set $fund_gef_extra,0; + set $fund_alde01,0; + set $fund_alde02,0; + set $fund_alde03,0; + set $fund_alde04,0; + set $fund_alde05,0; + set $fund_alde_extra,0; + } else if ($2011_agit_invest == 2) + donpcevent "#fund_master::OnCalculate"; + end; +OnReset: + set $2011_agit_invest,0; + donpcevent "Investment_total#fund00::OnReset"; + end; +} + +prt_gld,2,2,0 script Investment_total#fund00 844,{ +/* + mes "Is this not working properly?"; + next; + input .@input; + if (.@input == 1854) { + mes "If you think the investment timer is dead, please adjust the timer."; + next; + switch(select("Turn on the timer:Cancel")) { + case 1: + donpcevent "Investment_total#fund00::OnTimerReset"; + mes "You've turned on the timer."; + close; + case 2: + mes "Canceled."; + close; + } + } else { + mes "I don't need to adjust anything now."; + close; + } +*/ + end; +OnInit: + if (callfunc("F_Invest_Status") == 1) { + initnpctimer; + donpcevent "Investment_total#fund00::OnVarInit"; + } else { + set $agit_result_timer,0; + set $agit_result_notice,0; + } + end; +OnVarInit: + setarray .@cas$[0],"prt","pay","gef","alde"; + for(set .@i,0; .@i<4; set .@i,.@i+1) { + setd "$@vfund_"+.@cas$[.@i]+"01", getd("$fund_"+.@cas$[.@i]+"01"); + setd "$@vfund_"+.@cas$[.@i]+"02", getd("$fund_"+.@cas$[.@i]+"02"); + setd "$@vfund_"+.@cas$[.@i]+"03", getd("$fund_"+.@cas$[.@i]+"03"); + setd "$@vfund_"+.@cas$[.@i]+"04", getd("$fund_"+.@cas$[.@i]+"04"); + setd "$@vfund_"+.@cas$[.@i]+"05", getd("$fund_"+.@cas$[.@i]+"05"); + setd "$@vfund_"+.@cas$[.@i]+"_extra", getd("$fund_"+.@cas$[.@i]+"_extra"); + } + end; +OnEnable: + set $agit_result_timer,0; + set $agit_result_notice,0; + initnpctimer; + end; +OnReset: + set $agit_result_timer,0; + set $agit_result_notice,0; + stopnpctimer; + end; +OnTimerReset: + initnpctimer; + end; +OnTimer3600000: + if (callfunc("F_Invest_Status") == 1) { + if ($agit_result_timer < 59) { + set $agit_result_timer, $agit_result_timer+1; + + // Trigger on multiples of 5 up to 55, and 58. + if ($agit_result_timer % 10 == 5 || $agit_result_timer % 10 == 0 || $agit_result_timer == 58) { + set $agit_result_notice, $agit_result_notice+1; + donpcevent "Investment_total#fund00::OnVarInit"; + announce "No. "+$agit_result_notice+" Interim statement is now available. You can check through the Investment Status Board in each WOE area.",bc_all,0xFF0000; //FW_NORMAL 10 + } + + donpcevent "Investment_total#fund00::OnTimerReset"; + } else + stopnpctimer; + end; + } else { + donpcevent "Investment_total#fund00::OnReset"; + end; + } +} + +prt_gld,164,98,3 script Revoting Manager#Invest1 421,{ + mes "[Revoting Manager]"; + mes "We are not accepting additional votes."; + mes "Please wait for our results announcement."; + close; +OnInit: + set .@invest_status, callfunc("F_Invest_Status"); + if (.@invest_status == 2 && $2011_agit_invest >= 11 && $agit_revoting_timer < 30) { + donpcevent "Revoting Manager#Invest2::OnEnable"; + initnpctimer; + } else if (.@invest_status == 3 && $2011_agit_invest >= 11) + donpcevent "Revoting Manager#Invest1::OnCalculate"; + donpcevent "Revoting Manager#Invest1::OnDisable"; + end; +OnCalculate: + switch($2011_agit_invest) { + case 11: setarray.@cas$[0],"prt","pay"; break; + case 12: setarray.@cas$[0],"prt","alde"; break; + case 13: setarray.@cas$[0],"prt","gef"; break; + case 14: setarray.@cas$[0],"alde","pay"; break; + case 15: setarray.@cas$[0],"gef","pay"; break; + case 16: setarray.@cas$[0],"alde","gef"; break; + case 17: setarray.@cas$[0],"prt","pay","alde"; break; + case 18: setarray.@cas$[0],"prt","pay","gef"; break; + case 19: setarray.@cas$[0],"prt","alde","gef"; break; + case 20: setarray.@cas$[0],"alde","pay","gef"; break; + case 21: setarray.@cas$[0],"prt","pay","alde","gef"; break; + default: end; + } + set .@max, getd("$fund_"+.@cas$[0]+"_extra"); + for(set .@i,1; .@i<getarraysize(.@cas$); set .@i,.@i+1) { + set .@funds, getd("$fund_"+.@cas$[.@i]+"_extra"); + if (.@funds > .@max) { + set .@max, .@funds; + set .@ele, .@i; + deletearray .@rand$[0], getarraysize(.@rand$); + } else if (.@funds == .@max) { + if (!getarraysize(.@rand$)) + set .@rand$[0], .@cas$[.@ele]; + set .@rand$[getarraysize(.@rand$)], .@cas$[.@i]; + } + } + if (getarraysize(.@rand$)) { + set .@i, rand(getarraysize(.@rand$)); + setd "$"+.@rand$[.@i]+"_invest_result",3; + } else + setd "$"+.@cas$[.@ele]+"_invest_result",3; + set $2011_agit_invest,4; + set $agit_revoting_timer,0; + end; +OnEnable: + enablenpc "Revoting Manager#Invest1"; + end; +OnDisable: + disablenpc "Revoting Manager#Invest1"; + end; +OnStart: + initnpctimer; + donpcevent "Revoting Manager#Invest2::OnNotice_on"; + end; +OnEnd: + stopnpctimer; + disablenpc "Revoting Manager#Invest1"; + end; +OnTimerReset: + initnpctimer; + end; +OnTimer60000: + set .@revote, $agit_revoting_timer; + if (.@revote < 30) { + set $agit_revoting_timer, $agit_revoting_timer+1; + donpcevent "Revoting Manager#Invest1::OnTimerReset"; + } else if (.@revote == 30) { + announce "Cat Paw Merchant Guild: Now we are going to close the additional vote. We will announce the results soon.",bc_all,0xFF0000; //FW_NORMAL 10 + donpcevent "Revoting Manager#Invest2::OnDisable"; + donpcevent "Revoting Manager#Invest1::OnEnable"; + set $agit_revoting_timer, $agit_revoting_timer+1; + donpcevent "Revoting Manager#Invest1::OnTimerReset"; + } else if (.@revote == 31) { + donpcevent "Revoting Manager#Invest1::OnCalculate"; + donpcevent "Revoting Manager#Invest1::OnDisable"; + stopnpctimer; + end; + } else { + donpcevent "Revoting Manager#Invest1::OnDisable"; + stopnpctimer; + } + end; +} + +prt_gld,164,98,3 script Revoting Manager#Invest2 421,{ + set .@invest, $2011_agit_invest; + if (.@invest < 11) { + mes "[Revoting Manager]"; + mes "No! This is not the time to take a revote."; + close2; + disablenpc "Revoting Manager#Invest2"; + end; + } + set .@playtime, checkquest(7349,PLAYTIME); + if (.@playtime == 0 || .@playtime == 1) { + mes "[Revoting Manager]"; + mes "You've already participated in the vote."; + mes "Please relax and wait for the results."; + close; + } else if (.@playtime == 2) + erasequest 7349; + mes "[Revoting Manager]"; + mes "Would you like to participate in the vote for choosing where to connect the 'Abyss Gate'?"; + next; + if(select("Participate in the vote.:Skip for now.") == 2) { + mes "[Revoting Manager]"; + mes "You've canceled the vote."; + close; + } + mes "[Revoting Manager]"; + mes "You can vote once and won't need to invest for your choice."; + mes "Plesae choose one WOE area."; + next; + + // Create menu. + explode(.@candidates$, callsub(OnGetCandidates, .@invest),"|"); + for(set .@i,0; .@i<getarraysize(.@candidates$); set .@i,.@i+1) { + if (.@candidates$[.@i] == "alde") + set .@menu$[.@i],"Luina"; + else if (.@candidates$[.@i] == "gef") + set .@menu$[.@i],"Britoniah"; + else if (.@candidates$[.@i] == "pay") + set .@menu$[.@i],"Greenwood Lake"; + else if (.@candidates$[.@i] == "prt") + set .@menu$[.@i],"Valkyrie Realm"; + } + set .@vote, select(implode(.@menu$,":"))-1; + + mes "[Revoting Manager]"; + mes "You've voted for "+.@menu$[.@vote]+"."; + mes "Thanks for voting."; + setquest 7349; + setd "$fund_"+.@candidates$[.@vote]+"_extra", getd("$fund_"+.@candidates$[.@vote]+"_extra") + 1; + close; +OnGetCandidates: + switch(getarg(0)) { + case 11: return "prt|pay"; + case 12: return "prt|alde"; + case 13: return "prt|gef"; + case 14: return "alde|pay"; + case 15: return "gef|pay"; + case 16: return "alde|gef"; + case 17: return "prt|pay|alde"; + case 18: return "prt|pay|gef"; + case 19: return "prt|alde|gef"; + case 20: return "alde|pay|gef"; + case 21: return "prt|pay|alde|gef"; + } + return ""; +OnInit: + disablenpc "Revoting Manager#Invest2"; + end; +OnEnable: + enablenpc "Revoting Manager#Invest2"; + end; +OnDisable: + disablenpc "Revoting Manager#Invest2"; + stopnpctimer; + end; +OnNotice_on: + initnpctimer; + end; +OnTimer5000: + announce "Cat Paw Merchant Guild: As no WOE area has reached the maximum investment level to connect the 'Abyss Gate'...",bc_all,0xFF0000; //FW_NORMAL 10 + end; +OnTimer8000: + announce "Cat Paw Merchant Guild: We were about to connect the 'Abyss Gate' to the WOE area which invested most.",bc_all,0xFF0000; //FW_NORMAL 10 + end; +OnTimer11000: + announce "Cat Paw Merchant Guild: However, there were areas which invested the same amount. So we will put them to a vote.",bc_all,0xFF0000; //FW_NORMAL 10 + end; +OnTimer14000: + announce "Cat Paw Merchant Guild: Additional votes will be available for 30 minutes. You can vote in Valkyrie Realm.",bc_all,0xFF0000; //FW_NORMAL 10 + end; +OnTimer20000: + explode(.@candidates$, callsub(OnGetCandidates, $2011_agit_invest),"|"); + for(set .@i,0; .@i<getarraysize(.@candidates$); set .@i,.@i+1) { + if (.@candidates$[.@i] == "alde") + set .@choices$[.@i],"Luina"; + else if (.@candidates$[.@i] == "gef") + set .@choices$[.@i],"Britoniah"; + else if (.@candidates$[.@i] == "pay") + set .@choices$[.@i],"Greenwood Lake"; + else if (.@candidates$[.@i] == "prt") + set .@choices$[.@i],"Valkyrie Realm"; + } + announce "Cat Paw Merchant Guild: The candidates for the additional vote are... "+implode(.@choices$," vs. ")+".",bc_all,0xFF0000; //FW_NORMAL 10 + set $fund_prt_extra,0; + set $fund_pay_extra,0; + set $fund_gef_extra,0; + set $fund_alde_extra,0; + set $agit_revoting_timer,0; + donpcevent "Revoting Manager#Invest2::OnEnable"; + stopnpctimer; + end; +} + +/* +prtg_cas01,2,2,0 script Abrai 55,{ + mes "I should quit my steward job."; + close; +OnAgitInvest: + switch(callfunc("F_Invest_Status")) { + case 0: + set $2011_agit_invest,0; + donpcevent "#fund_master::OnReset"; + break; + case 1: + set $2011_agit_invest,1; + donpcevent "#fund_master::OnInvest_start"; + break; + case 2: + set $2011_agit_invest,2; + donpcevent "#fund_master::OnInvest_stop"; + break; + case 3: + donpcevent "#fund_master::OnResult"; + break; + } + end; +} +*/ + +// Realms - Merchant Guilds, Gate Managers, Status Boards +//============================================================ +- script Cat Paw Merchant Guild -1,{ + + if (compare(strnpcinfo(4),"alde")) { + set .@npc$,"alde"; + set .@name$,"Megrez"; + set .@realm$,"Luina"; + set .@intro$,"Luina Branch Manager in Al De Baran"; + } else if (compare(strnpcinfo(4),"gef")) { + set .@npc$,"gef"; + set .@name$,"Meraq"; + set .@realm$,"Britoniah"; + set .@intro$,"Britoniah Branch Manager"; + } else if (compare(strnpcinfo(4),"pay")) { + set .@npc$,"pay"; + set .@name$,"Phecda"; + set .@realm$,"Greenwood Lake"; + set .@intro$,"Payon Greenwood Lake Branch Manager"; + } else if (compare(strnpcinfo(4),"prt")) { + set .@npc$,"prt"; + set .@name$,"Dubae"; + set .@realm$,"Valkyrie Realm"; + set .@intro$,"Prontera Valkyrie Realm Branch Manager"; + } + set .@n$,"["+.@name$+"]"; + + mes .@n$; + mes "I'm "+.@name$+", the "+.@intro$+" of the Cat Paw Merchant Guild."; + mes "I consult about investments for the Abyss Gate development."; + mes "How may I help you?"; + next; + switch(select("What is the Abyss Gate?:Investing in the gate development?:I want to invest in this area.:Cancel")) { + case 1: + mes .@n$; + mes "It is only called the Abyss Gate for convenience but it's simply a ^4d4dffgap to another dimension^000000."; + next; + mes .@n$; + mes "More of these gaps are found here and there after Morocc created the Crack of Dimension."; + mes "I personally think that the Abyss Gate found recently is part of the past or even from the future."; + next; + mes .@n$; + mes "It is said that the Abyss Gate forcefully connects to another dimension beyond our world."; + mes "Probably because there are those that follow the Emperium's power."; + next; + mes .@n$; + mes "There are a total of 4 Abyss Gates found so far. They all connect to the Agit region overflowing with the Emperium's force."; + next; + mes .@n$; + mes "We named each by dimension beyond the gap."; + mes "^4d4dffWay of the Warrior, Hill of the Dead, Winds of the Ancient, and the Hero's Tears.^000000"; + mes "And all these four gaps are called the ^4d4dffAbyss Gate^000000."; + next; + mes .@n$; + mes "The gap may lead to the past, future or even an unknown world."; + mes "The power the Abyss Gate holds is both fearful but sweet"; + next; + mes .@n$; + mes "Are you also interested in exploring the Abyss Gate?"; + mes "Ha ha. You'll need to go through several steps before exploring."; + next; + mes .@n$; + mes "If you are interested,"; + mes "will you take the time to sit down and talk about investing in maintaining the Abyss Gate?"; + close; + case 2: + mes .@n$; + mes "Are you curious about investing in the Gate development?"; + mes "What do you want to know about?"; + next; + switch(select("About the Gate?:About investments?:How to invest?:Benefits from investing?")) { + case 1: + mes .@n$; + mes "The Gate is what it is named after, a door."; + mes "A dimensional passageway that connects here to there."; + next; + mes .@n$; + mes "The Abyss Gate was created as a very unstable path from beyond the dimensional gap,"; + mes "therefore traveling through the Gate will need an artificial dimension connection."; + next; + mes .@n$; + mes "Humans are far from having the advanced technology that's needed"; + mes "but our Cat Paw Merchant Guild holds the high technology to use the Crack of Dimension."; + next; + mes .@n$; + mes "So we made a proposal."; + mes "With the promise of support the Cat Paw Merchant Guild and paying for the immense expense for maintaining the connection with the Gate,"; + mes "we will make the connection to the Crack of Dimension."; + next; + mes .@n$; + mes "Of course working on the Crack of Dimension is no easy job and it does come with risks."; + mes "There are cases where people go missing from traveling between."; + next; + mes .@n$; + mes "The best maintaining duration is about 4 days"; + mes "You invest in us and we create the door that connects to the dimensional gap."; + next; + mes .@n$; + mes "Doesn't this sound like the perfect win-win proposal?"; + close; + case 2: + mes .@n$; + mes "Forcing through the unstable dimensional gap and creating a passageway is very dangerous."; + mes "Not to mention the huge resources needed."; + next; + mes .@n$; + mes "If you take care of the charges and also the danger pay by investing in the Cat Paw Merchant Guild,"; + mes "we'll create and maintain the gate regardless of the risks."; + next; + mes .@n$; + mes "But then of course the money involved for the gate costs will be extreme."; + mes "It will be easy if you can find investors to share the amount."; + next; + mes .@n$; + mes "There is a basic charge to start connecting the gate."; + mes "Results depend on the how much investment money is collected."; + next; + mes .@n$; + mes "The Abyss Gate exists in each Agit region."; + mes "Can you imagine how much money and sacrifice our guild will have to go through to develop in all areas?"; + next; + mes .@n$; + mes "This explains the regional competition in investments."; + mes "If not enough gate maintenance costs are collected then it is obvious the region with the most investments will receive the benefits"; + next; + mes .@n$; + mes "If ^4d4dffthe Abyss Gate is successfully connected then the dungeon of the hideout area"; + mes "will be open to others instead of being guild exclusive^000000 which will be very attractive for investment."; + next; + mes .@n$; + mes "But then again, this is only for when the gate is connected."; + close; + case 3: + mes .@n$; + mes "It's simple."; + mes "Visit the branch manager of the ^4d4dffregion you want to invest in during the investment duration^000000 and make your investment."; + next; + mes .@n$; + mes "We usually receive ^4d4dffthe common currency here, Zeny^000000."; + mes "But since we're talking about supporting our Cat Paw Merchant Guild, you can also invest with items in demand in Malangdo."; + next; + mes .@n$; + mes "Provide the items in need to Namis in Malangdo who is in charge of general affairs in our guild."; + mes "Bring back your Investment Certificate to add it to the investment tribute."; + next; + mes .@n$; + mes "You must visit and invest at the region you want in order for your investment to be counted as a tribute."; + close; + case 4: + mes .@n$; + mes "The Abyss Gate is basically contracting and connecting with the castle that owns the Agit;"; + mes "therefore, we will provide all we have once the costs for connecting and maintaining the gate are sufficient."; + next; + mes .@n$; + mes "In terms of the minimum and maximum costs for the whole work,"; + mes "if the collected investment ^4d4dffexceeds the minimum costs^000000, we can connect you to the ^4d4dffdeepest layer of an unknown guild dungeon^000000."; + next; + mes .@n$; + mes "If investments exceed the maximum costs, that region will be connected to the"; + mes "^4d4dffAbyss Gate^000000 regardless of the investment rank which includes the deepest layer of the guild dungeon."; + next; + mes .@n$; + mes "^ff0000If there is no Agit region that reached the maximum investment, then the region with the"; + mes "highest investment participation will get the Abyss Gate connected with the investment collected from all regions.^000000"; + next; + mes .@n$; + mes "Once the Abyss Gate is connected, the deepest layer (2F) of the guild dungeon"; + mes "will be open to all adventurers that participated in the regional investment."; + next; + mes .@n$; + mes "Visits to the dungeon will be counted for the next investment for the Agit region"; + mes "so being in good terms with the guild that claims the Agit castle will be a bonus."; + next; + mes .@n$; + mes "By the way, it isn't easy to maintain the connection with the Abyss Gate and investments and reconnection is needed weekly"; + mes "so please continue your support and investment if you want the power of the unknown."; + close; + } + case 3: + if (checkweight(1201,1) == 0 || MaxWeight - Weight < 1000) { + mes "- Currently you're carrying -"; + mes "- too many items with you. -"; + mes "- Please try again after you -"; + mes "- lose some weight. -"; + close; + } + if (countitem(6488) >= 4800) { + mes .@n$; + mes "You have too many Thank You Tickets to receive any more."; + mes "Cannot give you any more tickets. Please use your ticket and come back."; + mes "The ticket can be exchanged with various items in Malangdo."; + close; + } + if (callfunc("F_Invest_Status") != 1) { + mes .@n$; + mes "We do not receive investments now."; + mes "Please come back during the investment duration."; + close; + } + set .@guild, getcharid(2); + for(set .@i,1; .@i<=5; set .@i,.@i+1) { + set .@castle_name$[.@i], getcastlename(.@npc$+"g_cas0"+.@i); + set .@owner_id[.@i], getcastledata(.@npc$+"g_cas0"+.@i,1); + set .@owner_name$[.@i], getguildname(.@owner_id[.@i]); + if (.@guild == .@owner_id[.@i]) { + set .@menu$, .@menu$+.@castle_name$[.@i]+" ["+.@owner_name$[.@i]+"] Guild:"; + set .@castles_owned, .@castles_owned | (1<<.@i); + } else + set .@menu$, .@menu$+"^aaaaaaNot the guild that claimed "+.@castle_name$[.@i]+"^000000:"; + } + mes .@n$; + mes "Would you like to invest in the ^4d4dff"+.@realm$+"^000000 region?"; + mes "If there is a castle occupied already, you will invest in the castle and the guild that is occupying it."; + next; + if (.@castles_owned) { + set .@i, select(.@menu$+"Cancel"); + if (.@i == 6) { + mes .@n$; + mes "Canceled."; + close; + } + if (.@guild != .@owner_id[.@i]) { + mes .@n$; + mes "The guild that is occupying "+.@castle_name$[.@i]+" is "+.@owner_name$[.@i]+"."; + mes "Doesn't look like your guild."; + close; + } + mes .@n$; + mes "Invest under "+.@castle_name$[.@i]+"'s"+.@owner_name$[.@i]+" guild name."; + callfunc "F_Invest_Abyss","$fund_"+.@npc$+"0"+.@i,.@n$; + end; + } else { + mes .@n$; + callfunc "F_Invest_Abyss","$fund_"+.@npc$+"_extra",.@n$," for "+.@realm$; + end; + } + case 4: + mes .@n$; + mes "Is that so?"; + mes "Please come back whenever you are interested in investing in the Abyss Gate development."; + close; + } +} + +- script Gate Manager#realm -1,{ + + if (compare(strnpcinfo(4),"alde")) { + set .@npc$,"alde"; + set .@name$,"Alkor"; + set .@gate$,"Hero's Tears"; + set .@realm$,"Luina"; + } else if (compare(strnpcinfo(4),"gef")) { + set .@npc$,"gef"; + set .@name$,"Mizar"; + set .@gate$,"Hill of the Dead"; + set .@realm$,"Britoniah"; + } else if (compare(strnpcinfo(4),"pay")) { + set .@npc$,"pay"; + set .@name$,"Alkaid"; + set .@gate$,"Winds of the Ancient"; + set .@realm$,"Greenwood Lake"; + } else if (compare(strnpcinfo(4),"prt")) { + set .@npc$,"prt"; + set .@name$,"Arios"; + set .@gate$,"Way of the Warrior"; + set .@realm$,"Valkyrie Realm"; + } + set .@n$,"["+.@name$+"]"; + + if (callfunc("F_Invest_Status") != 3) { + mes .@n$; + mes "There are currently no connected dungeon gates."; + close; + } + set .@status, getd("$"+.@npc$+"_invest_result"); + if (.@status == 3) { + mes .@n$; + mes "We've successfully connected the Abyss Gate ["+.@gate$+"] with the help from your investment."; + mes "The Agit dungeon will be open to everyone with a small entrance fee in "+.@realm$+"."; + next; + mes .@n$; + mes "Please visit as often as possible since the entrance fee is saved as an investment for the region."; + mes "Do you want to enter the Agit dungeon?"; + next; + set .@i, select(.@realm$+" Dungeon 1F - 10000z:"+.@realm$+" Dungeon 2F - 10000z:Cancel"); + if (.@i == 3) { + mes .@n$; + mes "Canceled."; + close; + } + if (Zeny < 10000) { + mes .@n$; + mes "I'm collecting a small entrance fee."; + mes "Your contribution will be saved for the next investment."; + mes "Entrance fee is 10000z."; + close; + } + mes .@n$; + mes "I'm sending you to the "+.@realm$+" Agit Dungeon "+.@i+"F."; + set Zeny, Zeny-10000; + setd "$fund_"+.@npc$+"_extra", getd("$fund_"+.@npc$+"_extra") + 1; + close2; + if (compare(strnpcinfo(2),"alde")) + warp "gld_dun02"+((.@i == 2)?"_2":""),32,122; + else if (compare(strnpcinfo(2),"gef")) + warp "gld_dun04"+((.@i == 2)?"_2":""),39,258; + else if (compare(strnpcinfo(2),"pay")) + warp "gld_dun01"+((.@i == 2)?"_2":""),186,165; + else if (compare(strnpcinfo(2),"prt")) + warp "gld_dun03"+((.@i == 2)?"_2":""),164,268; + end; + } else if (.@status == 2) { + mes .@n$; + mes "The "+.@realm$+" Agit Dungeon 2F is now available but since it is not connected with the Abyss Gate,"; + mes "the Agit dungeon is only accessible to the Agit guild."; + close; + } else { + mes .@n$; + mes .@realm$+" was not chosen to be connected with a gate this time."; + mes "Please wait for the next investment duration."; + close; + } + end; +} + +- script Investment Status Board -1,{ + set .@invest_status, callfunc("F_Invest_Status"); + if (.@invest_status == 1) { + if (compare(strnpcinfo(4),"alde")) { + set .@npc$,"alde"; + set .@realm$,"Luina"; + } else if (compare(strnpcinfo(4),"gef")) { + set .@npc$,"gef"; + set .@realm$,"Britoniah"; + } else if (compare(strnpcinfo(4),"pay")) { + set .@npc$,"pay"; + set .@realm$,"Greenwood Lake"; + } else if (compare(strnpcinfo(4),"prt")) { + set .@npc$,"prt"; + set .@realm$,"Valkyrie Realm"; + } + set .@notice, $agit_result_notice; + if (.@notice < 1 || .@notice > 12) { + mes "There are currently no investment sums available."; + close; + } else if (.@notice == 1) + set .@str$,"1st"; + else if (.@notice == 2) + set .@str$,"2nd"; + else if (.@notice == 3) + set .@str$,"3rd"; + else + set .@str$,.@notice+"th"; + mes .@str$+" total (unit in 10,000z)"; + for(set .@i,1; .@i<=5; set .@i,.@i+1) { + set .@map$, .@npc$+"g_cas0"+.@i; + set .@fund[.@i], getd("$@vfund_"+.@npc$+"0"+.@i); + mes getcastlename(.@map$)+" "+getguildname(getcastledata(.@map$,1))+" Guild: "+.@fund[.@i]; + } + set .@fund[0], getd("$@vfund_"+.@npc$+"_extra"); + mes .@realm$+" normal: "+.@fund[0]; + mes .@realm$+" Investment Grand Total: "+(.@fund[0]+.@fund[1]+.@fund[2]+.@fund[3]+.@fund[4]+.@fund[5]); + close; + } else if (.@invest_status == 2) { + mes "!- Notice -!"; + mes "No sums are available because the total investment amount is currently being calculated."; + mes "Please wait for the announcement of the results."; + close; + } else if (.@invest_status == 3) { + setarray .@invest_result[0], $prt_invest_result,$pay_invest_result,$gef_invest_result,$alde_invest_result; + setarray .@invest_region$[0], "Valkyrie Realm", "Greenwood Lake", "Britoniah", "Luina"; + mes "!- Investment Results of All Agit Regions -!"; + for(set .@i,0; .@i<4; set .@i,.@i+1) { + if (.@invest_result[.@i] == 1) + mes "^aaaaaa["+.@invest_region$[.@i]+"] below minimum^000000"; + else if (.@invest_result[.@i] == 2) { + mes "["+.@invest_region$[.@i]+"] minimum achieved"; + mes "-> Guild Dungeon Deepest Layer (2F) available"; + } else if (.@invest_result[.@i] == 3) { + mes "^4d4dff["+.@invest_region$[.@i]+"] maximum achieved^000000"; + mes "-> Abyss Gate available"; + } else + mes "No data for ["+.@invest_region$[.@i]+"]."; + } + close; + } else { + mes "!- Notice -!"; + mes "No investment information will be announced now."; + close; + } +} + +// Inside Castles - Gate Managers +//============================================================ +- script Gate Manager#castle -1,{ + + set .@id, atoi(charat(strnpcinfo(2),getstrlen(strnpcinfo(2))-1)); + if (compare(strnpcinfo(2),"alde")) { + set .@npc$,"alde"; + set .@realm$,"Luina"; + } else if (compare(strnpcinfo(2),"gef")) { + set .@npc$,"gef"; + set .@realm$,"Britoniah"; + } else if (compare(strnpcinfo(2),"pay")) { + set .@npc$,"pay"; + set .@realm$,"Greenwood Lake"; + } else if (compare(strnpcinfo(2),"prt")) { + set .@npc$,"prt"; + set .@realm$,"Valkyrie Realm"; + } + + set .@GID, getcastledata(strnpcinfo(4),1); + if (getcharid(2) != .@GID) { + mes "[Gate Manager]"; + mes "You don't seem to be the member of guild owning this castle."; + mes "If you need any help, please visit any of our guild members at "+.@realm$+" Square."; + close; + } + mes "[Gate Manager]"; + mes "Hello, I am the Gate Manager from Cat Paw Merchant Guild warp department."; + mes "How may I help you today?"; + next; + switch(select("Invest for gate connection:Deepest Layer Dungeon Access:Abyss Gate Access:Cancel")) { + case 1: + if (checkweight(1201,1) == 0 || MaxWeight - Weight < 1000) { + mes "[Gate Manager]"; + mes "You have too many items to receive the Thank You Ticket as a small gift for your investment."; + mes "Please come back after making room in your inventory."; + close; + } + if (countitem(6488) >= 4800) { + mes "[Gate Manager]"; + mes "You have too many Thank You Tickets to receive any more."; + mes "Cannot give you any more tickets. Please use your ticket and come back."; + mes "The ticket can be exchanged with various items in Malangdo."; + close; + } + if (callfunc("F_Invest_Status") != 1) { + mes "[Gate Manager]"; + mes "We do not receive investments now."; + mes "Please come back during the investment duration."; + close; + } + if (getcharid(2) != .@GID) { + mes "[Gate Manager]"; + mes "You don't seem to be the member of the guild owning this castle."; + mes "Please use the normal investment from "+.@realm$+" Square."; + close; + } + mes "[Gate Manager]"; + mes "Proceed investing under your guild name."; + callfunc "F_Invest_Abyss","$fund_"+.@npc$+"0"+.@id,"[Gate Manager]"; + end; + case 2: + callsub L_Enter,1,.@realm$; + mes "[Gate Manager]"; + mes "You are interested in exploring the "+.@realm$+" Guild Dungeon Deepest Layer (2F)."; + mes "Let me guide you. Good luck."; + close2; + if (compare(strnpcinfo(2),"alde")) { + switch(.@id) { + case 1: warp "gld_dun02_2",32,122; end; + case 2: warp "gld_dun02_2",79,30; end; + case 3: warp "gld_dun02_2",165,38; end; + case 4: warp "gld_dun02_2",160,148; end; + case 5: warp "gld_dun02_2",103,169; end; + } + } else if (compare(strnpcinfo(2),"gef")) { + switch(.@id) { + case 1: warp "gld_dun04_2",39,258; end; + case 2: warp "gld_dun04_2",125,270; end; + case 3: warp "gld_dun04_2",268,251; end; + case 4: warp "gld_dun04_2",268,108; end; + case 5: warp "gld_dun04_2",230,35; end; + } + } else if (compare(strnpcinfo(2),"pay")) { + switch(.@id) { + case 1: warp "gld_dun01_2",186,165; end; + case 2: warp "gld_dun01_2",54,165; end; + case 3: warp "gld_dun01_2",54,39; end; + case 4: warp "gld_dun01_2",186,39; end; + case 5: warp "gld_dun01_2",223,202; end; + } + } else if (compare(strnpcinfo(2),"prt")) { + switch(.@id) { + case 1: warp "gld_dun03_2",28,251; end; + case 2: warp "gld_dun03_2",164,268; end; + case 3: warp "gld_dun03_2",164,179; end; + case 4: warp "gld_dun03_2",268,203; end; + case 5: warp "gld_dun03_2",199,28; end; + } + } + end; + case 3: + callsub L_Enter,2,.@realm$; + mes "[Gate Manager]"; + mes "Let me guide you to the Abyss Gap connected with "+.@realm$+", the Abyss Gate 'Way of the Warrior'."; + close2; + if (compare(strnpcinfo(2),"alde")) { + switch(.@id) { + case 1: warp "gld2_ald",175,41; end; + case 2: warp "gld2_ald",77,64; end; + case 3: warp "gld2_ald",46,127; end; + case 4: warp "gld2_ald",104,246; end; + case 5: warp "gld2_ald",241,156; end; + } + } else if (compare(strnpcinfo(2),"gef")) { + switch(.@id) { + case 1: warp "gld2_gef",28,199; end; + case 2: warp "gld2_gef",217,46; end; + case 3: warp "gld2_gef",171,195; end; + case 4: warp "gld2_gef",30,67; end; + case 5: warp "gld2_gef",115,40; end; + } + } else if (compare(strnpcinfo(2),"pay")) { + switch(.@id) { + case 1: warp "gld2_pay",33,112; end; + case 2: warp "gld2_pay",119,27; end; + case 3: warp "gld2_pay",205,111; end; + case 4: warp "gld2_pay",175,221; end; + case 5: warp "gld2_pay",61,221; end; + } + } else if (compare(strnpcinfo(2),"prt")) { + switch(.@id) { + case 1: warp "gld2_prt",10,27; end; + case 2: warp "gld2_prt",14,247; end; + case 3: warp "gld2_prt",259,236; end; + case 4: warp "gld2_prt",226,25; end; + case 5: warp "gld2_prt",97,11; end; + } + } + end; + case 4: + mes "[Gate Manager]"; + mes "Canceled."; + close; + } + end; + +L_Enter: + set .@invest_status, callfunc("F_Invest_Status"); + if (.@invest_status == 3) { + set .@status, getd("$"+.@npc$+"_invest_result"); + if ((getarg(0) == 1 && .@status == 2) || .@status == 3) + return; + else { + mes "[Gate Manager]"; + mes getarg(1)+" was not chosen to be connected with a gate this time."; + mes "Please wait for the next investment duration."; + close; + } + } else if (.@invest_status < 3) { + mes "[Gate Manager]"; + mes "There are currently no connected dungeon gates."; + mes "A gate will be connected as soon as the investment results are available."; + mes "Please wait."; + close; + } else { + mes "[Gate Manager]"; + mes "The gate will disappear soon."; + mes "The dungeon is no longer accessible."; + mes "Please try again next time."; + close; + } +} + +// Item Investments +//============================================================ +malangdo,218,126,4 script Cat Paw Merchants Notice 857,{ + mes "<< Cat Paw Merchants Notice >>"; + mes "'^C379CEInvest Unused Items for Prizes!^000000'"; + next; + switch(select("Read Notice:Check Event 1:Check Event 2")) { + case 1: + mes "- Notice -"; + mes "Hello all Cat Paw Merchants customers! With your love, we Cat Paw Merchants are growing every day. All executives and staff members promise to do our best to further our frontier and development."; + next; + mes "- Event Notice! -"; + mes " An Event called '^C379CEInvest Unused Items for Prizes!^000000' is under way, where you could exchange unused items in your storage for Investment Certificate of the Cat Paw Merchants."; + next; + mes "Exchangeable items will be announced on a separate sheet. Thank you for your time."; + mes "- From all the employees of Cat Paw Merchants -"; + next; + mes "There is a small warning at the bottom."; + mes " "; + mes "^FF0000This event could be changed or repealed due to the Merchants' situation.^000000"; + close; + case 2: + mes "'^C379CEInvest Unused Items for Prizes!^000000'"; + mes "There are details of Event 1."; + next; + setarray .@event1$[0], + "Wings of the Insect Queen","Crown of the Fly King","I hear Dragon Scales are tough 01","The Meaning of the Mother's Nightmare", + "To refine ore","Hekekek Orcs, Orcs!!","Study of Yin-Yang","Secrets of the Pyramid King","Tick-tock the time goes", + "Planting trees on Mellow Island","Ancient language research","Weapons made of sharp teeth","Toy boss doll 01", + "A tiger is just a cat after all","The shattered spear and shield?","Toy boss doll 02","Best in summer! Cold scales", + "Piece of Thanatos' armor","I hear Dragon Scales are tough 02","The identity of the creepy eye","If only I could see!"; + set .@menu$, "Quit:"+implode(.@event1$[0],":"); + while(1) { + set .@i, select(.@menu$)-1; + switch(.@i) { + case 0: close; + case 1: set .@str$,"2 Pieces of Queen's Wing"; break; + case 2: set .@str$,"2 Broken Crowns"; break; + case 3: set .@str$,"2 Fire Dragon Scales"; break; + case 4: set .@str$,"3 Mother's Nightmares"; break; + case 5: set .@str$,"5 Gemstones"; break; + case 6: set .@str$,"5 Heroic Emblems"; break; + case 7: set .@str$,"3 Taeguk Plates"; break; + case 8: set .@str$,"3 Broken Pharaoh Symbols and 3 Tutankhamen's Masks"; break; + case 9: set .@str$,"2 Pocket Watches"; break; + case 10: set .@str$,"3 Young Twigs"; break; + case 11: set .@str$,"5 Rossata Pieces"; break; + case 12: set .@str$,"5 Fangs of Garm"; break; + case 13: set .@str$,"3 Baphomet Dolls"; break; + case 14: set .@str$,"1 Tiger's Footskin and 5 Tiger Skins"; break; + case 15: set .@str$,"3 Broken Shield Pieces and 3 Shining Spear Blades"; break; + case 16: set .@str$,"3 Osiris Dolls"; break; + case 17: set .@str$,"1 Ice Scale"; break; + case 18: set .@str$,"1 Skeletal Armor Piece"; break; + case 19: set .@str$,"1 Darkred Scale Piece"; break; + case 20: set .@str$,"2 Wills of Red Darkness"; break; + case 21: set .@str$,"2 Foolishness of the Blind"; break; + } + mes "["+.@event1$[.@i-1]+"]"; + mes .@str$+" for one Cat Paw Merchants Investment Certificate."; + next; + } + case 3: + mes "Look out for the next '^C379CEInvest Unused Items for Prizes!^000000' Event 2!! Coming up real soon!"; + close; + } +} + +malangdo,218,123,1 script Namis#invest 545,4,4,{ + if (checkweight(1201,1) == 0 || MaxWeight - Weight < 1000) { + mes "- Currently you're carrying -"; + mes "- too many items with you. -"; + mes "- Please try again after you -"; + mes "- lose some weight. -"; + close; + } + emotion e_omg; + emotion e_an; + emotion e_ag; + mes "[Namis]"; + mes "Purr-Purr-Purrr-Purrrr-Pur~ Meow!!"; + mes "Wh-- What? How rude. You scared me."; + next; + switch(select("What do you need? I'll invest!:What's the purpose of this event?:Were you asleep?")) { + case 1: + break; + case 2: + mes "[Namis]"; + mes "So, another pushover in contract with the Cat Paw Merchants?"; + next; + select("Huh? What! You calling me a pushover?"); + mes "[Namis]"; + mes "I'll say this just once, so you listen good!"; + mes "We, the Cat Paw Merchants have planned an event for loyal workers like yourself."; + next; + mes "[Namis]"; + mes "Run along to your storage and bring back rotting antiques to us and we'll exchange them for the oh-so valuable 'Cat Paw Merchants Investment Certificate'."; + next; + mes "[Namis]"; + mes "It will be wise for you to do so because the Cat Paw Merchants are doing this at a loss!"; + next; + mes "[Namis]"; + mes "Details are on the notice."; + close; + case 3: + mes "[Namis]"; + mes "Hick- Slurp-"; + mes "Remember, human! There's no other cat who works as hard as I do."; + close; + } + mes "[Namis]"; + mes "You must be here to participate in the '^C379CEInvest Unused Items for Prizes!^000000' event of the Cat Paw Merchants."; + next; + mes "[Namis]"; + mes "So, which event do you wish to participate in?"; + next; + switch(select("Not interested:Event 1 Items:Event 2 Items")) { + case 1: + mes "[Namis]"; + mes "Don't you mess with a busy cat!"; + close; + case 2: + mes "[Namis]"; + mes "So you're in for Event 1."; + mes "Choose from the shown list."; + next; + setarray .@event1$[0], + "Wings of the Insect Queen","Crown of the Fly King","I hear Dragon Scales are tough 01","The Meaning of the Mother's Nightmare", + "To refine ore","Hekekek Orcs, Orcs!!","Study of Yin-Yang","Secrets of the Pyramid King","Tick-tock the time goes", + "Planting trees on Mellow Island","Ancient language research","Weapons made of sharp teeth","Toy boss doll 01", + "A tiger is just a cat after all","The shattered spear and shield?","Toy boss doll 02","Best in summer! Cold scales", + "Piece of Thanatos' armor","I hear Dragon Scales are tough 02","The identity of the creepy eye","If only I could see!"; + set .@i, select(implode(.@event1$[0],":"))-1; + switch(.@i+1) { + case 1: callsub L_Check,"2 Pieces of Queen's Wing",6326,2,"Wings of the Insect Queen? What a pitiful name. I would've given some cool names!",.@event1$[.@i]; + case 2: callsub L_Check,"2 Broken Crowns",7754,2,"For crying out loud! Those cats working on these events must be playing around. Can't they think of a better name?",.@event1$[.@i]; + case 3: callsub L_Check,"2 Fire Dragon Scales",7451,2,"Dragon scales? Well... I guess they are tough. But what are they going to use them for?",.@event1$[.@i]; + case 4: callsub L_Check,"3 Mother's Nightmares",7020,3,"Even though I don't have the authority to find out, I wonder what they're doing with the collected items?",.@event1$[.@i]; + case 5: callsub L_Check,"5 Gemstones",7300,5,"Something useful for a change. The ore will end up as nice pieces of jewelry.",.@event1$[.@i]; + case 6: callsub L_Check,"5 Heroic Emblems",968,5,"Good, good. This is the kind of name I wanted!",.@event1$[.@i]; + case 7: callsub L_Check,"3 Taeguk Plates",7169,3,"Taking in something like this, maybe they're up to something dangerous.",.@event1$[.@i]; + case 8: callsub L_Check,"3 Broken Pharaoh Symbols and 3 Tutankhamen's Masks",7113,3,"I hear the pyramids are in Morroc, but I've never been there. Some humans call it Morco.",.@event1$[.@i],7114,3; + case 9: callsub L_Check,"2 Pocket Watches",7513,2,"Those lazy merchants, why do they need pocket watches they don't even use?",.@event1$[.@i]; + case 10: callsub L_Check,"3 Young Twigs",7018,3,"Mellow Island has a climate like with where we cats used to live. But the trees die out sometimes due to it being an island.",.@event1$[.@i]; + case 11: callsub L_Check,"5 Rossata Pieces",7211,5,"I guess they collect these because humans have them, but what's the use of researching ancient languages?",.@event1$[.@i]; + case 12: callsub L_Check,"5 Fangs of Garm",7036,5,"Weak humans need sharp weapons, but cats already have nice and sharp claws, so why are we collecting these!!",.@event1$[.@i]; + case 13: callsub L_Check,"3 Baphomet Dolls",750,3,"Baphomet dolls are great for playing around with.",.@event1$[.@i]; + case 14: callsub L_Check,"1 Tiger's Footskin and 5 Tiger Skins",1030,1,"Did you know that tigers are cats too? Therefore, cats are better than tigers.",.@event1$[.@i],1029,5; + case 15: callsub L_Check,"3 Broken Shield Pieces and 3 Shining Spear Blades",7108,3,"I don't know what they want with these.",.@event1$[.@i],7109,3; + case 16: callsub L_Check,"3 Osiris Dolls",751,3,"Shame~ I never got to play with an Osiris doll.",.@event1$[.@i]; + case 17: callsub L_Check,"1 Ice Scale",7562,1,"Mellow Island is a fabulous place to live. But the ships are too hot.",.@event1$[.@i]; + case 18: callsub L_Check,"1 Skeletal Armor Piece",7450,1,"Ewww... Why would they collect something so creepy?",.@event1$[.@i]; + case 19: callsub L_Check,"1 Darkred Scale Piece",6091,1,"Dragon scales? Well... I guess they are tough. But what are they going to use them for?",.@event1$[.@i]; + case 20: callsub L_Check,"2 Wills of Red Darkness",7566,2,"Interesting! Does it scream or something when I poke it in the eye?",.@event1$[.@i]; + case 21: callsub L_Check,"2 Foolishness of the Blind",7021,2,"This blind man is foolish in not knowing that gathering 300 cats cures blindness...",.@event1$[.@i]; + } + case 3: + mes "[Namis]"; + mes "Participate in Event 2?"; + mes "It is not yet in motion. Wait for it!"; + close; + } + end; +L_Check: + set .@args, getargcount(); + if (.@args > 5) { + if (countitem(getarg(5)) < getarg(6)) + set .@items,1; //incomplete + else + set .@items,2; //complete + } + if (countitem(getarg(1)) < getarg(2) || .@items == 1) { + mes "[Namis]"; + mes "You don't have the items?"; + mes getarg(0)+" exchange for one Cat Paw Merchants Investment Certificate."; + next; + mes "[Namis]"; + mes "Don't bother me and look up the details on the board over there!"; + close; + } + mes "[Namis]"; + mes "'^8E5601"+getarg(4)+" Event^000000'"; + mes "Seems to be the right items."; + mes getarg(3); + mes "Oh! Almost forgot. Will you invest?"; + next; + if(select("Invest:Don't Invest") == 2) { + mes "[Namis]"; + mes "Don't you mess with a busy cat!"; + close; + } + delitem getarg(1),getarg(2); + if (.@items == 2) + delitem getarg(5),getarg(6); + getitem 6489,1; //Cats_Invest_Certif + mes "[Namis]"; + mes "Here's your Certificate. Always be grateful to the Merchants for these events!"; + close; +OnTouch: + if (rand(2)) + emotion e_yawn; + else + specialeffect EF_SLEEPATTACK; + end; +} + +// Investment Rewards +//============================================================ +malangdo,215,119,4 script Thanks Ticket Machine 564,{ + if (MaxWeight - Weight < 4500 || checkweight(1201,1) == 0) { + mes "- Currently you're carrying -"; + mes "- too many items with you. -"; + mes "- Please try again after you -"; + mes "- lose some weight. -"; + close; + } + mes "[Vending Machine Notice]"; + mes "^6815EA1. Don't kick the machine please. @_@"; + mes "2. You can only insert Invest Thanks Ticket."; + mes "3. About the Jelly Box, if you open it, it gives you a random item."; + mes "4. Hope you enjoy~^000000"; + mes "- Mr. Cat, the Machine Owner -"; + next; + switch(select("Finish:Purchase:Red Paw Jelly Bag (5 Tickets):Black Paw Jelly Bag (50 Tickets)")) { + case 1: + close; + case 2: + mes "The Vending Machine is selling items in the following list."; + next; + switch(select("Finish:1 Siege Arrow Quiver A (2 Tickets):1 Siege Arrow Quiver S (2 Tickets):30 White Potion (12 Tickets):30 White Slim Potion (14 Tickets):10 Dark Water (20 Tickets):20 Siege_Violet_Potion (30 Tickets):10 Coldproof Potion (30 Tickets):10 Thunderproof Potion (30 Tickets):10 Earthproof Potion (30 Tickets):10 Fireproof Potion (30 Tickets):10 Elemental Converter[Fire] (30 Tickets)")) { + case 1: close; + case 2: callsub L_Purchase,2,12678,1; //Siege_Arrow_Quiver_A + case 3: callsub L_Purchase,2,12677,1; //Siege_Arrow_Quiver_S + case 4: callsub L_Purchase,12,504,30; //White_Potion + case 5: callsub L_Purchase,14,547,30; //White_Slim_Potion + case 6: callsub L_Purchase,20,12020,10; //Water_Of_Darkness + case 7: callsub L_Purchase,30,11547,20; //Woe_Violet_Potion + case 8: callsub L_Purchase,30,12119,10; //Resist_Water + case 9: callsub L_Purchase,30,12121,10; //Resist_Wind + case 10: callsub L_Purchase,30,12120,10; //Resist_Earth + case 11: callsub L_Purchase,30,12118,10; //Resist_Fire + case 12: callsub L_Purchase,30,12114,10,"Elemental Converter[Fire]"; //Elemental_Fire + case 13: callsub L_Purchase,30,12115,10,"Elemental Converter[Water]"; //Elemental_Water + case 14: callsub L_Purchase,30,12117,10,"Elemental Converter[Wind]"; //Elemental_Wind + case 15: callsub L_Purchase,30,12116,10,"Elemental Converter[Earth]"; //Elemental_Earth + } + end; + case 3: + mes "Red Paw Jelly Bag Button chosen. Need to insert 5 ^FF0000Invest Thanks Ticket^000000 and a random item will appear."; + next; + if (countitem(6488) < 5) { + mes "You don't have enough ^FF0000Invest Thanks Ticket^000000 to proceed."; + close; + } + delitem 6488,5; //Thanks_Invest_Ticket + set .@i, rand(1,10000); + if (.@i <= 100) callsub L_Bag,12531,1; //White_Potion_Box + else if (.@i <= 200) callsub L_Bag,12549,1; //White_Slim_Pot_Box2 + else if (.@i <= 250) callsub L_Bag,11549,10; //Woe_Blue_Potion + else if (.@i <= 660) callsub L_Bag,617,1; //Old_Violet_Box + else if (.@i <= 710) callsub L_Bag,12532,1; //Royal_Jelly_Box2 + else if (.@i <= 760) callsub L_Bag,12533,1; //Blue_Herb_Box2 + else if (.@i <= 810) callsub L_Bag,505,5; //Blue_Potion + else if (.@i <= 1110) callsub L_Bag,644,1; //Gift_Box + else if (.@i <= 1120) callsub L_Bag,607,1; //Yggdrasilberry + else if (.@i <= 1130) callsub L_Bag,608,2; //Seed_Of_Yggdrasil + else if (.@i <= 1140) callsub L_Bag,12292,5; //Unripe_Fruit + else if (.@i <= 1150) callsub L_Bag,12293,5; //Dried_Yggdrasilberry + else if (.@i <= 1250) callsub L_Bag,12679,1; //Sg_White_Potion_Box + else if (.@i <= 1471) callsub L_Bag,603,1; //Old_Blue_Box + else if (.@i <= 1571) callsub L_Bag,12550,1,"Poison Bottle Box(30)"; //Poison_Bottle_Box2 + else if (.@i <= 1671) callsub L_Bag,12020,10; //Water_Of_Darkness + else if (.@i <= 1871) callsub L_Bag,12030,5; //Box_Of_Grudge + else if (.@i <= 2071) callsub L_Bag,12031,5; //Sleepy_Box + else if (.@i <= 2371) callsub L_Bag,12033,2; //Box_Of_Sunlight + else if (.@i <= 2571) callsub L_Bag,12114,5,"Elemental Converter[Fire]"; //Elemental_Fire + else if (.@i <= 2771) callsub L_Bag,12115,5,"Elemental Converter[Water]"; //Elemental_Water + else if (.@i <= 2971) callsub L_Bag,12117,5,"Elemental Converter[Wind]"; //Elemental_Wind + else if (.@i <= 3171) callsub L_Bag,12116,5,"Elemental Converter[Earth]"; //Elemental_Earth + else if (.@i <= 3271) callsub L_Bag,12680,1; //Sg_Blue_Potion_Box + else if (.@i <= 3471) callsub L_Bag,12118,5; //Resist_Fire + else if (.@i <= 3671) callsub L_Bag,12119,5; //Resist_Water + else if (.@i <= 3871) callsub L_Bag,12121,5; //Resist_Wind + else if (.@i <= 4071) callsub L_Bag,12120,5; //Resist_Earth + else if (.@i <= 4271) callsub L_Bag,929,20; //Immortal_Heart + else if (.@i <= 4471) callsub L_Bag,1059,20; //Transparent_Cloth + else if (.@i <= 4671) callsub L_Bag,905,20; //Stem + else if (.@i <= 4871) callsub L_Bag,606,10; //Aloebera + else if (.@i <= 5071) callsub L_Bag,609,10; //Amulet + else if (.@i <= 5271) callsub L_Bag,710,2; //Illusion_Flower + else if (.@i <= 5471) callsub L_Bag,576,20; //Prickly_Fruit + else if (.@i <= 5671) callsub L_Bag,621,10; //Bitter_Herb + else if (.@i <= 5871) callsub L_Bag,709,10; //Izidor + else if (.@i <= 6071) callsub L_Bag,605,10; //Anodyne + else if (.@i <= 6171) callsub L_Bag,11548,10; //Woe_White_Potion + else if (.@i <= 6371) callsub L_Bag,706,10; //Four_Leaf_Clover + else if (.@i <= 6571) callsub L_Bag,521,10; //Leaflet_Of_Aloe + else if (.@i <= 6771) callsub L_Bag,707,10; //Singing_Plant + else if (.@i <= 6971) callsub L_Bag,610,10; //Leaf_Of_Yggdrasil + else if (.@i <= 7021) callsub L_Bag,12676,1; //Sg_Violet_Potion_Box + else if (.@i <= 7171) callsub L_Bag,6249,10; //Savage_Meat + else if (.@i <= 7321) callsub L_Bag,6252,10; //Wolf_Blood + else if (.@i <= 7471) callsub L_Bag,6254,10; //Beef_Head_Meat + else if (.@i <= 7621) callsub L_Bag,6253,10; //Cold_Ice + else if (.@i <= 7771) callsub L_Bag,6256,10; //Ice_Fragment + else if (.@i <= 7921) callsub L_Bag,6257,10; //Ice_Crystal + else if (.@i <= 8071) callsub L_Bag,6260,10; //Petti_Tail + else if (.@i <= 8309) callsub L_Bag,7932,20; //Poison_Herb_Nerium + else if (.@i <= 8547) callsub L_Bag,7933,20; //Poison_Herb_Rantana + else if (.@i <= 8785) callsub L_Bag,7934,20; //Poison_Herb_Makulata + else if (.@i <= 9023) callsub L_Bag,7935,20; //Poison_Herb_Seratum + else if (.@i <= 9261) callsub L_Bag,7936,20; //Poison_Herb_Scopolia + else if (.@i <= 9499) callsub L_Bag,7937,20; //Poison_Herb_Amoena + else if (.@i <= 9699) callsub L_Bag,6217,20; //Mandragora_Flowerpot + else callsub L_Bag,12016,10; //Speed_Up_Potion + end; + case 4: + mes "Black Paw Jelly Bag Button chosen. Need to insert 50 ^FF0000Invest Thanks Ticket^000000 and a random item will appear."; + next; + if (countitem(6488) < 50) { + mes "You don't have enough ^FF0000Invest Thanks Ticket^000000 to proceed."; + close; + } + delitem 6488,50; //Thanks_Invest_Ticket + set .@i, rand(1,10000); + if (.@i <= 100) callsub L_Bag,12531,1; //White_Potion_Box + else if (.@i <= 200) callsub L_Bag,12549,1; //White_Slim_Pot_Box2 + else if (.@i <= 250) callsub L_Bag,11549,20; //Woe_Blue_Potion + else if (.@i <= 450) callsub L_Bag,617,1; //Old_Violet_Box + else if (.@i <= 500) callsub L_Bag,12532,1; //Royal_Jelly_Box2 + else if (.@i <= 550) callsub L_Bag,12533,1; //Blue_Herb_Box2 + else if (.@i <= 600) callsub L_Bag,505,10; //Blue_Potion + else if (.@i <= 800) callsub L_Bag,644,1; //Gift_Box + else if (.@i <= 810) callsub L_Bag,607,2; //Yggdrasilberry + else if (.@i <= 820) callsub L_Bag,608,3; //Seed_Of_Yggdrasil + else if (.@i <= 830) callsub L_Bag,12292,10; //Unripe_Fruit + else if (.@i <= 840) callsub L_Bag,12293,10; //Dried_Yggdrasilberry + else if (.@i <= 940) callsub L_Bag,12679,1; //Sg_White_Potion_Box + else if (.@i <= 1140) callsub L_Bag,603,1; //Old_Blue_Box + else if (.@i <= 1240) callsub L_Bag,12550,1,"Poison Bottle Box(30)"; //Poison_Bottle_Box2 + else if (.@i <= 1340) callsub L_Bag,12020,20; //Water_Of_Darkness + else if (.@i <= 1440) callsub L_Bag,12030,10; //Box_Of_Grudge + else if (.@i <= 1540) callsub L_Bag,12031,10; //Sleepy_Box + else if (.@i <= 1690) callsub L_Bag,12033,4; //Box_Of_Sunlight + else if (.@i <= 1790) callsub L_Bag,12114,10,"Elemental Converter[Fire]"; //Elemental_Fire + else if (.@i <= 1890) callsub L_Bag,12115,10,"Elemental Converter[Water]"; //Elemental_Water + else if (.@i <= 1990) callsub L_Bag,12117,10,"Elemental Converter[Wind]"; //Elemental_Wind + else if (.@i <= 2090) callsub L_Bag,12116,10,"Elemental Converter[Earth]"; //Elemental_Earth + else if (.@i <= 2190) callsub L_Bag,12680,1; //Sg_Blue_Potion_Box + else if (.@i <= 2290) callsub L_Bag,12118,10; //Resist_Fire + else if (.@i <= 2390) callsub L_Bag,12119,10; //Resist_Water + else if (.@i <= 2490) callsub L_Bag,12121,10; //Resist_Wind + else if (.@i <= 2590) callsub L_Bag,12120,10; //Resist_Earth + else if (.@i <= 2690) callsub L_Bag,929,40; //Immortal_Heart + else if (.@i <= 2790) callsub L_Bag,1059,40; //Transparent_Cloth + else if (.@i <= 2890) callsub L_Bag,905,40; //Stem + else if (.@i <= 2990) callsub L_Bag,606,20; //Aloebera + else if (.@i <= 3090) callsub L_Bag,609,20; //Amulet + else if (.@i <= 3190) callsub L_Bag,710,4; //Illusion_Flower + else if (.@i <= 3290) callsub L_Bag,576,40; //Prickly_Fruit + else if (.@i <= 3390) callsub L_Bag,621,20; //Bitter_Herb + else if (.@i <= 3490) callsub L_Bag,709,20; //Izidor + else if (.@i <= 3590) callsub L_Bag,605,20; //Anodyne + else if (.@i <= 3690) callsub L_Bag,11548,20; //Woe_White_Potion + else if (.@i <= 3790) callsub L_Bag,706,20; //Four_Leaf_Clover + else if (.@i <= 3890) callsub L_Bag,521,20; //Leaflet_Of_Aloe + else if (.@i <= 3990) callsub L_Bag,707,20; //Singing_Plant + else if (.@i <= 4090) callsub L_Bag,610,20; //Leaf_Of_Yggdrasil + else if (.@i <= 4140) callsub L_Bag,12676,1; //Sg_Violet_Potion_Box + else if (.@i <= 4240) callsub L_Bag,6249,20; //Savage_Meat + else if (.@i <= 4340) callsub L_Bag,6252,20; //Wolf_Blood + else if (.@i <= 4440) callsub L_Bag,6254,20; //Beef_Head_Meat + else if (.@i <= 4540) callsub L_Bag,6253,20; //Cold_Ice + else if (.@i <= 4640) callsub L_Bag,6256,20; //Ice_Fragment + else if (.@i <= 4740) callsub L_Bag,6257,20; //Ice_Crystal + else if (.@i <= 4840) callsub L_Bag,6260,20; //Petti_Tail + else if (.@i <= 4940) callsub L_Bag,7932,40; //Poison_Herb_Nerium + else if (.@i <= 5040) callsub L_Bag,7933,40; //Poison_Herb_Rantana + else if (.@i <= 5140) callsub L_Bag,7934,40; //Poison_Herb_Makulata + else if (.@i <= 5240) callsub L_Bag,7935,40; //Poison_Herb_Seratum + else if (.@i <= 5340) callsub L_Bag,7936,40; //Poison_Herb_Scopolia + else if (.@i <= 5440) callsub L_Bag,7937,40; //Poison_Herb_Amoena + else if (.@i <= 5540) callsub L_Bag,6217,40; //Mandragora_Flowerpot + else if (.@i <= 6000) callsub L_Bag,12016,20; //Speed_Up_Potion + else if (.@i <= 6500) callsub L_Bag,2483,1; //Siege_Greave + else if (.@i <= 7000) callsub L_Bag,2484,1; //Siege_Boots + else if (.@i <= 7500) callsub L_Bag,2485,1; //Siege_Shoes + else if (.@i <= 8000) callsub L_Bag,2586,1; //Siege_Manteau + else if (.@i <= 8500) callsub L_Bag,2587,1; //Siege_Muffler + else if (.@i <= 9000) callsub L_Bag,15046,1; //Siege_Plate + else if (.@i <= 9500) callsub L_Bag,15047,1; //Siege_Suits + else callsub L_Bag,15048,1; //Siege_Robe + end; + } + end; + +//callsub L_Purchase,<ticket cost>,<reward ID>,<reward amount>{,<reward name>}; +L_Purchase: + if (countitem(6488) < getarg(0)) { + mes "You don't have enough ^FF0000Invest Thanks Ticket^000000 to proceed."; + close; + } + delitem 6488,getarg(0); //Thanks_Invest_Ticket + getitem getarg(1),getarg(2); + mes "- Done! -"; + next; + mes "The item ^0000FF"+((getargcount() > 3)?getarg(3,""):getitemname(getarg(1)))+"^000000 has been obtained."; + close; + +//callsub L_Bag,<reward ID>,<reward amount>{,<reward name>}; +L_Bag: + getitem getarg(0),getarg(1); + mes "- Done! -"; + next; + mes "The item ^0000FF"+((getargcount() > 2)?getarg(2,""):getitemname(getarg(0)))+"^000000 has been obtained."; + close; +} diff --git a/npc/re/guild/invest_npc.txt b/npc/re/guild/invest_npc.txt new file mode 100644 index 000000000..3c6c45ee5 --- /dev/null +++ b/npc/re/guild/invest_npc.txt @@ -0,0 +1,66 @@ +//===== rAthena Script ======================================= +//= Hall of Abyss - NPC Duplicates +//===== By: ================================================== +//= Euphy +//===== Current Version: ===================================== +//= 1.0 +//===== Compatible With: ===================================== +//= rAthena SVN +//===== Description: ========================================= +//= Expansion for War of Emperium FE. +//= Invest in each realm to unlock new maps: +//= - Guild Dungeon F2, total 20,000,000z. +//= - Hall of Abyss, total 70,000,000z. +//===== Additional Comments: ================================= +//= 1.0 First version. [Euphy] +//============================================================ + +// Realms - Merchant Guilds, Gate Managers, Status Boards +//============================================================ +alde_gld,186,157,3 duplicate(Cat Paw Merchant Guild) Cat Paw Merchant Megrez 549 +alde_gld,191,164,3 duplicate(Gate Manager#realm) Gate Manager#alde_f00 421 +alde_gld,188,158,3 duplicate(Investment Status Board) Investment Status Board::InvestStatus_Alde 857 + +gef_fild13,187,208,3 duplicate(Cat Paw Merchant Guild) Cat Paw Merchant Meraq 549 +gef_fild13,189,206,3 duplicate(Gate Manager#realm) Gate Manager#gef_f00 421 +gef_fild13,190,209,3 duplicate(Investment Status Board) Investment Status Board::InvestStatus_Gef 857 + +pay_gld,203,189,3 duplicate(Cat Paw Merchant Guild) Cat Paw Merchant Phecda 549 +pay_gld,206,189,3 duplicate(Gate Manager#realm) Gate Manager#pay_f00 421 +pay_gld,200,189,5 duplicate(Investment Status Board) Investment Status Board::InvestStatus_Pay 857 + +prt_gld,158,96,5 duplicate(Cat Paw Merchant Guild) Cat Paw Merchant Dubae 549 +prt_gld,161,96,3 duplicate(Gate Manager#realm) Gate Manager#prt_f00 421 +prt_gld,163,99,3 duplicate(Investment Status Board) Investment Status Board::InvestStatus_Prt 857 + +// Inside Castles - Gate Managers +//============================================================ +aldeg_cas01,85,105,4 duplicate(Gate Manager#castle) Gate Manager#alde_f01 421 +aldeg_cas02,124,49,3 duplicate(Gate Manager#castle) Gate Manager#alde_f02 421 +aldeg_cas03,121,75,3 duplicate(Gate Manager#castle) Gate Manager#alde_f03 421 +aldeg_cas04,25,67,7 duplicate(Gate Manager#castle) Gate Manager#alde_f04 421 +aldeg_cas05,54,200,3 duplicate(Gate Manager#castle) Gate Manager#alde_f05 421 + +gefg_cas01,39,49,4 duplicate(Gate Manager#castle) Gate Manager#gef_f01 421 +gefg_cas02,10,65,4 duplicate(Gate Manager#castle) Gate Manager#gef_f02 421 +gefg_cas03,100,87,4 duplicate(Gate Manager#castle) Gate Manager#gef_f03 421 +gefg_cas04,35,44,3 duplicate(Gate Manager#castle) Gate Manager#gef_f04 421 +gefg_cas05,84,46,3 duplicate(Gate Manager#castle) Gate Manager#gef_f05 421 + +payg_cas01,129,59,3 duplicate(Gate Manager#castle) Gate Manager#pay_f01 421 +payg_cas02,27,277,3 duplicate(Gate Manager#castle) Gate Manager#pay_f02 421 +payg_cas03,51,266,3 duplicate(Gate Manager#castle) Gate Manager#pay_f03 421 +payg_cas04,39,264,4 duplicate(Gate Manager#castle) Gate Manager#pay_f04 421 +payg_cas05,272,252,4 duplicate(Gate Manager#castle) Gate Manager#pay_f05 421 + +prtg_cas01,114,178,3 duplicate(Gate Manager#castle) Gate Manager#prt_f01 421 +prtg_cas02,89,63,5 duplicate(Gate Manager#castle) Gate Manager#prt_f02 421 +prtg_cas03,72,109,3 duplicate(Gate Manager#castle) Gate Manager#prt_f03 421 +prtg_cas04,29,263,4 duplicate(Gate Manager#castle) Gate Manager#prt_f04 421 +prtg_cas05,24,23,4 duplicate(Gate Manager#castle) Gate Manager#prt_f05 421 + +// iRO NPC Locations +//============================================================ +//prt_gld,148,253,4 duplicate(Cat Paw Merchants Notice) Cat Paw Merchants Notice::CatPawNotice_iRO 857 +//prt_gld,145,255,6 duplicate(Namis#invest) Namis::Namis_iRO 545,4,4 +//prt_gld,165,50,4 duplicate(Thanks Ticket Machine) Thanks Ticket Machine::ThanksMachine_iRO 564 diff --git a/npc/re/instances/HazyForest.txt b/npc/re/instances/HazyForest.txt index cb65f11d7..cecdadd20 100644 --- a/npc/re/instances/HazyForest.txt +++ b/npc/re/instances/HazyForest.txt @@ -1,18 +1,18 @@ -//===== rAthena Script ======================================= +//===== Hercules Script ====================================== //= Hazy Forest -//===== By: ================================================== +//===== By: ================================================== //= Euphy -//===== Current Version: ===================================== +//===== Current Version: ===================================== //= 1.0 -//===== Compatible With: ===================================== -//= rAthena SVN -//===== Description: ========================================= +//===== Compatible With: ===================================== +//= Hercules +//===== Description: ========================================= //= [Official Conversion] //= Cross through the Hazy Forest to reach the Bifrost. //= Contains the Wandering Guardian quest. -//===== Additional Comments: ================================= +//===== Additional Comments: ================================= //= 1.0 First version. [Euphy] -//============================================================ +//============================================================ // Instance Creation //============================================================ diff --git a/npc/re/mobs/dungeons/gld_dun.txt b/npc/re/mobs/dungeons/gld_dun.txt deleted file mode 100644 index 7ac2d9f9f..000000000 --- a/npc/re/mobs/dungeons/gld_dun.txt +++ /dev/null @@ -1,52 +0,0 @@ -//===== Hercules Script ====================================== -//= Guild Dungeons Monster Spawn Script -//===== By: ================================================== -//= Athena (1.0) -//===== Current Version: ===================================== -//= 1.3 -//===== Compatible With: ===================================== -//= Hercules -//===== Additional Comments: ================================= -//= 1.2 Official kRO 10.1 spawns [Playtester] -//= 1.3 Corrected MVP spawn variance. [Gepard] -//============================================================ - -//================================================== -// gld_dun01 - Guild Dungeon -//================================================== -gld_dun01,0,0,0,0 monster Am Mut 1301,20,5000,0,0 -gld_dun01,0,0,0,0 monster Skeleton General 1290,10,5000,0,0 -gld_dun01,0,0,0,0 monster Gajomart 1309,10,5000,0,0 -gld_dun01,0,0,0,0 monster Cat o' Nine Tails 1307,3,1200000,0,0 -gld_dun01,0,0,0,0 monster Vagabond Wolf 1092,1,14400000,7200000,1 -gld_dun01,0,0,0,0 boss_monster Eddga 1115,1,28800000,600000,1 - -//================================================== -// gld_dun02 - Guild Dungeon -//================================================== -gld_dun02,0,0,0,0 monster Giant Hornet 1303,10,120000,60000,0 -gld_dun02,0,0,0,0 monster Giant Spider 1304,10,240000,120000,0 -gld_dun02,0,0,0,0 monster Ancient Worm 1305,7,120000,60000,0 -gld_dun02,0,0,0,0 monster Killer Mantis 1294,5,120000,60000,0 -gld_dun02,0,0,0,0 monster Owl Baron 1295,1,5000,0,0 -gld_dun02,0,0,0,0 boss_monster Doppelganger 1046,1,28800000,600000,1 - -//================================================== -// gld_dun03 - Guild Dungeon -//================================================== -gld_dun03,0,0,0,0 monster Caterpillar 1300,20,5000,0,0 -gld_dun03,0,0,0,0 monster Creamy Fear 1293,20,5000,0,0 -gld_dun03,0,0,0,0 monster Leib Olmai 1306,20,5000,0,0 -gld_dun03,0,0,0,0 monster Gullinbursti 1311,10,5000,0,0 -gld_dun03,0,0,0,0 monster Maya Purple 1289,3,1200000,600000,0 -gld_dun03,0,0,0,0 boss_monster Maya 1147,1,28800000,600000,1 - -//================================================== -// gld_dun04 - Guild Dungeon -//================================================== -gld_dun04,0,0,0,0 monster Zombie Master 1298,29,5000,0,0 -gld_dun04,0,0,0,0 monster Wraith Dead 1291,27,5000,0,0 -gld_dun04,0,0,0,0 monster Mini Demon 1292,3,5000,0,0 -gld_dun04,0,0,0,0 monster Dark Illusion 1302,1,1200000,0,0 -gld_dun04,0,0,0,0 monster Ghostring 1120,1,14400000,7200000,1 -gld_dun04,0,0,0,0 boss_monster Dark Lord 1272,1,28800000,600000,1 diff --git a/npc/re/mobs/dungeons/gld_re.txt b/npc/re/mobs/dungeons/gld_re.txt new file mode 100644 index 000000000..1280755a7 --- /dev/null +++ b/npc/re/mobs/dungeons/gld_re.txt @@ -0,0 +1,100 @@ +//===== Hercules Script ====================================== +//= Renewal Guild Monster Spawn Script +//===== By: ================================================== +//= Euphy +//===== Current Version: ===================================== +//= 1.0 +//===== Compatible With: ===================================== +//= Hercules +//===== Additional Comments: ================================= +//= 1.0 First version, Hall of Abyss update. [Euphy] +//============================================================ + +//================================================== +// Baldur - gld_dun01, gld_dun01_2, gld2_pay +//================================================== +gld_dun01,0,0,0,0 monster Gullinbursti 1311,30,5000,0,0 +gld_dun01,0,0,0,0 monster Leib Olmai 1306,55,5000,0,0 +gld_dun01,0,0,0,0 monster Cat O' Nine Tails 1307,3,1200000,0,0 +gld_dun01,0,0,0,0 boss_monster Moonlight Flower 1150,1,28800000,600000,1 + +gld_dun01_2,0,0,0,0 monster Skeleton General 1290,50,5000,0,0 +gld_dun01_2,0,0,0,0 monster Am Mut 1301,15,5000,0,0 +gld_dun01_2,0,0,0,0 monster Gajomart 1309,20,5000,0,0 +gld_dun01_2,0,0,0,0 boss_monster Eddga 1115,1,28800000,600000,1 + +gld2_pay,0,0,0,0 monster Skeleton General 1290,60,5000,0,0 +gld2_pay,0,0,0,0 monster Am Mut 1301,25,5000,0,0 +gld2_pay,0,0,0,0 monster Gajomart 1309,30,5000,0,0 +gld2_pay,0,0,0,0 boss_monster General Daehyun 2253,1,28800000,600000,1 +gld2_pay,0,0,0,0 monster Samurai Soheon 2254,1,1800000,600000,1 + +//================================================== +// Luina - gld_dun02, gld_dun02_2, gld2_ald +//================================================== +gld_dun02,0,0,0,0 monster Giant Hornet 1303,30,5000,0,0 +gld_dun02,0,0,0,0 monster Ancient Worm 1305,25,5000,0,0 +gld_dun02,0,0,0,0 monster Giant Spider 1304,15,5000,0,0 +gld_dun02,0,0,0,0 boss_monster Mistress 1059,1,28800000,600000,1 + +gld_dun02_2,0,0,0,0 monster Killer Mantis 1294,30,5000,0,0 +gld_dun02_2,0,0,0,0 monster Angra Mantis 2133,40,5000,0,0 +gld_dun02_2,0,0,0,0 monster Maya Purple 1289,3,1200000,600000,0 +gld_dun02_2,0,0,0,0 boss_monster Maya 1147,1,28800000,600000,1 + +gld2_ald,0,0,0,0 monster Killer Mantis 1294,60,5000,0,0 +gld2_ald,0,0,0,0 monster Angra Mantis 2133,70,5000,0,0 +gld2_ald,0,0,0,0 monster Maya Purple 1289,3,1200000,0,0 +gld2_ald,0,0,0,0 boss_monster Gioia 2251,1,28800000,600000,1 +gld2_ald,0,0,0,0 monster Elvira 2252,1,1800000,600000,1 + +//================================================== +// Valkyrie - gld_dun03, gld_dun03_02, gld2_prt +//================================================== +gld_dun03,0,0,0,0 monster Caterpillar 1300,35,5000,0,0 +gld_dun03,0,0,0,0 monster Creamy Fear 1293,35,5000,0,0 +gld_dun03,0,0,0,0 boss_monster Baphomet 1039,1,28800000,600000,1 + +gld_dun03_2,0,0,0,0 monster Dark Axe Kobold 2284,13,5000,0,0 +gld_dun03_2,0,0,0,0 monster Dark Hammer Kobold 2285,23,5000,0,0 +gld_dun03_2,0,0,0,0 monster Dark Mace Kobold 2286,23,5000,0,0 +gld_dun03_2,0,0,0,0 monster Dark Kobold Archer 2287,23,5000,0,0 +gld_dun03_2,0,0,0,0 monster Kobold Leader 1296,1,14400000,7200000,1 +gld_dun03_2,0,0,0,0 boss_monster Atroce 1785,1,28800000,600000,1 + +gld2_prt,0,0,0,0 monster Dark Axe Kobold 2284,25,5000,0,0 +gld2_prt,0,0,0,0 monster Dark Hammer Kobold 2285,35,5000,0,0 +gld2_prt,0,0,0,0 monster Dark Mace Kobold 2286,35,5000,0,0 +gld2_prt,0,0,0,0 monster Dark Kobold Archer 2287,35,5000,0,0 +gld2_prt,0,0,0,0 boss_monster Angry Student Pyuriel 2249,1,28800000,600000,1 +gld2_prt,0,0,0,0 monster Warrior Laura 2250,1,1800000,600000,1 + +//================================================== +// Britoniah - gld_dun04, gld_dun04_02, gld2_gef +//================================================== +gld_dun04,0,0,0,0 monster Mini Demon 1292,10,5000,0,0 +gld_dun04,0,0,0,0 monster Zombie Master 1298,55,5000,0,0 +gld_dun04,0,0,0,0 monster Wraith Dead 1291,25,5000,0,0 +gld_dun04,0,0,0,0 monster Ghostring 1120,1,14400000,7200000,1 +gld_dun04,0,0,0,0 boss_monster Doppelganger 1046,1,28800000,600000,1 + +gld_dun04_2,0,0,0,0 monster Dark Frame 2282,15,5000,0,0 +gld_dun04_2,0,0,0,0 monster Dark Priest 2283,15,5000,0,0 +gld_dun04_2,0,0,0,0 monster Dark Shadow 2281,45,5000,0,0 +gld_dun04_2,0,0,0,0 monster Dark Illusion 1302,1,1200000,0,0 +gld_dun04_2,0,0,0,0 boss_monster Dark Lord 1272,1,28800000,600000,1 + +gld2_gef,0,0,0,0 monster Dark Frame 2282,20,5000,0,0 +gld2_gef,0,0,0,0 monster Dark Priest 2283,20,5000,0,0 +gld2_gef,0,0,0,0 monster Dark Shadow 2281,80,5000,0,0 +gld2_gef,0,0,0,0 monster Dark Illusion 1302,1,1200000,0,0 +gld2_gef,0,0,0,0 boss_monster Dark Guardian Kades 2255,1,28800000,600000,1 +gld2_gef,0,0,0,0 monster Rudo 2256,1,1800000,600000,1 + +//================================================== +// Treasure Chests +//================================================== +gld2_pay,0,0,0,0 monster Treasure Chest 2288,5,5000,0,0 +gld2_ald,0,0,0,0 monster Treasure Chest 2288,5,5000,0,0 +gld2_prt,0,0,0,0 monster Treasure Chest 2288,5,5000,0,0 +gld2_gef,0,0,0,0 monster Treasure Chest 2288,5,5000,0,0 diff --git a/npc/re/scripts_monsters.conf b/npc/re/scripts_monsters.conf index 25811f8b3..46ab419d8 100644 --- a/npc/re/scripts_monsters.conf +++ b/npc/re/scripts_monsters.conf @@ -18,7 +18,7 @@ npc: npc/re/mobs/dungeons/ein_dun.txt npc: npc/re/mobs/dungeons/gef_dun.txt npc: npc/re/mobs/dungeons/gefenia.txt npc: npc/re/mobs/dungeons/glastheim.txt -npc: npc/re/mobs/dungeons/gld_dun.txt +npc: npc/re/mobs/dungeons/gld_re.txt npc: npc/re/mobs/dungeons/gld_dunSE.txt npc: npc/re/mobs/dungeons/gon_dun.txt npc: npc/re/mobs/dungeons/ice_dun.txt diff --git a/npc/re/warps/guildcastles.txt b/npc/re/warps/guildcastles.txt new file mode 100644 index 000000000..d8eab7cea --- /dev/null +++ b/npc/re/warps/guildcastles.txt @@ -0,0 +1,43 @@ +//===== rAthena Script ======================================= +//= Guild Castles Warp Script +//===== By: ================================================== +//= Euphy +//===== Current Version: ===================================== +//= 1.0 +//===== Compatible With: ===================================== +//= rAthena SVN +//===== Description: ========================================= +//= Warp Points for Renewal Guild Castles +//===== Additional Comments: ================================= +//= 1.0 First version. [Euphy] +//============================================================ + +// Hall of Abyss +//============================================================ +gld2_prt,10,22,0 warp dun2prt_to_gld 1,1,prt_gld,252,247 +gld2_prt,14,252,0 warp dun2prt_to_gld#2 1,1,prt_gld,63,66 +gld2_prt,266,236,0 warp dun2prt_to_gld#3 1,1,prt_gld,252,247 +gld2_prt,226,21,0 warp dun2prt_to_gld#4 1,1,prt_gld,63,66 +gld2_prt,103,11,0 warp dun2prt_to_gld#5 1,1,prt_gld,252,247 +gld_dun03_2,238,274,0 warp gdun03a_prtg#abyss 1,1,prt_gld,252,247 +gld_dun03_2,42,30,0 warp gdun03b_prtg#abyss 1,1,prt_gld,63,66 +gld2_pay,33,105,0 warp dun2pay_to_gld 1,1,pay_gld,53,141 +gld2_pay,119,21,0 warp dun2pay_to_gld#2 1,1,pay_gld,53,141 +gld2_pay,205,105,0 warp dun2pay_to_gld#3 1,1,pay_gld,53,141 +gld2_pay,175,215,0 warp dun2pay_to_gld#4 1,1,pay_gld,53,141 +gld2_pay,61,215,0 warp dun2pay_to_gld#5 1,1,pay_gld,53,141 +gld_dun01_2,119,14,0 warp gdun01_payg#abyss 1,1,pay_gld,53,141 +gld2_gef,28,205,0 warp dun2gef_to_gld 1,1,gef_fild13,42,331 +gld2_gef,221,145,0 warp dun2gef_to_gld#2 1,1,gef_fild13,373,62 +gld2_gef,175,198,0 warp dun2gef_to_gld#3 1,1,gef_fild13,42,331 +gld2_gef,25,68,0 warp dun2gef_to_gld#4 1,1,gef_fild13,373,62 +gld2_gef,111,35,0 warp dun2gef_to_gld#5 1,1,gef_fild13,42,331 +gld_dun04_2,37,230,0 warp gdun04_g13a#abyss 1,1,gef_fild13,42,331 +gld_dun04_2,110,20,0 warp gdun04_g13b#abyss 1,1,gef_fild13,373,62 +gld2_ald,172,46,0 warp dun2gef_to_gld#6 1,1,alde_gld,242,121 +gld2_ald,77,58,0 warp dun2gef_to_gld#7 1,1,alde_gld,229,185 +gld2_ald,46,122,0 warp dun2gef_to_gld#8 1,1,alde_gld,242,121 +gld2_ald,104,250,0 warp dun2gef_to_gld#9 1,1,alde_gld,229,185 +gld2_ald,247,156,0 warp dun2gef_to_gld#10 1,1,alde_gld,242,121 +gld_dun02_2,20,160,0 warp gdun02a_aldega#abyss 1,1,alde_gld,229,185 +gld_dun02_2,180,112,0 warp gdun02b_aldegb#abyss 1,1,alde_gld,242,121 diff --git a/src/common/mmo.h b/src/common/mmo.h index eaffdf7df..8643d2b54 100644 --- a/src/common/mmo.h +++ b/src/common/mmo.h @@ -54,6 +54,13 @@ // Comment the following line if your client is NOT ragexeRE (required because of conflicting packets in ragexe vs ragexeRE). #define PACKETVER_RE +// Client support for experimental RagexeRE UI present in 2012-04-10 and 2012-04-18 +#ifdef PACKETVER_RE +#if (PACKETVER == 20120410) || (PACKETVER == 20120418) + #define PARTY_RECRUIT +#endif +#endif + // Comment the following line to disable sc_data saving. [Skotlex] #define ENABLE_SC_SAVING diff --git a/src/config/const.h b/src/config/const.h index f4a2821f8..d8e397b1e 100644 --- a/src/config/const.h +++ b/src/config/const.h @@ -92,12 +92,7 @@ #else #define MAX_CARTS 5 #endif -/* Client Supports Party Recruit or Party Booking? */ -#ifdef PACKETVER_RE -#if (PACKETVER == 20120410) || (PACKETVER == 20120418) - #define PARTY_RECRUIT -#endif -#endif + // Renewal variable cast time reduction #ifdef RENEWAL_CAST #define VARCAST_REDUCTION(val){ \ diff --git a/src/map/atcommand.c b/src/map/atcommand.c index d9810e77c..b6a9e42ee 100644 --- a/src/map/atcommand.c +++ b/src/map/atcommand.c @@ -3718,10 +3718,33 @@ ACMD(reloadpcdb) *------------------------------------------*/ ACMD(reloadscript) { + struct s_mapiterator* iter; + struct map_session_data* pl_sd; + nullpo_retr(-1, sd); //atcommand_broadcast( fd, sd, "@broadcast", "Server is reloading scripts..." ); //atcommand_broadcast( fd, sd, "@broadcast", "You will feel a bit of lag at this point !" ); + iter = mapit_getallusers(); + for( pl_sd = (TBL_PC*)mapit->first(iter); mapit->exists(iter); pl_sd = (TBL_PC*)mapit->next(iter) ) { + if (pl_sd->npc_id || pl_sd->npc_shopid) { + if (pl_sd->state.using_fake_npc) { + clif->clearunit_single(pl_sd->npc_id, CLR_OUTSIGHT, pl_sd->fd); + pl_sd->state.using_fake_npc = 0; + } + if (pl_sd->state.menu_or_input) + pl_sd->state.menu_or_input = 0; + if (pl_sd->npc_menu) + pl_sd->npc_menu = 0; + + pl_sd->npc_id = 0; + pl_sd->npc_shopid = 0; + if (pl_sd->st && pl_sd->st->state != END) + pl_sd->st->state = END; + } + } + mapit->free(iter); + flush_fifos(); iMap->reloadnpc(true); // reload config files seeking for npcs script_reload(); @@ -6397,7 +6420,7 @@ ACMD(trade) return false; } - trade_traderequest(sd, pl_sd); + trade->request(sd, pl_sd); return true; } @@ -6601,7 +6624,7 @@ ACMD(misceffect) { ACMD(mail) { nullpo_ret(sd); - mail_openmail(sd); + mail->openmail(sd); return true; } diff --git a/src/map/battle.c b/src/map/battle.c index 31fe502f6..ace947aca 100644 --- a/src/map/battle.c +++ b/src/map/battle.c @@ -753,8 +753,8 @@ int battle_calc_masteryfix(struct block_list *src, struct block_list *target, ui int ratio = sd->status.base_level + status_get_dex(src) + status_get_luk(src); if ( i == 2 ) ratio += status_get_str(src); //Star Anger if (skill < 4 ) - ratio /= 12 - 3 * skill; - damage += damage * ratio; + ratio /= (12 - 3 * skill); + damage += damage * ratio / 100; } if( sc ){ @@ -4345,15 +4345,11 @@ struct Damage battle_calc_weapon_attack(struct block_list *src,struct block_list wd.damage = sstatus->max_hp* 9/100; wd.damage2 = 0; break; - -#ifdef RENEWAL - case MO_EXTREMITYFIST: // [malufett] - wd.damage = battle->calc_base_damage(src, target, skill_id, skill_lv, nk, n_ele, s_ele, s_ele_, EQI_HAND_R, (sc && sc->data[SC_MAXIMIZEPOWER]?1:0)|8, wd.flag); - // first value is still not confirm. - wd.damage = status_get_sp(src) + 10 * status_get_sp(src) * wd.damage / 100 + 8 * wd.damage; - flag.tdef = 1; - break; case NJ_ISSEN: // [malufett] +#ifndef RENEWAL + wd.damage = 40*sstatus->str +skill_lv*(sstatus->hp/10 + 35); + wd.damage2 = 0; +#else { short totaldef = status_get_total_def(target); i = 0; @@ -4367,12 +4363,14 @@ struct Damage battle_calc_weapon_attack(struct block_list *src,struct block_list ATK_RATE(50); flag.idef = 1; } -#else - - wd.damage = 40*sstatus->str +skill_lv*(sstatus->hp/10 + 35); - wd.damage2 = 0; -#endif break; + case MO_EXTREMITYFIST: // [malufett] + wd.damage = battle->calc_base_damage(src, target, skill_id, skill_lv, nk, n_ele, s_ele, s_ele_, EQI_HAND_R, (sc && sc->data[SC_MAXIMIZEPOWER]?1:0)|8, wd.flag); + // first value is still not confirm. + wd.damage = status_get_sp(src) + 10 * status_get_sp(src) * wd.damage / 100 + 8 * wd.damage; + flag.tdef = 1; +#endif + break; #ifndef RENEWAL case LK_SPIRALPIERCE: case ML_SPIRALPIERCE: diff --git a/src/map/clif.c b/src/map/clif.c index 2feb6f4bf..73d4b6666 100644 --- a/src/map/clif.c +++ b/src/map/clif.c @@ -5964,12 +5964,13 @@ void clif_wis_message(int fd, const char* nick, const char* mes, int mes_len) safestrncpy((char*)WFIFOP(fd,28), mes, mes_len); WFIFOSET(fd,WFIFOW(fd,2)); #else + struct map_session_data *ssd = iMap->nick2sd(nick); + WFIFOHEAD(fd, mes_len + NAME_LENGTH + 8); WFIFOW(fd,0) = 0x97; WFIFOW(fd,2) = mes_len + NAME_LENGTH + 8; safestrncpy((char*)WFIFOP(fd,4), nick, NAME_LENGTH); - WFIFOL(fd,28) = 0; // isAdmin; if nonzero, also displays text above char - // TODO: WFIFOL(fd,28) = pc->get_group_level(ssd); + WFIFOL(fd,28) = (pc->get_group_level(ssd) == 99) ? 1 : 0; // isAdmin; if nonzero, also displays text above char safestrncpy((char*)WFIFOP(fd,32), mes, mes_len); WFIFOSET(fd,WFIFOW(fd,2)); #endif @@ -8560,7 +8561,7 @@ void clif_refresh(struct map_session_data *sd) // unlike vending, resuming buyingstore crashes the client. buyingstore->close(sd); - mail_clear(sd); + mail->clear(sd); if( disguised(&sd->bl) ) {/* refresh-da */ short disguise = sd->disguise; @@ -9601,7 +9602,7 @@ void clif_parse_LoadEndAck(int fd,struct map_session_data *sd) } } - mail_clear(sd); + mail->clear(sd); clif->maptypeproperty2(&sd->bl,SELF); @@ -9756,7 +9757,7 @@ void clif_parse_progressbar(int fd, struct map_session_data * sd) if( iTimer->gettick() < sd->progressbar.timeout && sd->st ) sd->st->state = END; - sd->progressbar.npc_id = sd->progressbar.timeout = 0; + sd->state.workinprogress = sd->progressbar.npc_id = sd->progressbar.timeout = 0; npc_scriptcont(sd, npc_id, false); } @@ -9776,8 +9777,8 @@ void clif_parse_WalkToXY(int fd, struct map_session_data *sd) if (sd->sc.opt1 && ( sd->sc.opt1 == OPT1_STONEWAIT || sd->sc.opt1 == OPT1_BURNING )) ; //You CAN walk on this OPT1 value. - else if( sd->progressbar.npc_id ) - clif->progressbar_abort(sd); + /*else if( sd->progressbar.npc_id ) + clif->progressbar_abort(sd);*/ else if (pc_cant_act(sd)) return; @@ -10572,7 +10573,7 @@ void clif_parse_DropItem(int fd, struct map_session_data *sd) if (pc_isdead(sd)) break; - if ( pc_cant_act2(sd) ) + if ( pc_cant_act2(sd) || sd->state.vending ) break; if (sd->sc.count && ( @@ -10794,7 +10795,7 @@ void clif_parse_NpcClicked(int fd,struct map_session_data *sd) #endif return; } - if ( pc_cant_act2(sd) || !(bl = iMap->id2bl(RFIFOL(fd,2))) ) + if ( pc_cant_act2(sd) || !(bl = iMap->id2bl(RFIFOL(fd,2))) || sd->state.vending ) return; switch (bl->type) { @@ -11041,7 +11042,7 @@ void clif_parse_TradeRequest(int fd,struct map_session_data *sd) return; } - trade_traderequest(sd,t_sd); + trade->request(sd,t_sd); } @@ -11052,7 +11053,7 @@ void clif_parse_TradeRequest(int fd,struct map_session_data *sd) /// 4 = rejected void clif_parse_TradeAck(int fd,struct map_session_data *sd) { - trade_tradeack(sd,RFIFOB(fd,2)); + trade->ack(sd,RFIFOB(fd,2)); } @@ -11064,9 +11065,9 @@ void clif_parse_TradeAddItem(int fd,struct map_session_data *sd) int amount = RFIFOL(fd,4); if( index == 0 ) - trade_tradeaddzeny(sd, amount); + trade->addzeny(sd, amount); else - trade_tradeadditem(sd, index, (short)amount); + trade->additem(sd, index, (short)amount); } @@ -11074,7 +11075,7 @@ void clif_parse_TradeAddItem(int fd,struct map_session_data *sd) /// 00eb void clif_parse_TradeOk(int fd,struct map_session_data *sd) { - trade_tradeok(sd); + trade->ok(sd); } @@ -11082,7 +11083,7 @@ void clif_parse_TradeOk(int fd,struct map_session_data *sd) /// 00ed void clif_parse_TradeCancel(int fd,struct map_session_data *sd) { - trade_tradecancel(sd); + trade->cancel(sd); } @@ -11090,7 +11091,7 @@ void clif_parse_TradeCancel(int fd,struct map_session_data *sd) /// 00ef void clif_parse_TradeCommit(int fd,struct map_session_data *sd) { - trade_tradecommit(sd); + trade->commit(sd); } @@ -14471,8 +14472,8 @@ void clif_parse_Mail_refreshinbox(int fd, struct map_session_data *sd) else clif->mail_refreshinbox(sd); - mail_removeitem(sd, 0); - mail_removezeny(sd, 0); + mail->removeitem(sd, 0); + mail->removezeny(sd, 0); } @@ -14546,7 +14547,7 @@ void clif_parse_Mail_read(int fd, struct map_session_data *sd) if( mail_id <= 0 ) return; - if( mail_invalid_operation(sd) ) + if( mail->invalid_operation(sd) ) return; clif->mail_read(sd, RFIFOL(fd,2)); @@ -14565,7 +14566,7 @@ void clif_parse_Mail_getattach(int fd, struct map_session_data *sd) return; if( mail_id <= 0 ) return; - if( mail_invalid_operation(sd) ) + if( mail->invalid_operation(sd) ) return; ARR_FIND(0, MAIL_MAX_INBOX, i, sd->mail.inbox.msg[i].id == mail_id); @@ -14626,7 +14627,7 @@ void clif_parse_Mail_delete(int fd, struct map_session_data *sd) return; if( mail_id <= 0 ) return; - if( mail_invalid_operation(sd) ) + if( mail->invalid_operation(sd) ) return; ARR_FIND(0, MAIL_MAX_INBOX, i, sd->mail.inbox.msg[i].id == mail_id); @@ -14652,7 +14653,7 @@ void clif_parse_Mail_return(int fd, struct map_session_data *sd) if( mail_id <= 0 ) return; - if( mail_invalid_operation(sd) ) + if( mail->invalid_operation(sd) ) return; ARR_FIND(0, MAIL_MAX_INBOX, i, sd->mail.inbox.msg[i].id == mail_id); @@ -14676,7 +14677,7 @@ void clif_parse_Mail_setattach(int fd, struct map_session_data *sd) if (idx < 0 || amount < 0) return; - flag = mail_setitem(sd, idx, amount); + flag = mail->setitem(sd, idx, amount); clif->mail_setattachment(fd,idx,flag); } @@ -14692,9 +14693,9 @@ void clif_parse_Mail_winopen(int fd, struct map_session_data *sd) int flag = RFIFOW(fd,2); if (flag == 0 || flag == 1) - mail_removeitem(sd, 0); + mail->removeitem(sd, 0); if (flag == 0 || flag == 2) - mail_removezeny(sd, 0); + mail->removezeny(sd, 0); } @@ -14726,10 +14727,10 @@ void clif_parse_Mail_send(int fd, struct map_session_data *sd) if (body_len > MAIL_BODY_LENGTH) body_len = MAIL_BODY_LENGTH; - if( !mail_setattachment(sd, &msg) ) { // Invalid Append condition + if( !mail->setattachment(sd, &msg) ) { // Invalid Append condition clif->mail_send(sd->fd, true); // fail - mail_removeitem(sd,0); - mail_removezeny(sd,0); + mail->removeitem(sd,0); + mail->removezeny(sd,0); return; } @@ -14751,7 +14752,7 @@ void clif_parse_Mail_send(int fd, struct map_session_data *sd) msg.timestamp = time(NULL); if( !intif_Mail_send(sd->status.account_id, &msg) ) - mail_deliveryfail(sd, &msg); + mail->deliveryfail(sd, &msg); sd->cansendmail_tick = iTimer->gettick() + 1000; // 1 Second flood Protection } diff --git a/src/map/intif.c b/src/map/intif.c index 3cdf93487..f3931e79e 100644 --- a/src/map/intif.c +++ b/src/map/intif.c @@ -1582,7 +1582,7 @@ int intif_parse_Mail_getattach(int fd) memcpy(&item, RFIFOP(fd,12), sizeof(struct item)); - mail_getattachment(sd, zeny, &item); + mail->getattachment(sd, zeny, &item); return 0; } /*------------------------------------------ @@ -1718,7 +1718,7 @@ static void intif_parse_Mail_send(int fd) if( sd != NULL ) { if( fail ) - mail_deliveryfail(sd, &msg); + mail->deliveryfail(sd, &msg); else { clif->mail_send(sd->fd, false); diff --git a/src/map/mail.c b/src/map/mail.c index 299fb5117..9a8d4e521 100644 --- a/src/map/mail.c +++ b/src/map/mail.c @@ -1,5 +1,6 @@ -// Copyright (c) Athena Dev Teams - Licensed under GNU GPL -// For more information, see LICENCE in the main folder +// Copyright (c) Hercules Dev Team, licensed under GNU GPL. +// See the LICENSE file +// Portions Copyright (c) Athena Dev Teams #include "../common/nullpo.h" #include "../common/showmsg.h" @@ -72,7 +73,7 @@ unsigned char mail_setitem(struct map_session_data *sd, int idx, int amount) { return 0; } else { // Item Transfer idx -= 2; - mail_removeitem(sd, 0); + mail->removeitem(sd, 0); if( idx < 0 || idx >= MAX_INVENTORY ) return 1; @@ -121,8 +122,8 @@ bool mail_setattachment(struct map_session_data *sd, struct mail_message *msg) msg->zeny = sd->mail.zeny; // Removes the attachment from sender - mail_removeitem(sd,1); - mail_removezeny(sd,1); + mail->removeitem(sd,1); + mail->removezeny(sd,1); return true; } @@ -183,3 +184,18 @@ bool mail_invalid_operation(struct map_session_data *sd) return false; } + +void mail_defaults(void) +{ + mail = &mail_s; + + mail->clear = mail_clear; + mail->removeitem = mail_removeitem; + mail->removezeny = mail_removezeny; + mail->setitem = mail_setitem; + mail->setattachment = mail_setattachment; + mail->getattachment = mail_getattachment; + mail->openmail = mail_openmail; + mail->deliveryfail = mail_deliveryfail; + mail->invalid_operation = mail_invalid_operation; +}
\ No newline at end of file diff --git a/src/map/mail.h b/src/map/mail.h index cab582e55..99742c7bd 100644 --- a/src/map/mail.h +++ b/src/map/mail.h @@ -1,19 +1,26 @@ -// Copyright (c) Athena Dev Teams - Licensed under GNU GPL -// For more information, see LICENCE in the main folder +// Copyright (c) Hercules Dev Team, licensed under GNU GPL. +// See the LICENSE file +// Portions Copyright (c) Athena Dev Teams #ifndef _MAIL_H_ #define _MAIL_H_ #include "../common/mmo.h" -void mail_clear(struct map_session_data *sd); -int mail_removeitem(struct map_session_data *sd, short flag); -int mail_removezeny(struct map_session_data *sd, short flag); -unsigned char mail_setitem(struct map_session_data *sd, int idx, int amount); -bool mail_setattachment(struct map_session_data *sd, struct mail_message *msg); -void mail_getattachment(struct map_session_data* sd, int zeny, struct item* item); -int mail_openmail(struct map_session_data *sd); -void mail_deliveryfail(struct map_session_data *sd, struct mail_message *msg); -bool mail_invalid_operation(struct map_session_data *sd); +struct mail_interface { + void (*clear) (struct map_session_data *sd); + int (*removeitem) (struct map_session_data *sd, short flag); + int (*removezeny) (struct map_session_data *sd, short flag); + unsigned char (*setitem) (struct map_session_data *sd, int idx, int amount); + bool (*setattachment) (struct map_session_data *sd, struct mail_message *msg); + void (*getattachment) (struct map_session_data* sd, int zeny, struct item* item); + int (*openmail) (struct map_session_data *sd); + void (*deliveryfail) (struct map_session_data *sd, struct mail_message *msg); + bool (*invalid_operation) (struct map_session_data *sd); +} mail_s; + +struct mail_interface *mail; + +void mail_defaults(void); #endif /* _MAIL_H_ */ diff --git a/src/map/map.c b/src/map/map.c index 5dbedebb6..5f86286e9 100644 --- a/src/map/map.c +++ b/src/map/map.c @@ -5239,12 +5239,14 @@ void map_hp_symbols(void) { HPM->share(ircbot,"ircbot"); HPM->share(itemdb,"itemdb"); HPM->share(logs,"logs"); + HPM->share(mail,"mail"); HPM->share(script,"script"); HPM->share(searchstore,"searchstore"); HPM->share(skill,"skill"); HPM->share(vending,"vending"); HPM->share(pc,"pc"); HPM->share(party,"party"); + HPM->share(trade,"trade"); HPM->share(iMap,"iMap"); /* partial */ HPM->share(mapit,"mapit"); @@ -5269,6 +5271,7 @@ void load_defaults(void) { ircbot_defaults(); itemdb_defaults(); log_defaults(); + mail_defaults(); npc_defaults(); script_defaults(); searchstore_defaults(); @@ -5276,6 +5279,7 @@ void load_defaults(void) { vending_defaults(); pc_defaults(); party_defaults(); + trade_defaults(); } int do_init(int argc, char *argv[]) { diff --git a/src/map/npc.c b/src/map/npc.c index f4027096c..46e6d0fd2 100644 --- a/src/map/npc.c +++ b/src/map/npc.c @@ -1867,6 +1867,7 @@ int npc_unload(struct npc_data* nd, bool single) { aFree(nd->u.scr.timer_event); if (nd->src_id == 0) { if(nd->u.scr.script) { + script_stop_instances(nd->bl.id); script_free_code(nd->u.scr.script); nd->u.scr.script = NULL; } @@ -1885,8 +1886,6 @@ int npc_unload(struct npc_data* nd, bool single) { nd->ud = NULL; } - script_stop_sleeptimers(nd->bl.id); - aFree(nd); return 0; diff --git a/src/map/pc.c b/src/map/pc.c index 155812836..b7644f2fb 100644 --- a/src/map/pc.c +++ b/src/map/pc.c @@ -4255,7 +4255,7 @@ int pc_useitem(struct map_session_data *sd,int n) nullpo_ret(sd); - if( sd->npc_id ){ + if( sd->npc_id || sd->state.workinprogress&1 ){ /* TODO: add to clif->messages enum */ #ifdef RENEWAL clif->msg(sd, 0x783); // TODO look for the client date that has this message. @@ -4295,8 +4295,8 @@ int pc_useitem(struct map_session_data *sd,int n) return 0; /* Items with delayed consume are not meant to work while in mounts except reins of mount(12622) */ - if( sd->inventory_data[n]->flag.delay_consume ) { - if( nameid != ITEMID_REINS_OF_MOUNT && sd->sc.data[SC_ALL_RIDING] ) + if( sd->inventory_data[n]->flag.delay_consume && nameid != ITEMID_REINS_OF_MOUNT ) { + if( sd->sc.data[SC_ALL_RIDING] ) return 0; else if( pc_issit(sd) ) return 0; @@ -4323,7 +4323,8 @@ int pc_useitem(struct map_session_data *sd,int n) } else {// not yet used item (all slots are initially empty) sd->item_delay[i].nameid = nameid; } - sd->item_delay[i].tick = tick + sd->inventory_data[n]->delay; + if( !(nameid == ITEMID_REINS_OF_MOUNT && sd->sc.option&(OPTION_WUGRIDER|OPTION_RIDING|OPTION_DRAGON|OPTION_MADOGEAR)) ) + sd->item_delay[i].tick = tick + sd->inventory_data[n]->delay; } else {// should not happen ShowError("pc_useitem: Exceeded item delay array capacity! (nameid=%d, char_id=%d)\n", nameid, sd->status.char_id); } @@ -6667,7 +6668,7 @@ int pc_dead(struct map_session_data *sd,struct block_list *src) { npc_script_event(sd,NPCE_DIE); // Clear anything NPC-related when you die and was interacting with one. - if (sd->npc_id) { + if (sd->npc_id || sd->npc_shopid) { if (sd->state.using_fake_npc) { clif->clearunit_single(sd->npc_id, CLR_OUTSIGHT, sd->fd); sd->state.using_fake_npc = 0; @@ -6678,6 +6679,7 @@ int pc_dead(struct map_session_data *sd,struct block_list *src) { sd->npc_menu = 0; sd->npc_id = 0; + sd->npc_shopid = 0; if (sd->st && sd->st->state != END) sd->st->state = END; } diff --git a/src/map/pc.h b/src/map/pc.h index 5c585af1c..43d5d40c7 100644 --- a/src/map/pc.h +++ b/src/map/pc.h @@ -603,7 +603,7 @@ enum equip_pos { #define pc_cant_act(sd) ( (sd)->npc_id || (sd)->state.vending || (sd)->state.buyingstore || (sd)->chatID || ((sd)->sc.opt1 && (sd)->sc.opt1 != OPT1_BURNING) || (sd)->state.trading || (sd)->state.storage_flag || (sd)->state.prevend ) /* equals pc_cant_act except it doesn't check for chat rooms */ -#define pc_cant_act2(sd) ( (sd)->npc_id || (sd)->state.vending || (sd)->state.buyingstore || ((sd)->sc.opt1 && (sd)->sc.opt1 != OPT1_BURNING) || (sd)->state.trading || (sd)->state.storage_flag || (sd)->state.prevend ) +#define pc_cant_act2(sd) ( (sd)->npc_id || (sd)->state.buyingstore || ((sd)->sc.opt1 && (sd)->sc.opt1 != OPT1_BURNING) || (sd)->state.trading || (sd)->state.storage_flag || (sd)->state.prevend ) #define pc_setdir(sd,b,h) ( (sd)->ud.dir = (b) ,(sd)->head_dir = (h) ) #define pc_setchatid(sd,n) ( (sd)->chatID = n ) diff --git a/src/map/script.c b/src/map/script.c index f3bf2470a..682faa42b 100644 --- a/src/map/script.c +++ b/src/map/script.c @@ -181,8 +181,6 @@ int potion_target=0; c_op get_com(unsigned char *script,int *pos); int get_num(unsigned char *script,int *pos); -static struct linkdb_node* sleep_db;// int oid -> struct script_state* - /*========================================== * (Only those needed) local declaration prototype *------------------------------------------*/ @@ -2746,19 +2744,18 @@ void script_free_code(struct script_code* code) /// @param rid Who is running the script (attached player) /// @param oid Where the code is being run (npc 'object') /// @return Script state -struct script_state* script_alloc_state(struct script_code* script, int pos, int rid, int oid) -{ +struct script_state* script_alloc_state(struct script_code* rootscript, int pos, int rid, int oid) { struct script_state* st; - CREATE(st, struct script_state, 1); - st->stack = (struct script_stack*)aMalloc(sizeof(struct script_stack)); + + st = ers_alloc(script->st_ers, struct script_state); + st->stack = ers_alloc(script->stack_ers, struct script_stack); st->stack->sp = 0; st->stack->sp_max = 64; CREATE(st->stack->stack_data, struct script_data, st->stack->sp_max); st->stack->defsp = st->stack->sp; st->stack->var_function = idb_alloc(DB_OPT_RELEASE_DATA); st->state = RUN; - st->script = script; - //st->scriptroot = script; + st->script = rootscript; st->pos = pos; st->rid = rid; st->oid = oid; @@ -2768,6 +2765,11 @@ struct script_state* script_alloc_state(struct script_code* script, int pos, int if( !st->script->script_vars ) st->script->script_vars = idb_alloc(DB_OPT_RELEASE_DATA); + st->id = script->next_id++; + script->active_scripts++; + + idb_put(script->st_db, st->id, st); + return st; } @@ -2785,14 +2787,18 @@ void script_free_state(struct script_state* st) script_free_vars(st->stack->var_function); script->pop_stack(st, 0, st->stack->sp); aFree(st->stack->stack_data); - aFree(st->stack); + ers_free(script->stack_ers, st->stack); if( st->script && st->script->script_vars && !db_size(st->script->script_vars) ) { script_free_vars(st->script->script_vars); st->script->script_vars = NULL; } st->stack = NULL; st->pos = -1; - aFree(st); + idb_remove(script->st_db, st->id); + ers_free(script->st_ers, st); + if( --script->active_scripts == 0 ) { + script->next_id = 0; + } } // @@ -3270,60 +3276,36 @@ void run_script(struct script_code *rootscript,int pos,int rid,int oid) { run_script_main(st); } -void script_stop_sleeptimers(int id) -{ +void script_stop_instances(int id) { + DBIterator *iter; struct script_state* st; - for(;;) - { - st = (struct script_state*)linkdb_erase(&sleep_db,(void*)__64BPTRSIZE(id)); - if( st == NULL ) - break; // no more sleep timers - script_free_state(st); + + if( !script->active_scripts ) + return;//dont even bother. + + iter = db_iterator(script->st_db); + + for( st = dbi_first(iter); dbi_exists(iter); st = dbi_next(iter) ) { + if( st->oid == id ) { + script_free_state(st); + } } -} - -/*========================================== - * Delete the specified node from sleep_db - *------------------------------------------*/ -struct linkdb_node* script_erase_sleepdb(struct linkdb_node *n) -{ - struct linkdb_node *retnode; - - if( n == NULL) - return NULL; - if( n->prev == NULL ) - sleep_db = n->next; - else - n->prev->next = n->next; - if( n->next ) - n->next->prev = n->prev; - retnode = n->next; - aFree( n ); - return retnode; // The following; return retnode + + dbi_destroy(iter); } /*========================================== * Timer function for sleep *------------------------------------------*/ -int run_script_timer(int tid, unsigned int tick, int id, intptr_t data) -{ +int run_script_timer(int tid, unsigned int tick, int id, intptr_t data) { struct script_state *st = (struct script_state *)data; - struct linkdb_node *node = (struct linkdb_node *)sleep_db; TBL_PC *sd = iMap->id2sd(st->rid); - if((sd && sd->status.char_id != id) || (st->rid && !sd)) - { //Character mismatch. Cancel execution. + if((sd && sd->status.char_id != id) || (st->rid && !sd)) { //Character mismatch. Cancel execution. st->rid = 0; st->state = END; } - while( node && st->sleep.timer != INVALID_TIMER ) { - if( (int)__64BPTRSIZE(node->key) == st->oid && ((struct script_state *)node->data)->sleep.timer == st->sleep.timer ) { - script_erase_sleepdb(node); - st->sleep.timer = INVALID_TIMER; - break; - } - node = node->next; - } + st->sleep.timer = INVALID_TIMER; if(st->state != RERUNLINE) st->sleep.tick = 0; run_script_main(st); @@ -3523,9 +3505,7 @@ void run_script_main(struct script_state *st) st->sleep.charid = sd?sd->status.char_id:0; st->sleep.timer = iTimer->add_timer(iTimer->gettick()+st->sleep.tick, run_script_timer, st->sleep.charid, (intptr_t)st); - linkdb_insert(&sleep_db, (void*)__64BPTRSIZE(st->oid), st); - } - else if(st->state != END && st->rid){ + } else if(st->state != END && st->rid){ //Resume later (st is already attached to player). if(st->bk_st) { ShowWarning("Unable to restore stack! Double continuation!\n"); @@ -3711,6 +3691,9 @@ void script_setarray_pc(struct map_session_data* sd, const char* varname, uint8 *------------------------------------------*/ void do_final_script(void) { int i; + DBIterator *iter; + struct script_state *st; + #ifdef DEBUG_HASH if (battle_config.etc_log) { @@ -3771,16 +3754,15 @@ void do_final_script(void) { db_destroy(scriptlabel_db); userfunc_db->destroy(userfunc_db, db_script_free_code_sub); autobonus_db->destroy(autobonus_db, db_script_free_code_sub); - if(sleep_db) { - struct linkdb_node *n = (struct linkdb_node *)sleep_db; - while(n) { - struct script_state *st = (struct script_state *)n->data; - script_free_state(st); - n = n->next; - } - linkdb_final(&sleep_db); - } + iter = db_iterator(script->st_db); + + for( st = dbi_first(iter); dbi_exists(iter); st = dbi_next(iter) ) { + script_free_state(st); + } + + dbi_destroy(iter); + if (script->str_data) aFree(script->str_data); if (script->str_buf) @@ -3820,14 +3802,27 @@ void do_final_script(void) { aFree(script->hqi); if( script->word_buf != NULL ) aFree(script->word_buf); + + ers_destroy(script->st_ers); + ers_destroy(script->stack_ers); + + db_destroy(script->st_db); } /*========================================== * Initialization *------------------------------------------*/ void do_init_script(void) { + script->st_db = idb_alloc(DB_OPT_BASE); userfunc_db = strdb_alloc(DB_OPT_DUP_KEY,0); scriptlabel_db = strdb_alloc(DB_OPT_DUP_KEY,50); autobonus_db = strdb_alloc(DB_OPT_DUP_KEY,0); + + script->st_ers = ers_new(sizeof(struct script_state), "script.c::st_ers", ERS_OPT_NONE); + script->stack_ers = ers_new(sizeof(struct script_stack), "script.c::script_stack", ERS_OPT_NONE); + + ers_chunk_size(script->st_ers, 10); + ers_chunk_size(script->stack_ers, 10); + script->parse_builtin(); read_constdb(); mapreg_init(); @@ -3835,6 +3830,8 @@ void do_init_script(void) { int script_reload() { int i; + DBIterator *iter; + struct script_state *st; userfunc_db->clear(userfunc_db, db_script_free_code_sub); db_clear(scriptlabel_db); @@ -3848,15 +3845,16 @@ int script_reload() { atcommand->binding_count = 0; - if(sleep_db) { - struct linkdb_node *n = (struct linkdb_node *)sleep_db; - while(n) { - struct script_state *st = (struct script_state *)n->data; - script_free_state(st); - n = n->next; - } - linkdb_final(&sleep_db); + iter = db_iterator(script->st_db); + + for( st = dbi_first(iter); dbi_exists(iter); st = dbi_next(iter) ) { + script_free_state(st); } + + dbi_destroy(iter); + + db_clear(script->st_db); + mapreg_reload(); return 0; } @@ -7225,6 +7223,9 @@ BUILDIN(successrefitem) //Logs items, got from (N)PC scripts [Lupus] logs->pick_pc(sd, LOG_TYPE_SCRIPT, -1, &sd->status.inventory[i],sd->inventory_data[i]); + if (sd->status.inventory[i].refine >= MAX_REFINE) + return true; + sd->status.inventory[i].refine++; pc->unequipitem(sd,i,2); // status calc will happen in pc->equipitem() below @@ -15134,47 +15135,41 @@ BUILDIN(sleep2) /// Awakes all the sleep timers of the target npc /// /// awake "<npc name>"; -BUILDIN(awake) -{ +BUILDIN(awake) { + DBIterator *iter; + struct script_state *tst; struct npc_data* nd; - struct linkdb_node *node = (struct linkdb_node *)sleep_db; - nd = npc_name2id(script_getstr(st, 2)); - if( nd == NULL ) { + if( ( nd = npc_name2id(script_getstr(st, 2)) ) == NULL ) { ShowError("awake: NPC \"%s\" not found\n", script_getstr(st, 2)); return false; } - while( node ) - { - if( (int)__64BPTRSIZE(node->key) == nd->bl.id ) - {// sleep timer for the npc - struct script_state* tst = (struct script_state*)node->data; + iter = db_iterator(script->st_db); + + for( tst = dbi_first(iter); dbi_exists(iter); tst = dbi_next(iter) ) { + if( tst->oid == nd->bl.id ) { TBL_PC* sd = iMap->id2sd(tst->rid); - if( tst->sleep.timer == INVALID_TIMER ) - {// already awake ??? - node = node->next; + if( tst->sleep.timer == INVALID_TIMER ) {// already awake ??? continue; } - if( (sd && sd->status.char_id != tst->sleep.charid) || (tst->rid && !sd)) - {// char not online anymore / another char of the same account is online - Cancel execution + if( (sd && sd->status.char_id != tst->sleep.charid) || (tst->rid && !sd)) { + // char not online anymore / another char of the same account is online - Cancel execution tst->state = END; tst->rid = 0; } iTimer->delete_timer(tst->sleep.timer, run_script_timer); - node = script_erase_sleepdb(node); tst->sleep.timer = INVALID_TIMER; if(tst->state != RERUNLINE) tst->sleep.tick = 0; run_script_main(tst); } - else - { - node = node->next; - } } + + dbi_destroy(iter); + return true; } @@ -15271,7 +15266,7 @@ BUILDIN(openmail) if( sd == NULL ) return true; - mail_openmail(sd); + mail->openmail(sd); return true; } @@ -16317,6 +16312,7 @@ BUILDIN(progressbar) sd->progressbar.npc_id = st->oid; sd->progressbar.timeout = iTimer->gettick() + second*1000; + sd->state.workinprogress = 3; clif->progressbar(sd, strtol(color, (char **)NULL, 0), second); return true; @@ -16525,9 +16521,10 @@ BUILDIN(setmounting) { TBL_PC* sd; if( (sd = script_rid2sd(st)) == NULL ) return true; - if( sd->sc.option&(OPTION_WUGRIDER|OPTION_RIDING|OPTION_DRAGON|OPTION_MADOGEAR) ) + if( sd->sc.option&(OPTION_WUGRIDER|OPTION_RIDING|OPTION_DRAGON|OPTION_MADOGEAR) ){ + clif->msgtable(sd->fd, 0X78b); script_pushint(st,0);//can't mount with one of these - else { + }else { if( sd->sc.data[SC_ALL_RIDING] ) status_change_end(&sd->bl, SC_ALL_RIDING, INVALID_TIMER); else @@ -17840,6 +17837,12 @@ void script_parse_builtin(void) { void script_defaults(void) { script = &script_s; + script->st_db = NULL; + script->active_scripts = 0; + script->next_id = 0; + script->st_ers = NULL; + script->stack_ers = NULL; + script->hq = NULL; script->hqi = NULL; script->hqs = script->hqis = 0; diff --git a/src/map/script.h b/src/map/script.h index 92a083556..3cfcd9de4 100644 --- a/src/map/script.h +++ b/src/map/script.h @@ -9,6 +9,7 @@ #define NUM_WHISPER_VAR 10 struct map_session_data; +struct eri; extern int potion_flag; //For use on Alchemist improved potions/Potion Pitcher. [Skotlex] extern int potion_hp, potion_per_hp, potion_sp, potion_per_sp; @@ -160,6 +161,7 @@ struct script_state { unsigned freeloop : 1;// used by buildin_freeloop unsigned op2ref : 1;// used by op_2 unsigned npc_item_flag : 1; + unsigned int id; }; struct script_reg { @@ -189,11 +191,11 @@ int set_var(struct map_session_data *sd, char *name, void *val); int run_script_timer(int tid, unsigned int tick, int id, intptr_t data); void run_script_main(struct script_state *st); -void script_stop_sleeptimers(int id); +void script_stop_instances(int id); struct linkdb_node* script_erase_sleepdb(struct linkdb_node *n); void script_free_code(struct script_code* code); void script_free_vars(struct DBMap *storage); -struct script_state* script_alloc_state(struct script_code* script, int pos, int rid, int oid); +struct script_state* script_alloc_state(struct script_code* rootscript, int pos, int rid, int oid); void script_free_state(struct script_state* st); struct DBMap* script_get_label_db(void); @@ -334,6 +336,12 @@ struct str_data_struct { /* script.c interface (incomplete) */ struct script_interface { /* */ + DBMap *st_db; + unsigned int active_scripts; + unsigned int next_id; + struct eri *st_ers; + struct eri *stack_ers; + /* */ struct hQueue *hq; struct hQueueIterator *hqi; int hqs, hqis; diff --git a/src/map/skill.c b/src/map/skill.c index 5a10038d8..685fec353 100644 --- a/src/map/skill.c +++ b/src/map/skill.c @@ -2395,6 +2395,10 @@ int skill_attack (int attack_type, struct block_list* src, struct block_list *ds //Can't attack nor use items until skill's delay expires. [Skotlex] sd->ud.attackabletime = sd->canuseitem_tick = sd->ud.canact_tick; break; + case TK_DODGE: + if( pc->checkskill(sd, TK_JUMPKICK) > 0 ) + flag = 1; + break; case SR_DRAGONCOMBO: if( pc->checkskill(sd, SR_FALLENEMPIRE) > 0 ) flag = 1; @@ -3761,7 +3765,7 @@ int skill_castend_damage_id (struct block_list* src, struct block_list *bl, uint int sflag = skill_area_temp[0] & 0xFFF, heal; if( flag&SD_LEVEL ) sflag |= SD_LEVEL; // -1 will be used in packets instead of the skill level - if( skill_area_temp[1] != bl->id && !(skill->get_inf2(skill_id)&INF2_NPC_SKILL) ) + if( (skill_area_temp[1] != bl->id && !(skill->get_inf2(skill_id)&INF2_NPC_SKILL)) || flag&SD_ANIMATION ) sflag |= SD_ANIMATION; // original target gets no animation (as well as all NPC skills) heal = skill->attack(skill->get_type(skill_id), src, src, bl, skill_id, skill_lv, tick, sflag); @@ -3776,6 +3780,8 @@ int skill_castend_damage_id (struct block_list* src, struct block_list *bl, uint case GN_CARTCANNON: clif->skill_nodamage(src,bl,skill_id,skill_lv,1); break; + case SR_TIGERCANNON: + flag |= SD_ANIMATION; case LG_MOONSLASHER: clif->skill_damage(src,bl,tick, status_get_amotion(src), 0, -30000, 1, skill_id, skill_lv, 6); break; @@ -7965,12 +7971,11 @@ int skill_castend_nodamage_id (struct block_list *src, struct block_list *bl, ui break; for(i = 0; i < SC_MAX; i++) { - if( SC_COMMON_MAX > i ){ - if ( !tsc->data[i] || !status_get_sc_type(i) ) - continue; + if ( !tsc->data[i] ) + continue; + if( SC_COMMON_MAX > i ) if ( status_get_sc_type(i)&SC_NO_CLEARANCE ) continue; - } switch (i) { case SC_ASSUMPTIO: if( bl->type == BL_MOB ) @@ -8551,7 +8556,7 @@ int skill_castend_nodamage_id (struct block_list *src, struct block_list *bl, ui case SR_FLASHCOMBO: clif->skill_nodamage(src,bl,skill_id,skill_lv,1); for(i = SR_FLASHCOMBO_ATK_STEP1; i <= SR_FLASHCOMBO_ATK_STEP4; i++) - skill->addtimerskill(src, tick + 600 * (i - SR_FLASHCOMBO_ATK_STEP1), bl->id, 0, 0, i, skill_lv, BF_WEAPON, flag|SD_LEVEL); + skill->addtimerskill(src, tick + 500 * (i - SR_FLASHCOMBO_ATK_STEP1), bl->id, 0, 0, i, skill_lv, BF_WEAPON, flag|SD_LEVEL); break; case WA_SWING_DANCE: case WA_MOONLIT_SERENADE: @@ -13101,12 +13106,14 @@ int skill_check_condition_castbegin(struct map_session_data* sd, uint16 skill_id case TK_STORMKICK: case TK_DOWNKICK: case TK_COUNTER: + case TK_JUMPKICK: case HT_POWER: case GC_COUNTERSLASH: case GC_WEAPONCRUSH: case SR_FALLENEMPIRE: case SR_DRAGONCOMBO: case SR_TIGERCANNON: + case SR_GATEOFHELL: break; default: return 0; } diff --git a/src/map/status.c b/src/map/status.c index 8363b8021..55b79fff7 100644 --- a/src/map/status.c +++ b/src/map/status.c @@ -915,6 +915,7 @@ void initChangeTables(void) { StatusIconChangeTable[SC_PUSH_CART] = SI_ON_PUSH_CART; StatusIconChangeTable[SC_REBOUND] = SI_REBOUND; StatusIconChangeTable[SC_ALL_RIDING] = SI_ALL_RIDING; + StatusIconChangeTable[SC_MONSTER_TRANSFORM] = SI_MONSTER_TRANSFORM; //Other SC which are not necessarily associated to skills. StatusChangeFlagTable[SC_ATTHASTE_POTION1] = SCB_ASPD; @@ -1022,6 +1023,7 @@ void initChangeTables(void) { StatusDisplayType[SC_BLOOD_SUCKER] = true; StatusDisplayType[SC__SHADOWFORM] = true; StatusDisplayType[SC__MANHOLE] = true; + StatusDisplayType[SC_MONSTER_TRANSFORM] = true; #ifdef RENEWAL_EDP // renewal EDP increases your weapon atk @@ -2500,7 +2502,7 @@ int status_calc_pc_(struct map_session_data* sd, bool first) #ifdef RENEWAL wa->matk += sd->inventory_data[index]->matk; wa->wlv = wlv; - if( r ) // renewal magic attack refine bonus + if( r && sd->weapontype1 != W_BOW ) // renewal magic attack refine bonus wa->matk += refine_info[wlv].bonus[r-1] / 100; #endif @@ -8327,10 +8329,10 @@ int status_change_start(struct block_list* bl,enum sc_type type,int rate,int val break; case SC_BLOOD_SUCKER: { - struct block_list *src = iMap->id2bl(sce->val2); + struct block_list *src = iMap->id2bl(val2); val3 = 1; if(src) - val3 = 200 + 100 * sce->val1 + status_get_int(src); + val3 = 200 + 100 * val1 + status_get_int(src); val4 = tick / 1000; tick_time = 1000; // [GodLesZ] tick time } @@ -8712,6 +8714,11 @@ int status_change_start(struct block_list* bl,enum sc_type type,int rate,int val tick_time = 10000; val4 = tick / tick_time; break; + case SC_MONSTER_TRANSFORM: + if( !mobdb_checkid(val1) ) + val1 = 1002; // default poring + val_flag |= 1; + break; default: if( calc_flag == SCB_NONE && StatusSkillChangeTable[type] == 0 && StatusIconChangeTable[type] == 0 ) { //Status change with no calc, no icon, and no skill associated...? @@ -8739,8 +8746,12 @@ int status_change_start(struct block_list* bl,enum sc_type type,int rate,int val case SC_SUMMON3: case SC_SUMMON4: case SC_SUMMON5: + case SC_MONSTER_TRANSFORM: val_flag |= 1; break; + case SC_KYOUGAKU: + clif->status_change(bl, SI_ACTIVE_MONSTER_TRANSFORM, 1, 0, 1002, 0, 0); // Poring in disguise + break; } } @@ -9646,7 +9657,6 @@ int status_change_end_(struct block_list* bl, enum sc_type type, int tid, const } break; case SC_KYOUGAKU: - clif->sc_end(&sd->bl,sd->bl.id,AREA,SI_KYOUGAKU); clif->sc_end(&sd->bl,sd->bl.id,AREA,SI_ACTIVE_MONSTER_TRANSFORM); break; case SC_CLAIRVOYANCE: diff --git a/src/map/status.h b/src/map/status.h index 617cd9572..fbce95f17 100644 --- a/src/map/status.h +++ b/src/map/status.h @@ -671,6 +671,8 @@ typedef enum sc_type { SC_ALL_RIDING, SC_HANBOK, + SC_MONSTER_TRANSFORM, + SC_MAX, //Automatically updated max, used in for's to check we are within bounds. } sc_type; diff --git a/src/map/trade.c b/src/map/trade.c index 8311dbf3d..f469f4b28 100644 --- a/src/map/trade.c +++ b/src/map/trade.c @@ -331,7 +331,7 @@ void trade_tradeadditem(struct map_session_data *sd, short index, short amount) if( (target_sd = iMap->id2sd(sd->trade_partner)) == NULL ) { - trade_tradecancel(sd); + trade->cancel(sd); return; } @@ -415,13 +415,13 @@ void trade_tradeaddzeny(struct map_session_data* sd, int amount) if( (target_sd = iMap->id2sd(sd->trade_partner)) == NULL ) { - trade_tradecancel(sd); + trade->cancel(sd); return; } if( amount < 0 || amount > sd->status.zeny || amount > MAX_ZENY - target_sd->status.zeny ) { // invalid values, no appropriate packet for it => abort - trade_tradecancel(sd); + trade->cancel(sd); return; } @@ -440,7 +440,7 @@ void trade_tradeok(struct map_session_data *sd) return; if ((target_sd = iMap->id2sd(sd->trade_partner)) == NULL) { - trade_tradecancel(sd); + trade->cancel(sd); return; } sd->state.deal_locked = 1; @@ -532,18 +532,18 @@ void trade_tradecommit(struct map_session_data *sd) //Now is a good time (to save on resources) to check that the trade can indeed be made and it's not exploitable. // check exploit (trade more items that you have) - if (impossible_trade_check(sd)) { - trade_tradecancel(sd); + if (trade->check_impossible(sd)) { + trade->cancel(sd); return; } // check exploit (trade more items that you have) - if (impossible_trade_check(tsd)) { - trade_tradecancel(tsd); + if (trade->check_impossible(tsd)) { + trade->cancel(tsd); return; } // check for full inventory (can not add traded items) - if (!trade_check(sd,tsd)) { // check the both players - trade_tradecancel(sd); + if (!trade->check(sd,tsd)) { // check the both players + trade->cancel(sd); return; } @@ -607,3 +607,18 @@ void trade_tradecommit(struct map_session_data *sd) chrif_save(tsd,0); } } + +void trade_defaults(void) +{ + trade = &trade_s; + + trade->request = trade_traderequest; + trade->ack = trade_tradeack; + trade->check_impossible = impossible_trade_check; + trade->check = trade_check; + trade->additem = trade_tradeadditem; + trade->addzeny = trade_tradeaddzeny; + trade->ok = trade_tradeok; + trade->cancel = trade_tradecancel; + trade->commit = trade_tradecommit; +}
\ No newline at end of file diff --git a/src/map/trade.h b/src/map/trade.h index 6bb39936e..f66c70525 100644 --- a/src/map/trade.h +++ b/src/map/trade.h @@ -7,12 +7,19 @@ //#include "map.h" struct map_session_data; -void trade_traderequest(struct map_session_data *sd, struct map_session_data *target_sd); -void trade_tradeack(struct map_session_data *sd,int type); -void trade_tradeadditem(struct map_session_data *sd,short index,short amount); -void trade_tradeaddzeny(struct map_session_data *sd,int amount); -void trade_tradeok(struct map_session_data *sd); -void trade_tradecancel(struct map_session_data *sd); -void trade_tradecommit(struct map_session_data *sd); +struct trade_interface { + void (*request) (struct map_session_data *sd, struct map_session_data *target_sd); + void (*ack) (struct map_session_data *sd,int type); + int (*check_impossible) (struct map_session_data *sd); + int (*check) (struct map_session_data *sd, struct map_session_data *tsd); + void (*additem) (struct map_session_data *sd,short index,short amount); + void (*addzeny) (struct map_session_data *sd,int amount); + void (*ok) (struct map_session_data *sd); + void (*cancel) (struct map_session_data *sd); + void (*commit) (struct map_session_data *sd); +} trade_s; + +struct trade_interface *trade; +void trade_defaults(void); #endif /* _TRADE_H_ */ diff --git a/src/map/unit.c b/src/map/unit.c index e5637e42d..021859bba 100644 --- a/src/map/unit.c +++ b/src/map/unit.c @@ -2104,7 +2104,7 @@ int unit_remove_map_(struct block_list *bl, clr_type clrtype, const char* file, if(sd->chatID) chat_leavechat(sd,0); if(sd->trade_partner) - trade_tradecancel(sd); + trade->cancel(sd); buyingstore->close(sd); searchstore->close(sd); if(sd->state.storage_flag == 1) |