Properties
The Properties module by monkey_05_06 provides methods for the user to create, edit, and delete custom properties via the script at run-time.
Dependencies
Adventure Game Studio Editor v3.1.0 or higher.
Setup
This module is ready-to-use right out of the "box" however there are some settings you may wish to customize to better fit your needs. For these, see below under Enumerated Values and Macros (#define-s).
Enumerated Values
Properties_Settings
eProperties_IntDefault
Defines the default value to use for integers if the property is not defined or if no default value is given for the property.
eProperties_StringDefault
This value is for autocomplete purposes only. To set this value, see the macro by the same name below.
See Also: eProperties_StringDefault (macro)
eProperties_ObeyPropertyType
This setting controls whether the module will obey the type of properties (number or text) when getting and setting the value. It should only be set to TRUE or FALSE.
eProperties_MaxProperties
This defines the maximum number of properties you can define. Attempting to define more than this won't crash your game, but it won't work either until you delete some properties. You can lower this value if you need to save memory.
NOTE: If MaxProperties * MaxRooms is greater than 1000000 (one million) it WILL crash your game. The defaults for both are 1000.
See Also: eProperties_MaxRooms
eProperties_MaxRooms
This sets the maximum number of rooms the module will support. You can raise or lower this to fit your specific needs, but it cannot exceed 1000 since that is the highest number of rooms AGS supports. This setting should be set to one higher than the highest numbered room you have (so if you have 1 room named "room1.crm" this setting should be set to 2).
NOTE: If MaxProperties * MaxRooms is greater than 1000000 (one million) it WILL crash your game. The defaults for both are 1000.
See Also: eProperties_MaxProperties
Macros (#define-s)
eProperties_StringDefault
This is used to set the default value for Strings if the property does not exist or no default value has been set for the property. This must be a string of text or be null.
See Also: eProperties_StringDefault (enum)
PROPERTIES_VERSION
This defines the current version of the module. As of v3.1 you can use this macro as a float within your scripts.
PROPERTIES_VERSION_312
This defines that at least v3.12 of the module has been imported.
PROPERTIES_DEFAULTINTERACTION
If this macro is defined (you can comment it to exclude it) then an extra set of functions are included for default interactions. The property "DefaultInteraction" will be defined and wrapper functions will be created to simplify working with these functions.
Functions and Properties
Property management functions
Properties.Create
static int Properties::Create(String property, optional int defaultValue=eProperties_IntDefault)
Creates a new number property named PROPERTY if a similarly named property does not already exist. If the property was created you can also set the default value to DEFAULTVALUE. This function returns -1 if the property was not created.
See Also: Properties.CreateText, Properties.Delete
Properties.CreateText
static int Properties::CreateText(String property, optional String defaultValue=eProperties_StringDefault)
Creates a new text property named PROPERTY if a similarly named property does not already exist. If the property was created you can also set the default value to DEFAULTVALUE. This function returns -1 if the property was not created.
See Also: Properties.Create, Properties.Delete
Properties.Delete
static void Properties::Delete(String property)
Deletes PROPERTY if it exists. This can be either a number or a text property.
See Also: Properties.Create, Properties.CreateText
Properties.Exists
static bool Properties::Exists(String property)
Returns whether PROPERTY exists.
See Also: Properties.IsTextProperty
Properties.GetDefaultValue
static int Properties::GetDefaultValue(String property)
Returns the default value of PROPERTY. If the property does not exist this returns eProperties_IntDefault. Note that this property obeys eProperties_ObeyPropertyType, which if true means this function will only return the value of number property default values.
Properties.GetDefaultTextValue
static String Properties::GetDefaultTextValue(String property)
Returns the default value of PROPERTY. If the property does not exist this returns eProperties_StringDefault. Note that this property obeys eProperties_ObeyPropertyType, which if true means this function will only return the value of text property default values.
Properties.GetCount
static int Properties::GetCount()
Returns the number of currently created properties.
Properties.IsTextProperty
static bool Properties::IsTextProperty(String property)
Returns whether PROPERTY is a text property (TRUE) or a number property (FALSE). If the property does not exist this returns FALSE.
Properties.SetDefaultValue
static void Properties::SetDefaultValue(String property, int value)
Sets the default value of PROPERTY to VALUE. This obeys eProperties_ObeyPropertyType so it will only work on number properties and only if the property actually exists.
Properties.SetDefaultTextValue
static void Properties::SetDefaultTextValue(String property, String value)
Sets the default value of PROPERTY to VALUE. This obeys eProperties_ObeyPropertyType so it will only work on text properties and only if the property actually exists.
Properties.SetPropertyType
static void Properties::SetPropertyType(String property, bool isText)
Sets whether PROPERTY is a text property (TRUE) or a number property (FALSE). You should not normally need this function.
Item properties
GetCustomProperty
int Character.GetCustomProperty(String property)
int Hotspot.GetCustomProperty(String property, optional int roomID)
int InventoryItem.GetCustomProperty(String property)
int Object.GetCustomProperty(String property, optional int roomID)
int RoomGetCustomProperty(String property, optional int roomID)
These five functions are used to retrieve the value of the number property for the respective Character, Hotspot, InventoryItem, Object, or Room that they correspond to. The Hotspot, Object, and Room functions all have optional ROOMID properties which can be used to specify a room other than the current one.
NOTE: The Hotspot and Object functions operate on the item's ID. So even if you're using a specific instance in a specific room, if you pass a different room number for ROOMID it will access the hotspot/object with the same ID in that room.
NOTE: The Room function is not an extender method of the Room struct. You DO NOT use a dot to use this function.
See Also: GetCustomTextProperty, SetCustomProperty
GetCustomTextProperty
String Character.GetCustomTextProperty(String property)
String Hotspot.GetCustomTextProperty(String property, optional int roomID)
String InventoryItem.GetCustomTextProperty(String property)
String Object.GetCustomTextProperty(String property, optional int roomID)
String RoomGetCustomTextProperty(String property, optional int roomID)
These five functions are used to retrieve the value of the text property for the respective Character, Hotspot, InventoryItem, Object, or Room that they correspond to. The Hotspot, Object, and Room functions all have optional ROOMID properties which can be used to specify a room other than the current one.
NOTE: Hotspot and Object functions operate on the item's ID, not a specific instance.
NOTE: The Room function DOES NOT use a dot to operate.
See Also: GetCustomProperty, SetCustomTextProperty
SetCustomProperty
void Character.SetCustomProperty(String property, int value)
void Hotspot.SetCustomProperty(String property, int value, optional int roomID)
void InventoryItem.SetCustomProperty(String property, int value)
void Object.SetCustomProperty(String property, int value, optional int roomID)
void RoomSetCustomProperty(String property, int value, optional int roomID)
These five functions are used to set the value of the number property for the respective Character, Hotspot, InventoryItem, Object, or Room that they correspond to. The Hotspot, Object, and Room functions all have optional ROOMID properties which can be used to specify a room other than the current one.
NOTE: Hotspot and Object functions operate on the item's ID, not a specific instance.
NOTE: The Room function DOES NOT use a dot to operate.
See Also: GetCustomProperty, SetCustomTextProperty
SetCustomTextProperty
void Character.SetCustomTextProperty(String property, String value)
void Hotspot.SetCustomTextProperty(String property, String value, optional int roomID)
void InventoryItem.SetCustomTextProperty(String property, String value)
void Object.SetCustomTextProperty(String property, String value, optional int roomID)
void RoomSetCustomTextProperty(String property, String value, optional int roomID)
These five functions are used to set the value of the text property for the respective Character, Hotspot, InventoryItem, Object, or Room that they correspond to. The Hotspot, Object, and Room functions all have optional ROOMID properties which can be used to specify a room other than the current one.
NOTE: Hotspot and Object functions operate on the item's ID, not a specific instance.
NOTE: The Room function DOES NOT use a dot to operate.
Default interaction functions
The following functions are only implemented if the PROPERTIES_DEFAULTINTERACTION macro is defined. See Macros (#define-s) for more information.
GetDefaultInteraction
CursorMode Character.GetDefaultInteraction()
CursorMode Hotspot.GetDefaultInteraction()
CursorMode InventoryItem.GetDefaultInteraction()
CursorMode Object.GetDefaultInteraction()
These four functions all return the value of the property DefaultInteraction for the specified item.
NOTE: There is no Room function specified here. You cannot directly interact with a Room so it wouldn't make sense for there to be a default.
See Also: SetDefaultInteraction, GetDefaultInteractionAtScreenXY
SetDefaultInteraction
void Character.SetDefaultInteraction(CursorMode)
void Hotspot.SetDefaultInteraction(CursorMode)
void InventoryItem.SetDefaultInteraction(CursorMode)
void Object.SetDefaultInteraction(CursorMode)
These four functions all set the value of the property DefaultInteraction for the specified item.
NOTE: There is no Room function specified here. You cannot directly interact with a Room so it wouldn't make sense for there to be a default.
See Also: GetDefaultInteraction, GetDefaultInteractionAtScreenXY
GetDefaultInteractionAtScreenXY
CursorMode GetDefaultInteractionAtScreenXY(int x, int y)
Returns the value of the property DefaultInteraction for whatever is shown on the screen at the specified (X, Y) co-ordinates. This can be a Character, Hotspot, InventoryItem, or an Object.
Licensing
This AGS Script Module is hereby released to public domain with restriction as follows: the module may be modified and released in any fashion such that modifications do not nullify this license, and any subsequent versions of this module must be released using the same license, and may not be relicensed. This module is released without any warranty of any kind implicit or otherwise, and by using this module you agree to waive liability of the author of any subsequent consequence of using this module. The original author reserves the right at any time to void and revoke this license in favor of another license only provided the subsequently chosen license submits this module to public domain in some fashion. Furthermore, lol. That is all.
Changelog
Version 3.12
Version: 3.12 Author: monkey_05_06 Date: 06 October 2008 Description: Improved handling of room functions: Fixed crash if you didn't specify a room and the player was in a room unsupported by the module. Also implemented DefaultInteraction functions. Updated documentation to correct required AGS version which is 3.1.0+ and not 3.0.2+.
Version 3.11
Version: 3.11 Author: monkey_05_06 Date: 05 October 2008 Description: Fixes crash using InventoryItem functions due to InventoryItems being indexed from one instead of zero like most other items.
Version 3.1
Version: 3.1 Author: monkey_05_06 Date: 30 September 2008 Description: Fixes crash due to limit on number of properties. Implements static limits to increase functionality and speed. Provided method to enforce/ignore property type.