References: Difference between revisions

From OpenKore Wiki
Jump to navigation Jump to search
mNo edit summary
No edit summary
 
(43 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;
!Type
!Value
!Description
!Description
|-
|-
|align=center|flag
| 0 or empty string (unset option)
|A number with special meaning on its current context. The list of meaningful values are always given.
| FALSE (disable)
|-
|-
|align=center|boolean flag
| 1
|A type of flag with only two values: '''1''' to enable and '''0''' to disable.
| TRUE (enable)
|-
|align=center|number
|Any number. This can be a fractional value (separated by dot .) or an integer number.
|-
|align=center|percent
|A number from 1 to 100 that corresponds to a percent. Don't append a percent sign (%) unless otherwise specified.
|-
|align=center|seconds
|The time specified in seconds. Can be a fractional value (ex. 0.5).
|-
|align=center|string
|Any text string.
|}
|}
: 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]] ==
Message domains are names used to classify messages printed in the console.
{{:domain}}


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:


{| border="1" cellpadding="2" cellspacing="1"  
{| border="1" cellpadding="2" cellspacing="1"  
|- style=background-color:#F9F9F9;
|- style=background-color:#F9F9F9;
|+ List of known message domains:
!Name
!Name
!Description
!AI state description
|-
|-
|align=center|ai_attack
|align=center|attack
|Attack messages
|OpenKore is attacking someone
|-
|-
|align=center|ai_npcTalk
|align=center|autoResponse
|NPC talk sequence messages.
|OpenKore automatically replies to chat messages (see [[autoResponse]])
|-
|-
|align=center|attacked
|align=center|buyAuto
|Monster attacks you.
|OpenKore has initiated automatic item purchase (see [[buyAuto]])
|-
|-
|align=center|attackedMiss
|align=center|cartAdd
|Monster attacks you but misses.
|OpenKore moves items to [[cart]]
|-
|-
|align=center|attackMon
|align=center|cartGet
|You attack monster.
|OpenKore gets items from the [[cart]]
|-
|-
|align=center|attackMonMiss
|align=center|clientSuspend
|You attack monster but misses.
|AI is frozen, for example after changing the map
|-
|-
|align=center|connection
|align=center|dead
|Connection messages.
|Char died
|-
|align=center|console
|Messages without defined group.
|-
|-
|align=center|deal
|align=center|deal
|Deal messages.
|OpenKore makes [[deal]]
|-
|-
|align=center|drop
|align=center|drop
|Monster drop related messages.
|OpenKore throws items (see [[drop]])
|-
|-
|align=center|emotion
|align=center|equip
|Emoticon messages.
|OpenKore [[equip|equips]] items
|-
|align=center|exp
|Experience gained message.
|-
|-
|align=center|equip
|align=center|escape
|Equipment switching message.
|Openkore tries to [[route_escape_reachedNoPortal|escape from unknown map]]
|-
|-
|align=center|follow
|align=center|follow
|Follow messages.
|OpenKore [[follow|follows]] another player
|-
|-
|align=center|guildchat
|align=center|items_gather
|Guild chat message.
|Openkore picks up other people's items from the ground (see [[itemsGatherAuto]])
|-
|-
|align=center|guildnotice
|align=center|items_take
|Guild notice message.
|OpenKore picks up items after killing a monster (see [[itemsTakeAuto]])
|-
|-
|align=center|info
|align=center|look
|Character information messages.
|OpenKore is [[look|looking]] in the indicated direction
|-
|-
|align=center|input
|align=center|move
|User input messages.
|OpenKore moves to the specified coordinates within the line of sight
|-
|-
|align=center|inventory
|align=center|NPC
|Inventory related messages.
|OpenKore [[talk|talking]] to NPC
|-
|align=center|list
|Actor's list message.
|-
|align=center|load
|Loading config files messages.
|-
|align=center|looter
|Attacking looter message.
|-
|align=center|map_event
|PvP/GvG mode messages.
|-
|align=center|npc
|NPC messages.
|-
|align=center|parseMsg_statuslook
|Changed status/equipment messages.
|-
|align=center|parseMsg/hairColor
|Hair color change message.
|-
|align=center|parseMsg/job
|Job change message.
|-
|align=center|parseMsg/upgrade
|Item upgrading message.
|-
|align=center|party
|Party/follow related message.
|-
|align=center|partychat
|Party chat messages.
|-
|align=center|pet
|Pet related messages.
|-
|align=center|plugins
|Plugin handle messages.
|-
|align=center|pm
|Received private messages.
|-
|align=center|pm/sent
|Sent private messages.
|-
|align=center|portals
|Portal existance messages.
|-
|align=center|portalRecord
|Recording of portals messages.
|-
|align=center|publicchat
|Public chat message.
|-
|align=center|refine
|Weapon refining messages.
|-
|-
|align=center|route
|align=center|route
|Routing/pathfinding messages.
|OpenKore moves to the specified point using pathfinding.
|-
|-
|align=center|route_teleport
|align=center|sellAuto
|Route teleport messages.
|OpenKore has initiated automatic selling of items (see [[sellAuto]])
|-
|-
|align=center|schat
|align=center|sendEmotion
|GM broadcast messages.
|OpenKore sends an emote
|-
|-
|align=center|selfSkill
|align=center|sitAuto
|Skills used by yourself messages.
|OpenKore automatically sits down (see [[:Category:sitting]])
|-
|-
|align=center|skill
|align=center|sitting
|Skills not related to attack messages.
|OpenKore sits down
|-
|-
|align=center|sold
|align=center|skill_use
|Items sold while vending messages.
|OpenKore uses skill
|-
|-
|align=center|startup
|align=center|standing
|Startup messages.
|OpenKore stands up
|-
|-
|align=center|storage
|align=center|storageAuto
|Storage item added/removed messages.
|OpenKore has initiated automatic stocking of items (see [[storageAuto]])
|-
|-
|align=center|success
|align=center|take
|Operation succeeded messages.
|OpenKore picks up items after killing a monster (see [[itemsTakeAuto]]) TODO: hat is the difference between "items_take" and "take"?
|-
|align=center|syntax
|Syntax check files messages.
|-
|-
|align=center|teleport
|align=center|teleport
|Teleporting messages.
|OpenKore uses [[tele|teleport]] or [[respawn]]
|-
|-
|align=center|useItem
|align=center|transferItems
|Items used by you messages.
|OpenKore moves items from one location (inventory/cart/warehouse) to another
|-
|-
|align=center|useTeleport
|Attemp to use teleport messages.
|-
|align=center|waypoint
|Waypoint messages.
|-
|align=center|xkore
|X-Kore system messages.
|}
|}
The following is a list of debug domains:
{|
|
*ai
*ai_attack
*ai_autoCart
*ai_makeItem
*ai_move
*ai_npcTalk
*attackMonMiss
*autoBreakTime
||
*connection
*d_sendPacket
*debug
*drop
*equipAuto
*guild
*ipc
*Item
||
*monsterSkill
*npc
*packetParser
*parseInput
*parseMsg
*parseMsg_comboDelay
*parseMsg_damage
*parseMsg_move
||
*parseMsg_presence
*parseMsg_presence/name
*parseMsg_presence/player
*parseMsg_presence/remote
*parseMsg_statuslook
*parseSendMsg
*pet
*route
||
*route_teleport
*sendPacket
*sitAuto
*skill
*storage
*useTeleport
*vending
|}


