Skip to content

tes3script⚓︎

A script object.

This type inherits the following: tes3baseObject.

Properties⚓︎

blocked⚓︎

The blocked state of the object.

Returns:

  • result (boolean)

byteCode⚓︎

Read-only. A byte representation of instructions that the script will run.

Returns:

  • result (number[])

context⚓︎

Read-only. A special context used for getting and setting script's variables.

Returns:


deleted⚓︎

Read-only. The deleted state of the object.

Returns:

  • result (boolean)

disabled⚓︎

Read-only. The disabled state of the object.

Returns:

  • result (boolean)

floatVariableCount⚓︎

Read-only. The number of variables of float type in the script.

Returns:

  • result (number)

id⚓︎

Read-only. The unique identifier for the object.

Returns:

  • result (string)

longVariableCount⚓︎

Read-only. The number of variables of long type in the script.

Returns:

  • result (number)

modified⚓︎

The modification state of the object since the last save.

Returns:

  • result (boolean)

objectFlags⚓︎

Read-only. The raw flags of the object.

Returns:

  • result (number)

objectType⚓︎

Read-only. The type of object. Maps to values in tes3.objectType.

Returns:


persistent⚓︎

The persistent flag of the object.

Returns:

  • result (boolean)

shortVariableCount⚓︎

Read-only. The number of variables of short type in the script.

Returns:

  • result (number)

sourceless⚓︎

The sourceless flag of the object.

Returns:

  • result (boolean)

sourceMod⚓︎

Read-only. The filename (including the extension) of the mod that owns this object. It has nil value if the object was anything other than loaded from an ESP or ESM file.

Returns:

  • result (string)

supportsActivate⚓︎

If true, the object supports activation. This includes all the items (excluding non-carriable lights), actors outside combat, activators, containers and doors.

However, the activation of such an object may still be blocked via mwscript or a Lua script.

Returns:

  • result (boolean)

supportsLuaData⚓︎

If true, references of this object can store temporary or persistent lua data.

Returns:

  • result (boolean)

text⚓︎

Read-only. The plain text of the script. Note that line endings do not match the default lua line endings. This requires file IO, and is slow. If recompile is used to change the script at runtime, this will not be accurate.

Returns:

  • result (string)

Methods⚓︎

__tojson⚓︎

Serializes the object to json.

local string = myObject:__tojson()

Returns:

  • string (string)

getVariableData⚓︎

This method fetches all of the script's variables as a table. Returns nil if the script has no variables.

local results = myObject:getVariableData(useLocals)

Parameters:

  • useLocals (boolean): Optional.

Returns:

  • results (table<string, tes3scriptVariableData>, nil): A table with all of the script's variable names as keys.

recompile⚓︎

Replaces the bytecode of a script with the code compiled with the given mwscript. This should only be done during the initialized event, prior to a game being loaded.

local success = myObject:recompile(text)

Parameters:

  • text (string): The script text to compile. The line endings must be provided using CRLF.

Returns:

  • success (boolean): If true, the script was recompiled successfully.