References: Difference between revisions
|  →Self Conditions:  add homun&merc self conditions | |||
| (42 intermediate revisions by 10 users not shown) | |||
| Line 27: | Line 27: | ||
| Parameters types that may appear in a configuration option's value or a command parameter. | Parameters types that may appear in a configuration option's value or a command parameter. | ||
| {|border="1" cellpadding="2" cellspacing="1"   | === boolean flag === | ||
| : Option values are interpreted with [http://perldoc.perl.org/perlsyn.html#Truth-and-Falsehood Perl's Truth and Falsehood] rules. | |||
| {| border="1" cellpadding="2" cellspacing="1" style="text-align:center" | |||
| |- style=background-color:#F9F9F9; | |- style=background-color:#F9F9F9; | ||
| ! | !Value | ||
| !Description | !Description | ||
| |- | |- | ||
| | | | 0 or empty string (unset option) | ||
| | | | FALSE (disable) | ||
| |- | |- | ||
| | | | 1 | ||
| | TRUE (enable) | |||
| | | |||
| |} | |} | ||
| : Actually, [https://perldoc.perl.org/5.8.8/perlsyn.html#Truth-and-Falsehood boolean flag] (which isn't checked for anything but boolean) can have any value. | |||
| : Boolean options MAY be extended in future. In such a case, values of '''0''' and '''1''' SHOULD preserve the old behaviour, and more values MAY be added. | |||
| : '''API:''' There is no API per se, just use usual Perl's logic operators. | |||
| : '''Examples:''' | |||
|  if ($config{useDeadlyRay}) { ... | |||
| === flag === | |||
| : A number with special meaning on its current context. The list of meaningful values are always given. | |||
| === number === | |||
| : A number with special meaning on its current context. The list of meaningful values are always given. May be a fractional value (with dot <code>.</code> separator) or just an integer. Empty string (unset option) or strings starting with non-numeric characters are evaluated as in Perl, usually to '''0'''. | |||
| : '''Notes:''' This is not a [[References#Range_Operators|range]]. Values like "<code>= 11</code>" would just evaluate to '''0'''. | |||
| : '''API:''' There is no API per se, just use usual [http://perldoc.perl.org/perlop.html#Relational-Operators Perl's relational and equality operators]. | |||
| : '''Examples:''' | |||
|  if ($config{answerToLifeUniverseAndEverything} == 42) { ... | |||
| === percent === | |||
| : A number from 1 to 100 that corresponds to a percent. Don't append a percent sign (%) unless otherwise specified. | |||
| === seconds === | |||
| : The time specified in seconds. Can be a fractional value (ex. 0.5). | |||
| === string === | |||
| : Any text string. | |||
| ==Equipment Slots== | ==Equipment Slots== | ||
| Line 90: | Line 103: | ||
| |align=center|shoes | |align=center|shoes | ||
| |Footwear slot. | |Footwear slot. | ||
| |- | |||
| |align=center|costumeTopHead | |||
| |Upper head costume slot. | |||
| |- | |||
| |align=center|costumeMidHead | |||
| |Middle head costume slot. | |||
| |- | |||
| |align=center|costumeLowHead | |||
| |Lower heads costume slot. | |||
| |- | |||
| |align=center|costumeRobe | |||
| |Robe costume slot. | |||
| |- | |||
| |align=center|costumeFloor | |||
| |Floor costume slot. | |||
| |- | |- | ||
| |align=center|arrow | |align=center|arrow | ||
| |Arrow or Bullet slot.   | |Arrow or Bullet slot. | ||
| |} | |} | ||
| : Developer Notes | |||
| Equipment slot names are defined in [https://github.com/OpenKore/openkore/blob/master/src/Globals.pm#L61 %Globals::equipSlot_lut]. | |||
| == Message Domains == | == [[domain|Message Domains]] == | ||
| {{:domain}} | |||
| == AI Queue == | |||
| List of possible AI states: | |||
| {| border="1" cellpadding="2" cellspacing="1"   | {| border="1" cellpadding="2" cellspacing="1"   | ||
| |- style=background-color:#F9F9F9; | |- style=background-color:#F9F9F9; | ||
| !Name | !Name | ||
| ! | !AI state description | ||
| |- | |- | ||
| |align=center| | |align=center|attack | ||
| | | |OpenKore is attacking someone | ||
| |- | |- | ||
| |align=center| | |align=center|autoResponse | ||
| | | |OpenKore automatically replies to chat messages (see [[autoResponse]]) | ||
| |- | |- | ||
| |align=center| | |align=center|buyAuto | ||
| | | |OpenKore has initiated automatic item purchase (see [[buyAuto]]) | ||
| |- | |- | ||
| |align=center| | |align=center|cartAdd | ||
| | | |OpenKore moves items to [[cart]] | ||
| |- | |- | ||
| |align=center| | |align=center|cartGet | ||
| | | |OpenKore gets items from the [[cart]] | ||
| |- | |- | ||
| |align=center| | |align=center|clientSuspend | ||
| | | |AI is frozen, for example after changing the map | ||
| |- | |- | ||
| |align=center| | |align=center|dead | ||
| | | |Char died | ||
| |- | |- | ||
| |align=center|deal | |align=center|deal | ||
| | | |OpenKore makes [[deal]] | ||
| |- | |- | ||
| |align=center|drop | |align=center|drop | ||
| | | |OpenKore throws items (see [[drop]]) | ||
| |- | |- | ||
| |align=center| | |align=center|equip | ||
| | | |OpenKore [[equip|equips]] items | ||
| | | |||
| |- | |- | ||
| |align=center| | |align=center|escape | ||
| | | |Openkore tries to [[route_escape_reachedNoPortal|escape from unknown map]] | ||
| |- | |- | ||
| |align=center|follow | |align=center|follow | ||
| | | |OpenKore [[follow|follows]] another player | ||
| |- | |- | ||
| |align=center| | |align=center|items_gather | ||
| | | |Openkore picks up other people's items from the ground (see [[itemsGatherAuto]]) | ||
| |- | |- | ||
| |align=center| | |align=center|items_take | ||
| | | |OpenKore picks up items after killing a monster (see [[itemsTakeAuto]]) | ||
| |- | |- | ||
| |align=center| | |align=center|look | ||
| | | |OpenKore is [[look|looking]] in the indicated direction | ||
| |- | |- | ||
| |align=center| | |align=center|move | ||
| | | |OpenKore moves to the specified coordinates within the line of sight | ||
| |- | |- | ||
| |align=center| | |align=center|NPC | ||
| |OpenKore [[talk|talking]] to NPC | |||
| | | |||
| |NPC  | |||
| |- | |- | ||
| |align=center|route | |align=center|route | ||
| | | |OpenKore moves to the specified point using pathfinding. | ||
| |- | |- | ||
| |align=center| | |align=center|sellAuto | ||
| | | |OpenKore has initiated automatic selling of items (see [[sellAuto]]) | ||
| |- | |- | ||
| |align=center| | |align=center|sendEmotion | ||
| | | |OpenKore sends an emote | ||
| |- | |- | ||
| |align=center| | |align=center|sitAuto | ||
| | | |OpenKore automatically sits down (see [[:Category:sitting]]) | ||
| |- | |- | ||
| |align=center| | |align=center|sitting | ||
| | | |OpenKore sits down | ||
| |- | |- | ||
| |align=center| | |align=center|skill_use | ||
| | | |OpenKore uses skill | ||
| |- | |- | ||
| |align=center| | |align=center|standing | ||
| | | |OpenKore stands up | ||
| |- | |- | ||
| |align=center| | |align=center|storageAuto | ||
| | | |OpenKore has initiated automatic stocking of items (see [[storageAuto]]) | ||
| |- | |- | ||
| |align=center| | |align=center|take | ||
| | | |OpenKore picks up items after killing a monster (see [[itemsTakeAuto]]) TODO: hat is the difference between "items_take" and "take"? | ||
| |- | |- | ||
| |align=center|teleport | |align=center|teleport | ||
| | | |OpenKore uses [[tele|teleport]] or [[respawn]] | ||
| |- | |- | ||
| |align=center| | |align=center|transferItems | ||
| | | |OpenKore moves items from one location (inventory/cart/warehouse) to another | ||
| |- | |- | ||
| |} | |} | ||
| == Names == | == Names == | ||
| Line 343: | Line 249: | ||
| '''Example''' | '''Example''' | ||
| * For a + | * For a +7 Cranial Mirror Shield, a Hard Padded Armor, a 3-slotted +5 Double Flammable Boned Saber, and a +6 Very Very Strong Wind Tsurugi, use: | ||
|   +7 Mirror Shield [Thara Frog] [1] |   +7 Mirror Shield [Thara Frog] [1] | ||
| Line 349: | Line 255: | ||
|   +5 Saber [Skel Worker:Vadon*2] [3] |   +5 Saber [Skel Worker:Vadon*2] [3] | ||
|   +6 VVS Wind Tsurugi |   +6 VVS Wind Tsurugi | ||
| === Item Names === | === Item Names === | ||
| Line 367: | Line 272: | ||
| '''Note.'''   | '''Note.'''   | ||
| * So far configuration options using item names are not strict with case-sensitivity.   | * So far configuration options using item names are not strict with case-sensitivity.   | ||
| * You can also get item's name by using [[Console Commands|console commands]], like '''i, cart, storage'''. | * You can also get item's name by using [[Console Commands|console commands]], like '''[[i]]''', '''[[cart]]''', '''[[storage]]'''. | ||
| Line 382: | Line 287: | ||
| '''Note:'''   | '''Note:'''   | ||
| * Ground spell names can also be found using [[Console Commands|console command]] ''' | * Ground spell names can also be found using [[Console Commands|console command]] '''[[spells]]''' while certain spells are active on the ground.   | ||
| Line 399: | Line 304: | ||
| '''Notes:'''   | '''Notes:'''   | ||
| * Map names can also be find using [[Console Commands|console command]] '''where'''. | * Map names can also be find using [[Console Commands|console command]] '''[[where]]'''. | ||
| Line 414: | Line 319: | ||
| '''Notes:'''   | '''Notes:'''   | ||
| * You can also find monster name using [[Console Commands|console command]] '''ml''' while certain monters are on screen.   | * You can also find monster name using [[Console Commands|console command]] '''[[ml]]''' while certain monters are on screen.   | ||
| === Player Names === | === Player Names === | ||
| ---- | ---- | ||
| Player names can be found by using the [[Console Commands|console command]] '''pl''' while certain players are on screen. | Player names can be found by using the [[Console Commands|console command]] '''[[pl]]''' while certain players are on screen. | ||
| '''Note.''' These are case-sensitive. | '''Note.''' These are case-sensitive. | ||
| ===  | === Skills === | ||
| In OpenKore configs, in macros or when using console commands, sometimes you have to specify skills. When writing a skill, you can use three equivalent options: | |||
| # '''<skill_ID>''' - unique skill number. Does not depend on OpenKore language settings. Can be found in [[:Category:tables|tables]]\[[SKILL_id_handle.txt]] | |||
| # '''<skill_handle>''' - skill name (does not contain spaces). Does not depend on OpenKore language settings. Can be found in [[:Category:tables|tables]]\[[SKILL_id_handle.txt]] and [[:Category:tables|tables]]\..\[[skillnametable.txt]] | |||
| # '''<skill_name>''' - "human" name of the skill. Depends on OpenKore language settings. Can be found in the file [[:Category:tables|tables]]\..\[[skillnametable.txt]] | |||
| ''' | ''' Example: ''' | ||
| *  | * 142 - skill_ID | ||
| * NV_FIRSTAID - skill_handle | |||
| * "First Aid" - English name of the skill | |||
| * "Первая помощь" - Russian name of the skill | |||
| Currently used skill names can also be found by inspecting [[skills]], [[homun|homun skills]], [[merc|merc skills]] commands output. | |||
| === Status Names === | === Status Names === | ||
| Status handles (locale independent) can be found at <code>tables/{AILMENT,LOOK,STATE,STATUS}_id_handle.txt</code>. | |||
| Corresponding status names (depend on your configuration) can be found at <code>statusnametable.txt</code> used by your configuration. | |||
| Currently used status names can also be found by inspecting Kore output when certain status is received or by using the [[s]] command while certain status are active on you character. | |||
| == [[NPC conversation codes]] == | |||
| ==  | == Range Operators == | ||
| User-specified [[wikipedia:Interval (mathematics)|interval]] for an option. | |||
| {| border="1" cellpadding="2" cellspacing="1" style="text-align:center" | |||
| {| border="1" cellpadding="2" cellspacing="1"   | |||
| |- style=background-color:#F9F9F9; | |- style=background-color:#F9F9F9; | ||
| !Value | |||
| ! | |||
| !Description | !Description | ||
| |- | |- | ||
| | X | |||
| | | | {X} | ||
| |- | |- | ||
| | X..Y | |||
| | | |rowspan="2"| [X, Y] | ||
| |- | |- | ||
| | X-Y | |||
| |- | |- | ||
| | > X | |||
| | | | (X, +∞) | ||
| |- | |- | ||
| | >= X | |||
| | | | [X, +∞) | ||
| |- | |- | ||
| | < X | |||
| | | | (-∞, X) | ||
| |- | |- | ||
| | <= X | |||
| | (-∞, X] | |||
| |} | |} | ||
| '''API''': | |||
| Features and plugins MUST use [https://github.com/OpenKore/openkore/blob/master/src/Utils.pm#L1070 Utils::inRange(<current value>, <option contents>)] to check any kind of options with range values. | |||
| == [[:Category:Self Condition|Self Conditions]] == | |||
| {{:Category:Self Condition}} | |||
| == Self Conditions == | |||
| { | |||
| == Target Conditions == | == Target Conditions == | ||
| === [[:Category:Monster Condition|Monster Conditions]] === | |||
| {{:Category:Monster Condition}} | |||
| === [[:Category:Player Condition|Player Conditions]] === | |||
| {{:Category:Player Condition}} | |||
| === [[:Category:Skill Use Condition|Skill Use Conditions]] === | |||
| {{:Category:Skill Use Condition}} | |||
| === [[:Category:Idle Condition|Idle Condition]] === | |||
| {{:Category:Idle Condition}} | |||
| == [[:Category:Interfaces|Interfaces]] == | |||
| {{:Category:Interfaces}} | |||
| | | |||
| { | |||
Latest revision as of 22:37, 22 May 2025
Syntax Legends
Syntax format used in declarations of configuration options and commands.
| Symbol | Description | 
|---|---|
| Bold | Elements that the user must type exactly as shown. | 
| < > | Information that the user must specify. | 
| ( ) | Required parameters. | 
| [ ] | Optional parameters. | 
| | | Means OR. This separates choices from which the user must choose only one. | 
Basic Value and Parameter Types
Parameters types that may appear in a configuration option's value or a command parameter.
boolean flag
- Option values are interpreted with Perl's Truth and Falsehood rules.
| Value | Description | 
|---|---|
| 0 or empty string (unset option) | FALSE (disable) | 
| 1 | TRUE (enable) | 
- Actually, boolean flag (which isn't checked for anything but boolean) can have any value.
- Boolean options MAY be extended in future. In such a case, values of 0 and 1 SHOULD preserve the old behaviour, and more values MAY be added.
- API: There is no API per se, just use usual Perl's logic operators.
- Examples:
if ($config{useDeadlyRay}) { ...
flag
- A number with special meaning on its current context. The list of meaningful values are always given.
number
- A number with special meaning on its current context. The list of meaningful values are always given. May be a fractional value (with dot .separator) or just an integer. Empty string (unset option) or strings starting with non-numeric characters are evaluated as in Perl, usually to 0.
- Notes: This is not a range. Values like "= 11" would just evaluate to 0.
- API: There is no API per se, just use usual Perl's relational and equality operators.
- Examples:
if ($config{answerToLifeUniverseAndEverything} == 42) { ...
percent
- A number from 1 to 100 that corresponds to a percent. Don't append a percent sign (%) unless otherwise specified.
seconds
- The time specified in seconds. Can be a fractional value (ex. 0.5).
string
- Any text string.
Equipment Slots
Equipment slot names used by Openkore.
| Name | Description | 
|---|---|
| topHead | Upper head slot. | 
| midHead | Middle head slot. | 
| lowHead | Lower heads slot. | 
| rightHand | Right hand slot. | 
| leftHand | Left hand slot. | 
| rightAcessory | Right Acessory slot. | 
| leftAcessory | Left Acessory slot. | 
| armor | Armor slot. | 
| robe | Gaments slot. | 
| shoes | Footwear slot. | 
| costumeTopHead | Upper head costume slot. | 
| costumeMidHead | Middle head costume slot. | 
| costumeLowHead | Lower heads costume slot. | 
| costumeRobe | Robe costume slot. | 
| costumeFloor | Floor costume slot. | 
| arrow | Arrow or Bullet slot. | 
- Developer Notes
Equipment slot names are defined in %Globals::equipSlot_lut.
Message Domains
Message domains are names used to classify messages printed in the console.
For information about a certain messages that you see in your console, set the option showDomain in config.txt to 1, making Openkore display domains along with messages in the console.
AI Queue
List of possible AI states:
| Name | AI state description | 
|---|---|
| attack | OpenKore is attacking someone | 
| autoResponse | OpenKore automatically replies to chat messages (see autoResponse) | 
| buyAuto | OpenKore has initiated automatic item purchase (see buyAuto) | 
| cartAdd | OpenKore moves items to cart | 
| cartGet | OpenKore gets items from the cart | 
| clientSuspend | AI is frozen, for example after changing the map | 
| dead | Char died | 
| deal | OpenKore makes deal | 
| drop | OpenKore throws items (see drop) | 
| equip | OpenKore equips items | 
| escape | Openkore tries to escape from unknown map | 
| follow | OpenKore follows another player | 
| items_gather | Openkore picks up other people's items from the ground (see itemsGatherAuto) | 
| items_take | OpenKore picks up items after killing a monster (see itemsTakeAuto) | 
| look | OpenKore is looking in the indicated direction | 
| move | OpenKore moves to the specified coordinates within the line of sight | 
| NPC | OpenKore talking to NPC | 
| route | OpenKore moves to the specified point using pathfinding. | 
| sellAuto | OpenKore has initiated automatic selling of items (see sellAuto) | 
| sendEmotion | OpenKore sends an emote | 
| sitAuto | OpenKore automatically sits down (see Category:sitting) | 
| sitting | OpenKore sits down | 
| skill_use | OpenKore uses skill | 
| standing | OpenKore stands up | 
| storageAuto | OpenKore has initiated automatic stocking of items (see storageAuto) | 
| take | OpenKore picks up items after killing a monster (see itemsTakeAuto) TODO: hat is the difference between "items_take" and "take"? | 
| teleport | OpenKore uses teleport or respawn | 
| transferItems | OpenKore moves items from one location (inventory/cart/warehouse) to another | 
Names
Sometimes equipment/item/monster names are different in each server, so Openkore have it's own database in tables folder for defaulting names. Changing the name from the files will affect your configuration.
Equipment Names
Openkore equipment name syntax:
# for normal equipments: [BROKEN] [+<upgrade level>] (<item name>) [[<card name>[*<number>]] [<number of slots>]] # for elemental weapons [BROKEN][+<upgrade level>][VS|VVS|VVVS][Fire|Earth|Wind|Water](<item name>)
Notes:
- If the equipment is not broken, omit the BROKEN part.
- If the equipment is not upgraded, omit the +<upgrade level> part.
- Use only the monster name for the card name, e.g. use Hydra for the Hydra Card.
- If there is only one card of a certain type slotted on the equipment, omit the *<number> part.
- If there are more than one type of cards compounded on the equipment, the <card name>*<number> pair should be colon-separated list. The list should be sorted alphabetically.
- If the equipment is not slotted, omit the [<number of slots>] part.
- So far configuration options using item names are not strict with case-sensitivity.
- If you have the equipment, you can use console commands
Example
- For a +7 Cranial Mirror Shield, a Hard Padded Armor, a 3-slotted +5 Double Flammable Boned Saber, and a +6 Very Very Strong Wind Tsurugi, use:
+7 Mirror Shield [Thara Frog] [1] Padded Armor [Pupa] [1] +5 Saber [Skel Worker:Vadon*2] [3] +6 VVS Wind Tsurugi
Item Names
Item names can be found at tables\items.txt, following this syntax:
<Item ID>#<item_name>#
In items.txt item names are separated with underscores (_), to use them in your configuration replace them with spaces.
 Example 
- Item's name is Mirror Shield.
2107#Mirror_Shield#
Note.
- So far configuration options using item names are not strict with case-sensitivity.
- You can also get item's name by using console commands, like i, cart, storage.
Ground Spell Names
Ground spell names can be found at tables\spells.txt, following this syntax:
<Spell ID> <spell name>
Example
- Ground spell name: Safety Wall
126 Safety Wall
Note:
- Ground spell names can also be found using console command spells while certain spells are active on the ground.
Map Names
Map names can be found at tables\maps.txt, following this syntax:
<map file name>#<map name>#
Openkore use just the first name of the map in it's configuration files.
Example
- Map name is Prontera
prontera.rsw#Prontera City#
Notes:
- Map names can also be find using console command where.
Monster Names
Monster names can be found at tables\monsters.txt, following this syntax:
<monster ID> <monster name>
Example
- Monster name is Scorpion
1001 Scorpion
Notes:
- You can also find monster name using console command ml while certain monters are on screen.
Player Names
Player names can be found by using the console command pl while certain players are on screen.
Note. These are case-sensitive.
Skills
In OpenKore configs, in macros or when using console commands, sometimes you have to specify skills. When writing a skill, you can use three equivalent options:
- <skill_ID> - unique skill number. Does not depend on OpenKore language settings. Can be found in tables\SKILL_id_handle.txt
- <skill_handle> - skill name (does not contain spaces). Does not depend on OpenKore language settings. Can be found in tables\SKILL_id_handle.txt and tables\..\skillnametable.txt
- <skill_name> - "human" name of the skill. Depends on OpenKore language settings. Can be found in the file tables\..\skillnametable.txt
Example:
- 142 - skill_ID
- NV_FIRSTAID - skill_handle
- "First Aid" - English name of the skill
- "Первая помощь" - Russian name of the skill
Currently used skill names can also be found by inspecting skills, homun skills, merc skills commands output.
Status Names
Status handles (locale independent) can be found at tables/{AILMENT,LOOK,STATE,STATUS}_id_handle.txt.
Corresponding status names (depend on your configuration) can be found at statusnametable.txt used by your configuration.
Currently used status names can also be found by inspecting Kore output when certain status is received or by using the s command while certain status are active on you character.
NPC conversation codes
Range Operators
User-specified interval for an option.
| Value | Description | 
|---|---|
| X | {X} | 
| X..Y | [X, Y] | 
| X-Y | |
| > X | (X, +∞) | 
| >= X | [X, +∞) | 
| < X | (-∞, X) | 
| <= X | (-∞, X] | 
API: Features and plugins MUST use Utils::inRange(<current value>, <option contents>) to check any kind of options with range values.
Self Conditions
Conditions about the character status/information.
These condition options are shared between the attackComboSlot, attackSkillSlot, buyAuto, doCommand, equipAuto, monsterSkill, partySkill, useSelf_item, and useSelf_skill configuration blocks.
Target Conditions
Monster Conditions
Conditions about the monster status/information.
These condition attributes are shared between the attackComboSlot, attackSkillSlot, equipAuto, and monsterSkill configuration blocks.
Player Conditions
Condition about player's status/information.
Currently, only the partySkill configuration block uses these conditions.
Skill Use Conditions
Conditions about skills.
These options are shared between the attackComboSlot, attackSkillSlot, monsterSkill, partySkill, and useSelf_skill configuration blocks.
Idle Condition
Activated when the BOT this without actions to perform.
Interfaces
OpenKore Interface Implementations.
Interface to load on start can be specified with Command Line Arguments (--interface=InterfaceName).