== Names ==
== Names ==
Line 343: Line 249:
'''Example'''
'''Example'''


* For a +4 Cranial Mirror Shield, a Hard Padded Armor, a 3-slotted +5 Double Flammable Boned Saber, and a +6 Very Very Strong Wind Tsurugi, use:
* 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]] '''spell''' while certain spells are active on the ground.  
* 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.
Line 425: Line 330:


=== Skill Names ===
=== Skill Names ===
----
Skill names can be found at tables\skills.txt, following this syntax:
<skill ID> <skill alias> <skill name>
''' Example '''


* Skill name is Basic Skill
Skill handles (locale independent) can be found at <code>tables/SKILL_id_handle.txt</code>.
1 NV_BASIC Basic Skill


'''Note:'''
Skill names (depend on your configuration) can be found at <code>skillnametable.txt</code> used by your configuration.
* Your skill names can also be find using [[Console Commands|console command]] '''skills'''.


Currently used skill names can also be found by inspecting [[skills]], [[homun|homun skills]], [[merc|merc skills]] commands output.


=== Status Names ===
=== Status Names ===
----
Status names can be found at tables\skillsailments.txt, tables\skillslooks.txt, tables\skillsstate.txt, tables\skillsstatus.txt, following this syntax:


<skill status ID> <status name>
Status handles (locale independent) can be found at <code>tables/{AILMENT,LOOK,STATE,STATUS}_id_handle.txt</code>.


