Difference between revisions of "TES5Edit Scripting Functions"
imported>Turulo |
imported>Turulo |
||
Line 1: | Line 1: | ||
Work in progress: To become the future home of scripting functions for TES5Edit. | Work in progress: To become the future home of scripting functions for TES5Edit. If you make scripts for TES5Edit please contribute to this page. | ||
TES5Edit implements a script engine based on pascal syntax. The following table enumerates the functions exported by TES5Edit to the script engine that allows interacting with the editor's elements to perform various tasks such as finding records, fixing record conflicts, etc. | |||
The information in the table is not complete so please contribute by explaining these functions, their uses and by fixing mistakes in this information. | |||
The types described by this table such as IwbElement, IwbFile, etc.. are internal and not directly accessible but instead the script engine receives a generic type named <b>IInterface</b> which is common to every object type returned by TES5Edit. | |||
The reason the internal types are shown in this table is because some functions expect references to specific types even if the object reference is being hold by the generic IInterface variable. | |||
| | {| class="wikitable" style="background-color: #AAAAAA; cellpadding: 0" | ||
|+TES5Edit Scripting Functions | |||
|- align="left" | |||
! scope="col" style="background-color: #DDDDDD" | Function | |||
| | ! scope="col" style="background-color: #DDDDDD" | Returns | ||
! scope="col" style="background-color: #DDDDDD" | Arguments | |||
|- | ! scope="col" style="background-color: #DDDDDD" | Description | ||
! scope=" | |- align="left" style="background-color: #F8F8F8" | ||
| scope="row" | <b>Add</b> || IwbElement || container : IwbContainer, name : string, silent = true : boolean || Implemented for main records etc. | |||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>AddElement</b> || || container : IwbContainer , element : IwbElement || | ||
|- align="left" style="background-color: #F8F8F8" | |||
| | | scope="row" | <b>AdditionalElementCount</b> || integer || container : IwbContainer || | ||
! scope=" | |- align="left" style="background-color: #EEEEEE" | ||
| | | scope="row" | <b>AddMasterIfMissing</b> || || file : IwbFile , mastername : string || | ||
|- align="left" style="background-color: #F8F8F8" | |||
| scope="row" | <b>AddMessage</b> || || message : string || Adds a message line into the TES5Edit output panel | |||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>AddNewFile</b> || IwbFile || || Adds a new file and returns its reference | ||
|- align="left" style="background-color: #F8F8F8" | |||
| | | scope="row" | <b>AddRequiredElementMasters</b> || IwbFile || aSourceElement : IwbElement , aTargetFile : IwbFile , aAsNew : boolean || Add the element''s master into the target file. | ||
| | |- align="left" style="background-color: #EEEEEE" | ||
| | | scope="row" | <b>Assigned</b> || || element : IwbElement || | ||
|- align="left" style="background-color: #F8F8F8" | |||
|- | | scope="row" | <b>CanContainFormIDs</b> || boolean || element : IwbElement || | ||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>CanMoveDown</b> || boolean || element : IwbElement || | ||
| element : IwbElement | |- align="left" style="background-color: #F8F8F8" | ||
| | | scope="row" | <b>CanMoveUp</b> || boolean || element : IwbElement || | ||
|- align="left" style="background-color: #EEEEEE" | |||
|- | | scope="row" | <b>ChangeFormSignature</b> || || record : IwbMainRecord , signature : TwbSignature || | ||
|- align="left" style="background-color: #F8F8F8" | |||
| | | scope="row" | <b>Check</b> || boolean || element : IwbElement || | ||
| | |- align="left" style="background-color: #EEEEEE" | ||
| | | scope="row" | <b>ChildGroup</b> || IwbGroupRecord || record : IwbMainRecord || | ||
|- align="left" style="background-color: #F8F8F8" | |||
|- | | scope="row" | <b>ChildrenOf</b> || IwbMainRecord || group : IwbGroupRecord || | ||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>CleanMasters</b> || || file : IwbFile || | ||
| | |- align="left" style="background-color: #F8F8F8" | ||
| | | scope="row" | <b>CompareExchangeFormID</b> || boolean || mainrecord : IwbMainRecord , oldFormID : Cardinal , aNewFormID : Cardinal || | ||
|- align="left" style="background-color: #EEEEEE" | |||
|- | | scope="row" | <b>ConflictAllForMainRecord</b> || TConflictThis || record : IwbMainRecord || Gets the ConflictThis argument of the record by calling ConflictLevelForMainRecord (see ctXxxxx enums) | ||
|- align="left" style="background-color: #F8F8F8" | |||
| scope="row" | <b>ConflictAllForNode</b> || TConflictThis || node : IwbElement || Gets the ConflictAll argument of the record by calling ConflictLevelForMainRecord (see ctXxxxx enums) | |||
| | |- align="left" style="background-color: #EEEEEE" | ||
| scope="row" | <b>ConflictThisForMainRecord</b> || TConflictThis || record : IwbMainRecord || Gets the ConflictThis argument of the record by calling ConflictLevelForMainRecord (see ctXxxxx enums) | |||
|- align="left" style="background-color: #F8F8F8" | |||
| scope="row" | <b>ConflictThisForNode</b> || TConflictThis || node : IwbElement || Gets the ConflictAll argument of the record by calling ConflictLevelForMainRecord (see ctXxxxx enums) | |||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>ContainingMainRecord</b> || IwbMainRecord || element : IwbElement || | ||
| | |- align="left" style="background-color: #F8F8F8" | ||
| | | scope="row" | <b>DefType</b> || TwbDefType || element : IInterface || returns the IwbElement::DefType (see dtXxxx enums) | ||
|- align="left" style="background-color: #EEEEEE" | |||
|- | | scope="row" | <b>ElementAssign</b> || IwbElement || container : IwbContainer , aInder : integer, [element : IwbElement], aOnlySK : boolean || Adds a new element to the container | ||
|- align="left" style="background-color: #F8F8F8" | |||
| | | scope="row" | <b>ElementByIndex</b> || IwbElement || container : IwbContainer , index : integer || Gets an element in the container by index | ||
| | |- align="left" style="background-color: #EEEEEE" | ||
| | | scope="row" | <b>ElementByName</b> || IwbElement || container : IwbContainer , name : string || Gets an element in the container by name | ||
|- align="left" style="background-color: #F8F8F8" | |||
|- | | scope="row" | <b>ElementByPath</b> || IwbElement || container : IwbContainer , path : string || Gets an element in the container by path | ||
|- align="left" style="background-color: #EEEEEE" | |||
| scope="row" | <b>ElementBySignature</b> || IwbElement || container : IwbContainer , signature : string || Gets an element in the container by its signature | |||
|- align="left" style="background-color: #F8F8F8" | |||
| scope="row" | <b>ElementCount</b> || integer || container : IwbContainer || Returns the number of elements in a container | |||
|- align="left" style="background-color: #EEEEEE" | |||
| scope="row" | <b>ElementExists</b> || boolean || container : IwbContainer , name : string || Checks if the name of the element already exist in the container | |||
|- align="left" style="background-color: #F8F8F8" | |||
| | | scope="row" | <b>ElementType</b> || TwbElementType || element : IwbElement || Returns the ElementType of the element | ||
| | |- align="left" style="background-color: #EEEEEE" | ||
| | | scope="row" | <b>Equals</b> || boolean || element1 : IwbElement , element2 : IwbElement || Compares both elements by their ElementID | ||
|- align="left" style="background-color: #F8F8F8" | |||
|- | | scope="row" | <b>FileByIndex</b> || IwbFile || index : integer || Gets the file at the specified index | ||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>FileByLoadOrder</b> || IwbFile || loadorder : integer || Gets the file at the specified load order | ||
| | |- align="left" style="background-color: #F8F8F8" | ||
| | | scope="row" | <b>FileFormIDtoLoadOrderFormID</b> || cardinal || file : IwbFile , formid : string/cardinal || | ||
|- align="left" style="background-color: #EEEEEE" | |||
|- | | scope="row" | <b>FindChildGroup</b> || IwbGroupRecord || group : IwbGroupRecord , aType : integer , aMainRecord : IwbMainRecord || | ||
|- align="left" style="background-color: #F8F8F8" | |||
| boolean | | scope="row" | <b>FixedFormID</b> || cardinal || aMainRecord : IwbMainRecord || | ||
| | |- align="left" style="background-color: #EEEEEE" | ||
| scope="row" | <b>FormID</b> || cardinal || aMainRecord : IwbMainRecord || Obtains the FormID of the record | |||
|- align="left" style="background-color: #F8F8F8" | |||
| | | scope="row" | <b>FullPath</b> || string || element : IwbElement || | ||
|- align="left" style="background-color: #EEEEEE" | |||
| scope="row" | <b>GetContainer</b> || IwbContainer || element : IwbElement || Gets the container of the element | |||
|- align="left" style="background-color: #F8F8F8" | |||
| scope="row" | <b>GetEditValue</b> || string || element : IwbElement || Gets the element's value represented as text | |||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>GetElementEditValues</b> || string || element : IwbElement , name : string || Gets the element's value represented as text | ||
|- align="left" style="background-color: #F8F8F8" | |||
| | | scope="row" | <b>GetElementNativeValues</b> || variant || element : IwbElement , name : string || Gets the element's native value | ||
| | |- align="left" style="background-color: #EEEEEE" | ||
| | | scope="row" | <b>GetFile</b> || IwbFile || element : IwbElement || Gets the file that defines the element | ||
|- align="left" style="background-color: #F8F8F8" | |||
|- | | scope="row" | <b>GetFileName</b> || string || file : IwbFile || Obtains the filename of the plugin file | ||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>GetFormVersion</b> || cardinal || mainrecord : IwbMainRecord || | ||
| record : IwbMainRecord , | |- align="left" style="background-color: #F8F8F8" | ||
| | | scope="row" | <b>GetIsDeleted</b> || boolean || mainrecord : IwbMainRecord || Indicates if the record has been deleted | ||
|- align="left" style="background-color: #EEEEEE" | |||
|- | | scope="row" | <b>GetIsESM</b> || boolean || file : IwbFile || Indicates if the plugin is an ESM file | ||
|- align="left" style="background-color: #F8F8F8" | |||
| | | scope="row" | <b>GetIsInitiallyDisabled</b> || boolean || mainrecord : IwbMainRecord || | ||
| | |- align="left" style="background-color: #EEEEEE" | ||
| | | scope="row" | <b>GetIsPersistent</b> || boolean || mainrecord : IwbMainRecord || | ||
|- align="left" style="background-color: #F8F8F8" | |||
| | | scope="row" | <b>GetIsVisibleWhenDistant</b> || boolean || mainrecord : IwbMainRecord || | ||
|- align="left" style="background-color: #EEEEEE" | |||
| IwbMainRecord | | scope="row" | <b>GetLoadOrder</b> || cardinal || file : IwbFile || Gets the global load order of the file | ||
| | |- align="left" style="background-color: #F8F8F8" | ||
| | | scope="row" | <b>GetLoadOrderFormID</b> || cardinal || mainrecord : IwbMainRecord || Obtains the FormID with the current load order applied | ||
|- align="left" style="background-color: #EEEEEE" | |||
|- | | scope="row" | <b>GetNativeValue</b> || variant || element : IwbElement || Gets the element's native value | ||
|- align="left" style="background-color: #F8F8F8" | |||
| | | scope="row" | <b>GroupBySignature</b> || || file : IwbFile , signature : string || | ||
| | |- align="left" style="background-color: #EEEEEE" | ||
| | | scope="row" | <b>GroupLabel</b> || cardinal || group : IwbGroupRecord || | ||
|- align="left" style="background-color: #F8F8F8" | |||
|- | | scope="row" | <b>GroupType</b> || integer || group : IwbGroupRecord || | ||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>HasGroup</b> || boolean || file : IwbFile , signature : string || | ||
| | |- align="left" style="background-color: #F8F8F8" | ||
| | | scope="row" | <b>HasMaster</b> || boolean || file : IwbFile , signature : string || Returns true if the file has a master file defined | ||
|- align="left" style="background-color: #EEEEEE" | |||
|- | | scope="row" | <b>IndexOf</b> || integer || container : IwbContainer , element : IwbElement || Gets the index of the element inside the collection | ||
|- align="left" style="background-color: #F8F8F8" | |||
| scope="row" | <b>InsertElement</b> || || container : IwbContainer , position : integer , element : IwbElement || Inserts an existing element inside a collection by position | |||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>IsEditable</b> || boolean || element : IwbElement || | ||
|- align="left" style="background-color: #F8F8F8" | |||
| scope="row" | <b>IsInjected</b> || boolean || element : IwbElement || | |||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>IsMaster</b> || boolean || record : IwbMainRecord || | ||
| | |- align="left" style="background-color: #F8F8F8" | ||
| Gets | | scope="row" | <b>IsWinningOverride</b> || boolean || record : IwbMainRecord || | ||
|- align="left" style="background-color: #EEEEEE" | |||
|- | | scope="row" | <b>JumpTo</b> || TConflictThis || record : IwbMainRecord , backward : boolean || Selects the specified record | ||
|- align="left" style="background-color: #F8F8F8" | |||
| scope="row" | <b>LastElement</b> || IwbElement || container : IwbContainer || Obtains the last element in the collection | |||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>LinksTo</b> || IwbElement || element : IwbElement || Obtains the referenced element | ||
|- align="left" style="background-color: #F8F8F8" | |||
| scope="row" | <b>LoadOrderFormIDtoFileFormID</b> || cardinal || file : IwbFile , aFormID : cardinal || | |||
|- align="left" style="background-color: #EEEEEE" | |||
| IwbElement | | scope="row" | <b>MainRecordByEditorID</b> || IwbMainRecord || group : IwbGroupRecord || Does not work for every case because its inefficient | ||
| | |- align="left" style="background-color: #F8F8F8" | ||
| Gets | | scope="row" | <b>Master</b> || IInterface || record : IwbMainRecord || | ||
|- align="left" style="background-color: #EEEEEE" | |||
|- | | scope="row" | <b>MasterByIndex</b> || IInterface || file : IwbFile , index : integer || | ||
|- align="left" style="background-color: #F8F8F8" | |||
| | | scope="row" | <b>MasterCount</b> || cardinal || file : IwbFile || | ||
| | |- align="left" style="background-color: #EEEEEE" | ||
| | | scope="row" | <b>MasterOrSelf</b> || IwbMainRecord || record : IwbMainRecord || | ||
|- align="left" style="background-color: #F8F8F8" | |||
|- | | scope="row" | <b>MoveDown</b> || || element : IwbElement || Moves the element down | ||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>MoveUp</b> || || element : IwbElement || Moves the element up | ||
| | |- align="left" style="background-color: #F8F8F8" | ||
| | | scope="row" | <b>Name</b> || || element : IwbElement || Obtains the name of the element | ||
|- align="left" style="background-color: #EEEEEE" | |||
|- | | scope="row" | <b>OverrideByIndex</b> || IwbMainRecord || record : IwbMainRecord , index : integer || | ||
|- align="left" style="background-color: #F8F8F8" | |||
| | | scope="row" | <b>OverrideCount</b> || cardinal || record : IwbMainRecord || | ||
| element : IwbElement | |- align="left" style="background-color: #EEEEEE" | ||
| | | scope="row" | <b>Path</b> || string || element : IwbElement || | ||
|- align="left" style="background-color: #F8F8F8" | |||
|- | | scope="row" | <b>RecordByEditorID</b> || IwbMainRecord || file : IwbFile , editorid : string || | ||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>RecordByFormID</b> || IwbMainRecord || file : IwbFile , formid : integer , aAllowInjected : boolean || | ||
|- align="left" style="background-color: #F8F8F8" | |||
| scope="row" | <b>RecordByIndex</b> || IwbMainRecord || file : IwbFile , index : integer || | |||
|- align="left" style="background-color: #EEEEEE" | |||
|- | | scope="row" | <b>RecordCount</b> || cardinal || file : IwbFile || | ||
|- align="left" style="background-color: #F8F8F8" | |||
| scope="row" | <b>ReferencedByCount</b> || cardinal || record : IwbMainRecord || | |||
|- align="left" style="background-color: #EEEEEE" | |||
| scope="row" | <b>ReferencedByIndex</b> || IwbMainRecord || record : IwbMainRecord , index : integer || | |||
|- align="left" style="background-color: #F8F8F8" | |||
| | | scope="row" | <b>Remove</b> || || element : IwbElement || | ||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>RemoveByIndex</b> || IwbElement || container : IwbContainer , index : integer , aMarkModified : boolean || | ||
| | |- align="left" style="background-color: #F8F8F8" | ||
| | | scope="row" | <b>RemoveElement</b> || IwbElement || container : IwbContainer , element : IwbElement || | ||
|- align="left" style="background-color: #EEEEEE" | |||
|- | | scope="row" | <b>RemoveNode</b> || boolean || node : IwbElement || Removes the node from the file | ||
|- align="left" style="background-color: #F8F8F8" | |||
| scope="row" | <b>ResourceCopy</b> || || container : IwbContainer , fileName : string , pathOut : string , containerIndex : integer || | |||
|- align="left" style="background-color: #EEEEEE" | |||
| scope="row" | <b>ResourceCount</b> || cardinal || container : IwbContainer , aFileName : string , containers : TStrings || | |||
|- align="left" style="background-color: #F8F8F8" | |||
| | | scope="row" | <b>ResourceExists</b> || boolean || container : IwbContainer , aFileName : string || | ||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>ResourceList</b> || || container : IwbContainer , aContainerName : string , containers : TStrings || | ||
| | |- align="left" style="background-color: #F8F8F8" | ||
| | | scope="row" | <b>ReverseElements</b> || || container : IwbContainer || | ||
|- align="left" style="background-color: #EEEEEE" | |||
|- | | scope="row" | <b>SetEditValue</b> || || element : IwbElement , value : string || Sets the value of the element as string | ||
|- align="left" style="background-color: #F8F8F8" | |||
| | | scope="row" | <b>SetElementEditValues</b> || || container : IwbContainer , path : string , value : string || Sets the value as a string of the element by its path | ||
| | |- align="left" style="background-color: #EEEEEE" | ||
| | | scope="row" | <b>SetElementNativeValues</b> || || container : IwbContainer , path : string , value : variant || Sets the native value of the element by its path | ||
|- align="left" style="background-color: #F8F8F8" | |||
|- | | scope="row" | <b>SetFormVersion</b> || || record : IwbMainRecord , version : integer || | ||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>SetIsDeleted</b> || || record : IwbMainRecord , value : boolean || | ||
| | |- align="left" style="background-color: #F8F8F8" | ||
| | | scope="row" | <b>SetIsESM</b> || || file : IwbFile , value : boolean || | ||
|- align="left" style="background-color: #EEEEEE" | |||
|- | | scope="row" | <b>SetIsInitiallyDisabled</b> || || record : IwbMainRecord , value : boolean || | ||
|- align="left" style="background-color: #F8F8F8" | |||
| scope="row" | <b>SetIsPersistent</b> || || record : IwbMainRecord , value : boolean || | |||
|- align="left" style="background-color: #EEEEEE" | |||
| scope="row" | <b>SetIsVisibleWhenDistant</b> || || record : IwbMainRecord , value : boolean || | |||
|- align="left" style="background-color: #F8F8F8" | |||
| | | scope="row" | <b>SetLoadOrderFormID</b> || || record : IwbMainRecord , loadOrderFormId : cardinal || | ||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>SetNativeValue</b> || || element : IwbElement , value : variant || Sets the native value of the element | ||
| | |- align="left" style="background-color: #F8F8F8" | ||
| | | scope="row" | <b>ShortName</b> || string || element : IwbElement || Gets the short name of the element | ||
|- align="left" style="background-color: #EEEEEE" | |||
|- | | scope="row" | <b>Signature</b> || string || record : IwbMainRecord || | ||
|- align="left" style="background-color: #F8F8F8" | |||
| | | scope="row" | <b>SortKey</b> || string || element : IwbElement, aExtended: boolean || | ||
| | |- align="left" style="background-color: #EEEEEE" | ||
| | | scope="row" | <b>SortMasters</b> || || file : IwbFile || | ||
|- align="left" style="background-color: #F8F8F8" | |||
|- | | scope="row" | <b>wbCopyElementToFile</b> || IwbElement || element : IwbElement , file : IwbFile , aAsNew : boolean , aDeepCopy : boolean || | ||
|- align="left" style="background-color: #EEEEEE" | |||
| | | scope="row" | <b>wbCopyElementToRecord</b> || IwbElement || element : IwbElement , aMainRecord : IwbMainRecord , aAsNew : boolean , aDeepCopy : boolean || | ||
| | |- align="left" style="background-color: #F8F8F8" | ||
| | | scope="row" | <b>WinningOverride</b> || boolean || record : IwbMainRecord || | ||
|- | |||
| | |||
| element : IwbElement | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| file : IwbFile , | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| element : IwbElement | |||
| Gets the element's | |||
|- | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| file : IwbFile | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| boolean | |||
| | |||
| | |||
|- | |||
| boolean | |||
| | |||
| | |||
|- | |||
| boolean | |||
| | |||
| | |||
|- | |||
| boolean | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| file : IwbFile , | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| record : IwbMainRecord | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
| | |||
| | |||
| record : IwbMainRecord | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| file : IwbFile , | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
| | |||
| | |||
|- | |||
| | |||
|} | |} |
Revision as of 13:16, 20 July 2013
Work in progress: To become the future home of scripting functions for TES5Edit. If you make scripts for TES5Edit please contribute to this page.
TES5Edit implements a script engine based on pascal syntax. The following table enumerates the functions exported by TES5Edit to the script engine that allows interacting with the editor's elements to perform various tasks such as finding records, fixing record conflicts, etc.
The information in the table is not complete so please contribute by explaining these functions, their uses and by fixing mistakes in this information.
The types described by this table such as IwbElement, IwbFile, etc.. are internal and not directly accessible but instead the script engine receives a generic type named IInterface which is common to every object type returned by TES5Edit. The reason the internal types are shown in this table is because some functions expect references to specific types even if the object reference is being hold by the generic IInterface variable.
Function | Returns | Arguments | Description |
---|---|---|---|
Add | IwbElement | container : IwbContainer, name : string, silent = true : boolean | Implemented for main records etc. |
AddElement | container : IwbContainer , element : IwbElement | ||
AdditionalElementCount | integer | container : IwbContainer | |
AddMasterIfMissing | file : IwbFile , mastername : string | ||
AddMessage | message : string | Adds a message line into the TES5Edit output panel | |
AddNewFile | IwbFile | Adds a new file and returns its reference | |
AddRequiredElementMasters | IwbFile | aSourceElement : IwbElement , aTargetFile : IwbFile , aAsNew : boolean | Add the elements master into the target file. |
Assigned | element : IwbElement | ||
CanContainFormIDs | boolean | element : IwbElement | |
CanMoveDown | boolean | element : IwbElement | |
CanMoveUp | boolean | element : IwbElement | |
ChangeFormSignature | record : IwbMainRecord , signature : TwbSignature | ||
Check | boolean | element : IwbElement | |
ChildGroup | IwbGroupRecord | record : IwbMainRecord | |
ChildrenOf | IwbMainRecord | group : IwbGroupRecord | |
CleanMasters | file : IwbFile | ||
CompareExchangeFormID | boolean | mainrecord : IwbMainRecord , oldFormID : Cardinal , aNewFormID : Cardinal | |
ConflictAllForMainRecord | TConflictThis | record : IwbMainRecord | Gets the ConflictThis argument of the record by calling ConflictLevelForMainRecord (see ctXxxxx enums) |
ConflictAllForNode | TConflictThis | node : IwbElement | Gets the ConflictAll argument of the record by calling ConflictLevelForMainRecord (see ctXxxxx enums) |
ConflictThisForMainRecord | TConflictThis | record : IwbMainRecord | Gets the ConflictThis argument of the record by calling ConflictLevelForMainRecord (see ctXxxxx enums) |
ConflictThisForNode | TConflictThis | node : IwbElement | Gets the ConflictAll argument of the record by calling ConflictLevelForMainRecord (see ctXxxxx enums) |
ContainingMainRecord | IwbMainRecord | element : IwbElement | |
DefType | TwbDefType | element : IInterface | returns the IwbElement::DefType (see dtXxxx enums) |
ElementAssign | IwbElement | container : IwbContainer , aInder : integer, [element : IwbElement], aOnlySK : boolean | Adds a new element to the container |
ElementByIndex | IwbElement | container : IwbContainer , index : integer | Gets an element in the container by index |
ElementByName | IwbElement | container : IwbContainer , name : string | Gets an element in the container by name |
ElementByPath | IwbElement | container : IwbContainer , path : string | Gets an element in the container by path |
ElementBySignature | IwbElement | container : IwbContainer , signature : string | Gets an element in the container by its signature |
ElementCount | integer | container : IwbContainer | Returns the number of elements in a container |
ElementExists | boolean | container : IwbContainer , name : string | Checks if the name of the element already exist in the container |
ElementType | TwbElementType | element : IwbElement | Returns the ElementType of the element |
Equals | boolean | element1 : IwbElement , element2 : IwbElement | Compares both elements by their ElementID |
FileByIndex | IwbFile | index : integer | Gets the file at the specified index |
FileByLoadOrder | IwbFile | loadorder : integer | Gets the file at the specified load order |
FileFormIDtoLoadOrderFormID | cardinal | file : IwbFile , formid : string/cardinal | |
FindChildGroup | IwbGroupRecord | group : IwbGroupRecord , aType : integer , aMainRecord : IwbMainRecord | |
FixedFormID | cardinal | aMainRecord : IwbMainRecord | |
FormID | cardinal | aMainRecord : IwbMainRecord | Obtains the FormID of the record |
FullPath | string | element : IwbElement | |
GetContainer | IwbContainer | element : IwbElement | Gets the container of the element |
GetEditValue | string | element : IwbElement | Gets the element's value represented as text |
GetElementEditValues | string | element : IwbElement , name : string | Gets the element's value represented as text |
GetElementNativeValues | variant | element : IwbElement , name : string | Gets the element's native value |
GetFile | IwbFile | element : IwbElement | Gets the file that defines the element |
GetFileName | string | file : IwbFile | Obtains the filename of the plugin file |
GetFormVersion | cardinal | mainrecord : IwbMainRecord | |
GetIsDeleted | boolean | mainrecord : IwbMainRecord | Indicates if the record has been deleted |
GetIsESM | boolean | file : IwbFile | Indicates if the plugin is an ESM file |
GetIsInitiallyDisabled | boolean | mainrecord : IwbMainRecord | |
GetIsPersistent | boolean | mainrecord : IwbMainRecord | |
GetIsVisibleWhenDistant | boolean | mainrecord : IwbMainRecord | |
GetLoadOrder | cardinal | file : IwbFile | Gets the global load order of the file |
GetLoadOrderFormID | cardinal | mainrecord : IwbMainRecord | Obtains the FormID with the current load order applied |
GetNativeValue | variant | element : IwbElement | Gets the element's native value |
GroupBySignature | file : IwbFile , signature : string | ||
GroupLabel | cardinal | group : IwbGroupRecord | |
GroupType | integer | group : IwbGroupRecord | |
HasGroup | boolean | file : IwbFile , signature : string | |
HasMaster | boolean | file : IwbFile , signature : string | Returns true if the file has a master file defined |
IndexOf | integer | container : IwbContainer , element : IwbElement | Gets the index of the element inside the collection |
InsertElement | container : IwbContainer , position : integer , element : IwbElement | Inserts an existing element inside a collection by position | |
IsEditable | boolean | element : IwbElement | |
IsInjected | boolean | element : IwbElement | |
IsMaster | boolean | record : IwbMainRecord | |
IsWinningOverride | boolean | record : IwbMainRecord | |
JumpTo | TConflictThis | record : IwbMainRecord , backward : boolean | Selects the specified record |
LastElement | IwbElement | container : IwbContainer | Obtains the last element in the collection |
LinksTo | IwbElement | element : IwbElement | Obtains the referenced element |
LoadOrderFormIDtoFileFormID | cardinal | file : IwbFile , aFormID : cardinal | |
MainRecordByEditorID | IwbMainRecord | group : IwbGroupRecord | Does not work for every case because its inefficient |
Master | IInterface | record : IwbMainRecord | |
MasterByIndex | IInterface | file : IwbFile , index : integer | |
MasterCount | cardinal | file : IwbFile | |
MasterOrSelf | IwbMainRecord | record : IwbMainRecord | |
MoveDown | element : IwbElement | Moves the element down | |
MoveUp | element : IwbElement | Moves the element up | |
Name | element : IwbElement | Obtains the name of the element | |
OverrideByIndex | IwbMainRecord | record : IwbMainRecord , index : integer | |
OverrideCount | cardinal | record : IwbMainRecord | |
Path | string | element : IwbElement | |
RecordByEditorID | IwbMainRecord | file : IwbFile , editorid : string | |
RecordByFormID | IwbMainRecord | file : IwbFile , formid : integer , aAllowInjected : boolean | |
RecordByIndex | IwbMainRecord | file : IwbFile , index : integer | |
RecordCount | cardinal | file : IwbFile | |
ReferencedByCount | cardinal | record : IwbMainRecord | |
ReferencedByIndex | IwbMainRecord | record : IwbMainRecord , index : integer | |
Remove | element : IwbElement | ||
RemoveByIndex | IwbElement | container : IwbContainer , index : integer , aMarkModified : boolean | |
RemoveElement | IwbElement | container : IwbContainer , element : IwbElement | |
RemoveNode | boolean | node : IwbElement | Removes the node from the file |
ResourceCopy | container : IwbContainer , fileName : string , pathOut : string , containerIndex : integer | ||
ResourceCount | cardinal | container : IwbContainer , aFileName : string , containers : TStrings | |
ResourceExists | boolean | container : IwbContainer , aFileName : string | |
ResourceList | container : IwbContainer , aContainerName : string , containers : TStrings | ||
ReverseElements | container : IwbContainer | ||
SetEditValue | element : IwbElement , value : string | Sets the value of the element as string | |
SetElementEditValues | container : IwbContainer , path : string , value : string | Sets the value as a string of the element by its path | |
SetElementNativeValues | container : IwbContainer , path : string , value : variant | Sets the native value of the element by its path | |
SetFormVersion | record : IwbMainRecord , version : integer | ||
SetIsDeleted | record : IwbMainRecord , value : boolean | ||
SetIsESM | file : IwbFile , value : boolean | ||
SetIsInitiallyDisabled | record : IwbMainRecord , value : boolean | ||
SetIsPersistent | record : IwbMainRecord , value : boolean | ||
SetIsVisibleWhenDistant | record : IwbMainRecord , value : boolean | ||
SetLoadOrderFormID | record : IwbMainRecord , loadOrderFormId : cardinal | ||
SetNativeValue | element : IwbElement , value : variant | Sets the native value of the element | |
ShortName | string | element : IwbElement | Gets the short name of the element |
Signature | string | record : IwbMainRecord | |
SortKey | string | element : IwbElement, aExtended: boolean | |
SortMasters | file : IwbFile | ||
wbCopyElementToFile | IwbElement | element : IwbElement , file : IwbFile , aAsNew : boolean , aDeepCopy : boolean | |
wbCopyElementToRecord | IwbElement | element : IwbElement , aMainRecord : IwbMainRecord , aAsNew : boolean , aDeepCopy : boolean | |
WinningOverride | boolean | record : IwbMainRecord |