diff options
Diffstat (limited to 'doc')
-rw-r--r-- | doc/script_commands.txt | 57 |
1 files changed, 36 insertions, 21 deletions
diff --git a/doc/script_commands.txt b/doc/script_commands.txt index a57a261bd..e67aaf601 100644 --- a/doc/script_commands.txt +++ b/doc/script_commands.txt @@ -128,6 +128,8 @@ //= Changed the error behaviour of delitem/delitem2/Zeny. [FlavioJS] //= 3.25.20081220 //= Extended the behaviour of duplicates (warps/shops/cashshops). [FlavioJS] +//= 3.26.20090702 +//= Replaced 'bonusautoscript' by 'autobonus'. [Inkfish] //========================================================= This document is a reference manual for all the scripting commands and functions @@ -4502,42 +4504,55 @@ kind in 'doc/item_bonus.txt'. --------------------------------------- -*bonusautoscript <script>,<rate>{,<flag>} -*bonusautoscript2 <script>,<rate>{,<flag>} +*autobonus <bonus script>,<rate>,<duration>{,<flag>,{<other script>}}; +*autobonus2 <bonus script>,<rate>,<duration>{,<flag>,{<other script>}}; +*autobonus3 <bonus script>,<rate>,<duration>,<skill id>,{<other script>}; +*autobonus3 <bonus script>,<rate>,<duration>,"<skill name>",{<other script>}; These commands are meant to be used in item scripts. They will probably work outside item scripts, but the bonus will not persist for long. They, as expected, refer only to an invoking character. What these commands do is 'attach' a script to the player which will get -executed on attack (or when attacked in the case of bonusautoscript2). Rate is -the trigger rate of the script (1000 = 100%). The optional argument flag is -used to classify the type of attack where the script can trigger (it shares -the same flags as the bAutoSpell bonus script): +executed on attack (or when attacked in the case of autobonus2). + +Rate is the trigger rate of the script (1000 = 100%). + +Duration is the time that the bonus will last for since the script has triggered. + +The optional argument 'flag' is used to classify the type of attack where the script +can trigger (it shares the same flags as the bAutoSpell bonus script): Range criteria: - BF_SHORT: Trigger on melee attack - BF_LONG: Trigger on ranged attack - Default: BF_SHORT+BF_LONG + BF_SHORT: Trigger on melee attack + BF_LONG: Trigger on ranged attack + Default: BF_SHORT+BF_LONG Attack type criteria: BF_WEAPON: Trigger on weapon skills - BF_MAGIC: Trigger on magic skills - BF_MISC: Trigger on misc skills - Default: BF_WEAPON + BF_MAGIC: Trigger on magic skills + BF_MISC: Trigger on misc skills + Default: BF_WEAPON Skill criteria: BF_NORMAL: Trigger on normal attacks - BF_SKILL: Trigger on skills - default: If the attack type is BF_WEAPON (only) BF_NORMAL is used, otherwise - BF_SKILL+BF_NORMAL is used. + BF_SKILL: Trigger on skills + default: If the attack type is BF_WEAPON (only) BF_NORMAL is used, + otherwise BF_SKILL+BF_NORMAL is used. + +The difference between the optional argument 'other script' and the 'bonus script' is that, +the former one triggers only when attacking(or attacked) and the latter one runs on +status calculation as well, which makes sure, within the duration, the "bonus" that get +lost on status calculation is restored. So, 'bonus script' is technically supposed to accept +"bonus" command only. And we usually use 'other script' to show visual effects. -In both cases, when the script triggers, the attached player will be the one -who holds the bonus. There is currently no way of knowing within this script -who was the other character (the attacker in autoscript2, or the target in -autoscript). +In all cases, when the script triggers, the attached player will be the one +who holds the bonus. There is currently no way of knowing within this script +who was the other character (the attacker in autobonus2, or the target in +autobonus and autobonus3). //Grants a 1% chance of starting the state "all stats +10" for 10 seconds when -//using weapon or misc attacks (both melee and ranged skills). - bonusautoscript "{ sc_start SC_INCALLSTATUS,10000,10; }",10,BF_WEAPON|BF_MISC; +//using weapon or misc attacks (both melee and ranged skills) and shows a special +//effect when the bonus is active. + autobonus "{ bonus bAllStats,10; }",10,10000,BF_WEAPON|BF_MISC,"{ specialeffect2 EF_FIRESPLASHHIT; }"; --------------------------------------- |