''' Example '''
Corresponding status names (depend on your configuration) can be found at <code>statusnametable.txt</code> used by your configuration.


* Status name is Poisoned
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.
1 Poisoned


'''Note:'''
== [[NPC conversation codes]] ==
* Status names can be found by using the [[Console Commands|console command]] '''s''' while certain status are active on you character.


== Range Operators ==


== NPC Conversation Codes ==
User-specified [[wikipedia:Interval (mathematics)|interval]] for an option.
These codes are used for specifying NPC talk sequences or steps when using the [[Console Commands]] or the config.txt options. Each code is separated with a whitespace.


{| border="1" cellpadding="2" cellspacing="1"  
{| border="1" cellpadding="2" cellspacing="1" style="text-align:center"
|- style=background-color:#F9F9F9;
|- style=background-color:#F9F9F9;
|+ List of known NPC talk codes.
!Value
!Code
!Description
!Description
|-
|-
!align=center|c
| X
|Continue talking to the NPC. This is the same as pressing the Next buttom.
| {X}
|-
|-
!align=center|r(<response #>)
| X..Y
|Send a response to the NPC. The response number is the index of the responses in the displayed response list . This is the same as selecting a response when you talk to an NPC.
|rowspan="2"| [X, Y]
|-
|-
!align=center|w(<seconds>)
| X-Y
|Wait for the specified number of seconds before continuing to talk to the NPC.
|-
|-
!align=center|d(<number>)
| > X
|Send a number to the NPC. Use this if the NPC asks you to enter an amount. 
| (X, +∞)
|-
|-
!align=center|t=(<string>)
| >= X
|Send a text to the NPC. Use this if the NPC asks you to enter some text.
| [X, +∞)
|-
|-
!align=center|s
| < X
|Go to sell list. This is the same as pressing the sell button when you talk to a buy/sell NPC.
| (-∞, X)
|-
|-
!align=center|b
| <= X
|Go to the store list. This is the same as pressing the buy button when you talk to a buy/sell NPC.
| (-, X]
|-
!align=center|b(<store item #>),(<amount>)
|Buy an item from the NPC. See similar [[Console Commands|buy]]. Note that the amount is not optional.
|-
!align=center|n
|Ends and cancel conversation with the NPC. This is the same as pressing the close or cancel button when talking to an NPC.
|-
!align=center|e
|Wait until the NPC says "Done talking". Use this after the '''s''' or '''b''' talk code when talking to a buy/sell NPC.
|}
|}


'''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.


''' Example '''
== [[:Category:Self Condition|Self Conditions]] ==
 
{{:Category:Self Condition}}
* Talk to NPC at the coordinates (63, 60), using the talk sequence: Next>Choose fourth response>Next>Choose first response>Next>Next>Choose first response>Next>End.
talknpc 63 60 c r3 c r0 c c r0 c n
 
 
 
== Range Operators ==
Range operators provide flexibility in specifying values for some [[config.txt]] options by specifying ranges instead of exact values.
{| border="1" cellpadding="2" cellspacing="1"
|- style=background-color:#F9F9F9;
|+ List of syntaxes for specifying ranges
!Symbol
!Description
|-
!align=center|X
|Value is exactly equal to X.
|-
!align=center|X..Y
|Includes all numbers from X to Y.
|-
!align=center|X-Y
|Includes all numbers from X to Y.
|-
!align=center|> X
|Value is greater than X.
|-
!align=center|>= X
|Value is greater than or equal to X.
|-
!align=center|< X
|Value is less than X.
|-
!align=center|<= X
|Value is less than or equal to X.
|-
|}
 
 
''' Example '''
 
* Level is greater than 10
lvl > 10
 
* Zenys is equal to 5000.
zeny 5000
 
* Job level is between 10 and 15
jlvl 10..15
 
 
== 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.
 
{|
|
* [[aggressives]]
 
* [[defendMonsters]]
 
* [[disabled]]
 
* [[hp]]
 
* [[inCart]]
 
* [[inInventory]]
 
* [[inLockOnly]]
 
* [[inMap]]
||
* [[monsters]]
 
* [[notInTown]]
 
* [[notMonsters]]
 
* [[notOnAction]]
 
* [[notInMap]]
 
* [[notWhileSitting]]
 
* [[onAction]]
 
* [[partyAggressives]]
||
* [[sp]]
 
* [[spirit]]
 
* [[stopWhenHit]]
 
* [[timeout]]
 
* [[whenFlag]]
 
* [[whenFollowing]]
 
* [[whenGround]]
 
* [[whenIdle]]
||
* [[whenNotFlag]]
 
* [[whenNotGround]]
 
* [[whenNotPermitSkill]]
 
* [[whenPermitSkill]]
 
* [[whenStatusActive]]
 
* [[whenStatusInactive]]
 
* whenWater - not working yet
|}
 


== Target Conditions ==
== Target Conditions ==
=== Monster Conditions ===
Conditions about the monster status/information.
These condition attributes are shared between the [[attackComboSlot]], [[attackSkillSlot]], [[equipAuto]], and [[monsterSkill]] configuration blocks.
{|
|
* [[target_deltaHP]]
* [[target_dist]]
* [[target_misses]]
||
* [[target_timeout]]
* [[target_totalMisses]]
* [[target_whenGround]]
||
* [[target_whenNotGround]]
* [[target_whenStatusActive]]
* [[target_whenStatusInactive]]
|}


=== Player Conditions ===
=== [[:Category:Monster Condition|Monster Conditions]] ===
Condition about player's status/information.
Currently, only the [[partySkill]] configuration block uses these conditions.
{|
|
* [[target_aggressives]]


* [[target_dead]]
{{:Category:Monster Condition}}


* [[target_defendMonsters]]
=== [[:Category:Player Condition|Player Conditions]] ===


* [[target_deltaHP]]
{{:Category:Player Condition}}


* [[target_dist]]
=== [[:Category:Skill Use Condition|Skill Use Conditions]] ===
{{:Category:Skill Use Condition}}


* [[target_hp]]
=== [[:Category:Idle Condition|Idle Condition]] ===
||
{{:Category:Idle Condition}}
* [[target_isGuild]]


* [[target_isJob]]
== [[:Category:Interfaces|Interfaces]] ==
 
{{:Category:Interfaces}}
* [[target_isNotJob]]
 
* [[target_monsters]]
 
* [[target_notWhileSitting]]
 
* [[target_timeout]]
||
* [[target_whenGround]]
 
* [[target_whenNotGround]]
 
* [[target_whenShieldEquipped]]
 
* [[target_whenStatusActive]]
 
* [[target_whenStatusInactive]]
 
* [[target_whenWeaponEquipped]]
|}
 
== Skill Use Conditions ==
Conditions about skills.
These options are shared between the [[attackComboSlot]], [[attackSkillSlot]], [[monsterSkill]], [[partySkill]], and [[useSelf_skill]] configuration blocks.
 
{|
* [[lvl]]
 
* [[maxCastTime]]
 
* [[minCastTime]]
 
* [[equip]]
|}

Latest revision as of 22:09, 3 April 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.

List of equipment slots.
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:


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.


Skill Names

Skill handles (locale independent) can be found at tables/SKILL_id_handle.txt.

Skill names (depend on your configuration) can be found at skillnametable.txt used by your configuration.

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).