Difference between revisions of "Lua:Class:Addresslist"

From Cheat Engine
Jump to navigation Jump to search
m
 
(14 intermediate revisions by 3 users not shown)
Line 1: Line 1:
The Addresslist class can be used to access information regarding the Cheat Engine table. It is commonly combined with [[MemoryRecord]].
+
[[Category:Lua]]
 +
Addresslist '''class''': ('''Inheritance''': ''[[Lua:Class:Panel|Panel]]''->''[[Lua:Class:WinControl|WinControl]]''->''[[Lua:Class:Control|Control]]''->''[[Lua:Class:Component|Component]]''->''[[Lua:Class:Object|Object]]'')
  
'''addresslist_getCount'''(addresslist)
+
The AddressList class represents the list of memory records (cheat entries) in Cheat Engine. 
 +
It provides access to all records, selection, appearance, and event handling for the address list.
  
Returns the ammount of entires in the addresslist.
+
== Properties ==
 +
{| class="wikitable" style="width:100%"
 +
! Property
 +
! Type
 +
! Description
 +
|-
 +
| LoadedTableVersion
 +
| Integer
 +
| Returns the tableVersion of the last loaded table.
 +
|-
 +
| Count
 +
| Integer
 +
| The number of records in the table.
 +
|-
 +
| SelCount
 +
| Integer
 +
| The number of records that are selected.
 +
|-
 +
| SelectedRecord
 +
| [[Lua:Class:MemoryRecord|MemoryRecord]]
 +
| The main selected record.
 +
|-
 +
| MemoryRecord[]
 +
| [[Lua:Class:MemoryRecord|MemoryRecord]]
 +
| Array to access the individual memory records.
 +
|-
 +
| [index]
 +
| [[Lua:Class:MemoryRecord|MemoryRecord]]
 +
| Default accessor for memory records.
 +
|-
 +
| CheckboxActiveSelectedColor
 +
| Color
 +
| Color for active and selected checkboxes.
 +
|-
 +
| CheckboxActiveColor
 +
| Color
 +
| Color for active checkboxes.
 +
|-
 +
| CheckboxSelectedColor
 +
| Color
 +
| Color for selected checkboxes.
 +
|-
 +
| CheckboxColor
 +
| Color
 +
| Color for checkboxes.
 +
|-
 +
| SelectedBackgroundColor
 +
| Color
 +
| Color for the selected row background.
 +
|-
 +
| SelectedSecondaryBackgroundColor
 +
| Color
 +
| Secondary color for selected row background.
 +
|-
 +
| ExpandSignColor
 +
| Color
 +
| Color for the expand/collapse sign.
 +
|-
 +
| IncreaseArrowColor
 +
| Color
 +
| Color for the increase arrow.
 +
|-
 +
| DecreaseArrowColor
 +
| Color
 +
| Color for the decrease arrow.
 +
|}
  
Example:
+
== Methods ==
  --Assume the table is empty
+
{| class="wikitable" style="width:100%"
  table=getAddressList()
+
! Method
  address=0x2031a3ac
+
! Parameters
  --Create 2 entires
+
! Returns
  for i=1,2 do
+
! Description
    mr=addresslist_createMemoryRecord(table)  
+
|-
    memoryrecord_setAddress(mr,address)  
+
| getCount
 
+
| None
    address=address+1
+
| Integer
  end
+
| Returns the number of memory records.
  entries=addresslist_getCount(table) -- entries now has the value 2
+
|-
 +
| getMemoryRecord
 +
| Integer (index)
 +
| [[Lua:Class:MemoryRecord|MemoryRecord]]
 +
| Returns the memory record at the given index.
 +
|-
 +
| getMemoryRecordByDescription
 +
| String (description)
 +
| [[Lua:Class:MemoryRecord|MemoryRecord]]
 +
| Returns the memory record with the given description.
 +
|-
 +
| getMemoryRecordByID
 +
| Integer (ID)
 +
| [[Lua:Class:MemoryRecord|MemoryRecord]]
 +
| Returns the memory record with the given ID.
 +
|-
 +
| createMemoryRecord
 +
| None
 +
| [[Lua:Class:MemoryRecord|MemoryRecord]]
 +
| Creates a generic cheat table entry and adds it to the list.
 +
|-
 +
| getSelectedRecords
 +
| None
 +
| Table of [[Lua:Class:MemoryRecord|MemoryRecord]]
 +
| Returns a table containing all the selected records.
 +
|-
 +
| doDescriptionChange
 +
| None
 +
| None
 +
| Shows the GUI window to change the description of the selected entry.
 +
|-
 +
| doAddressChange
 +
| None
 +
| None
 +
| Shows the GUI window to change the address of the selected entry.
 +
|-
 +
| doTypeChange
 +
| None
 +
| None
 +
| Shows the GUI window to change the type of the selected entries.
 +
|-
 +
| doValueChange
 +
| None
 +
| None
 +
| Shows the GUI window to change the value of the selected entries.
 +
|-
 +
| getSelectedRecord
 +
| None
 +
| [[Lua:Class:MemoryRecord|MemoryRecord]]
 +
| Gets the main selected memory record.
 +
|-
 +
| setSelectedRecord
 +
| [[Lua:Class:MemoryRecord|MemoryRecord]]
 +
| None
 +
| Sets the currently selected memory record (unselects all others).
 +
|-
 +
| disableAllWithoutExecute
 +
| None
 +
| None
 +
| Disables all memory records without executing their [Disable] section.
 +
|-
 +
| rebuildDescriptionCache
 +
| None
 +
| None
 +
| Rebuilds the description-to-record lookup table.
 +
|}
  
 +
== Events / Callbacks ==
 +
{| class="wikitable" style="width:100%"
 +
! Event
 +
! Parameters
 +
! Description
 +
|-
 +
| OnDescriptionChange
 +
| function(addresslist, memrec):boolean
 +
| Called when the user initiates a description column change on a record. Return true if you handle it, false for normal behaviour.
 +
|-
 +
| OnAddressChange
 +
| function(addresslist, memrec):boolean
 +
| Called when the user initiates an address column change on a record. Return true if you handle it, false for normal behaviour.
 +
|-
 +
| OnTypeChange
 +
| function(addresslist, memrec):boolean
 +
| Called when the user initiates a type column change on a record. Return true if you handle it, false for normal behaviour.
 +
|-
 +
| OnValueChange
 +
| function(addresslist, memrec):boolean
 +
| Called when the user initiates a value column change on a record. Return true if you handle it, false for normal behaviour.
 +
|-
 +
| OnAutoAssemblerEdit
 +
| function(addresslist, memrec)
 +
| Called when the user initiates a memory record AA script edit. This function will be responsible for changing the memory record.
 +
|}
  
'''addresslist_getMemoryRecord'''(addresslist, index)
+
== Other Functions ==
 +
* '''MouseHighlightedRecord()''' — Returns the memory record that the mouse points at, or nil if nothing.
  
Returns the [[MemoryRecord]] entry. The first object is indexed by 0.
+
== Examples ==
 +
<pre>
 +
-- Print all memory record descriptions
 +
for i = 0, AddressList.Count - 1 do
 +
  print(AddressList[i].Description)
 +
end
  
Example:
+
-- Create a new memory record
  table=getAddressList()
+
local newrec = AddressList:createMemoryRecord()
  memory_record1=addresslist_getMemoryRecord(table,0)
+
newrec.Description = "My New Entry"
 +
newrec.Address = "00400000"
  
 +
-- Get all selected records
 +
local selected = AddressList:getSelectedRecords()
 +
for i, rec in ipairs(selected) do
 +
  print("Selected:", rec.Description)
 +
end
  
'''addresslist_getMemoryRecordByDescription'''(addresslist, string)
+
-- Change the selected record
 +
AddressList:setSelectedRecord(AddressList[0])
 +
</pre>
  
Returns the [[MemoryRecord]] entry matched by the string. The description has to be an exact match, but is case-insensitive
+
{{LuaSeeAlso}}
  
Example:
+
=== Related Functions ===
  --Assume we have a entry in the cheat table with the description "Health"
+
* [[Lua:getMainForm|getMainForm]]
  table=getAddressList()
+
* [[Lua:getAddressList|getAddressList]]
  memory_record=addresslist_getMemoryRecordByDescription(table,"Health")
 
  
 
+
=== Related Classes ===
'''addresslist_getMemoryRecordByID'''(addresslist, ID)
+
* [[Lua:Class:MemoryRecord|MemoryRecord]]
 
 
Returns the [[MemoryRecord]] entry matched by the unique ID.
 
 
 
Example:
 
  --Assume we have a entry in the cheat table with the description "Health"
 
  table=getAddressList()
 
  id=memoryrecord_getID(addresslist_getMemoryRecordByDescription(table,"Health"))
 
  memory_record=addresslist_getMemoryRecordByID(table,id)
 
 
 
 
 
'''addresslist_createMemoryRecord'''(addresslist)
 
 
 
Creates an empty memory record at the end of the addresslist.
 
This function also returns the empty [[MemoryRecord]] entry, which can be used to immediately access the [[MemoryRecord]].
 
 
 
Example:
 
  --Assume we have a entry in the cheat table with the description "Health"
 
  table=getAddressList()
 
  memory_record=addresslist_createMemoryRecord(table)
 
  memoryrecord_setAddress(memory_record,0x00400000)
 
 
 
 
 
 
 
----
 
Don't know what these are:
 
 
 
'''addresslist_getSelectedRecords'''(addresslist)
 
Returns a array of selected Cheat Table entires. (??)
 
 
 
'''addresslist_doDescriptionChange'''(addresslist)
 
Change description(??)
 
 
 
'''addresslist_doAddressChange'''(addresslist)
 
 
 
'''addresslist_doTypeChange'''(addresslist)
 
 
 
'''addresslist_doValueChange'''(addresslist)
 
 
 
'''addresslist_getSelectedRecord'''(addresslist)
 
 
 
'''addresslist_setSelectedRecord'''(addresslist)
 

Latest revision as of 13:46, 11 July 2025

Addresslist class: (Inheritance: Panel->WinControl->Control->Component->Object)

The AddressList class represents the list of memory records (cheat entries) in Cheat Engine. It provides access to all records, selection, appearance, and event handling for the address list.

Properties[edit]

Property Type Description
LoadedTableVersion Integer Returns the tableVersion of the last loaded table.
Count Integer The number of records in the table.
SelCount Integer The number of records that are selected.
SelectedRecord MemoryRecord The main selected record.
MemoryRecord[] MemoryRecord Array to access the individual memory records.
[index] MemoryRecord Default accessor for memory records.
CheckboxActiveSelectedColor Color Color for active and selected checkboxes.
CheckboxActiveColor Color Color for active checkboxes.
CheckboxSelectedColor Color Color for selected checkboxes.
CheckboxColor Color Color for checkboxes.
SelectedBackgroundColor Color Color for the selected row background.
SelectedSecondaryBackgroundColor Color Secondary color for selected row background.
ExpandSignColor Color Color for the expand/collapse sign.
IncreaseArrowColor Color Color for the increase arrow.
DecreaseArrowColor Color Color for the decrease arrow.

Methods[edit]

Method Parameters Returns Description
getCount None Integer Returns the number of memory records.
getMemoryRecord Integer (index) MemoryRecord Returns the memory record at the given index.
getMemoryRecordByDescription String (description) MemoryRecord Returns the memory record with the given description.
getMemoryRecordByID Integer (ID) MemoryRecord Returns the memory record with the given ID.
createMemoryRecord None MemoryRecord Creates a generic cheat table entry and adds it to the list.
getSelectedRecords None Table of MemoryRecord Returns a table containing all the selected records.
doDescriptionChange None None Shows the GUI window to change the description of the selected entry.
doAddressChange None None Shows the GUI window to change the address of the selected entry.
doTypeChange None None Shows the GUI window to change the type of the selected entries.
doValueChange None None Shows the GUI window to change the value of the selected entries.
getSelectedRecord None MemoryRecord Gets the main selected memory record.
setSelectedRecord MemoryRecord None Sets the currently selected memory record (unselects all others).
disableAllWithoutExecute None None Disables all memory records without executing their [Disable] section.
rebuildDescriptionCache None None Rebuilds the description-to-record lookup table.

Events / Callbacks[edit]

Event Parameters Description
OnDescriptionChange function(addresslist, memrec):boolean Called when the user initiates a description column change on a record. Return true if you handle it, false for normal behaviour.
OnAddressChange function(addresslist, memrec):boolean Called when the user initiates an address column change on a record. Return true if you handle it, false for normal behaviour.
OnTypeChange function(addresslist, memrec):boolean Called when the user initiates a type column change on a record. Return true if you handle it, false for normal behaviour.
OnValueChange function(addresslist, memrec):boolean Called when the user initiates a value column change on a record. Return true if you handle it, false for normal behaviour.
OnAutoAssemblerEdit function(addresslist, memrec) Called when the user initiates a memory record AA script edit. This function will be responsible for changing the memory record.

Other Functions[edit]

  • MouseHighlightedRecord() — Returns the memory record that the mouse points at, or nil if nothing.

Examples[edit]

-- Print all memory record descriptions
for i = 0, AddressList.Count - 1 do
  print(AddressList[i].Description)
end

-- Create a new memory record
local newrec = AddressList:createMemoryRecord()
newrec.Description = "My New Entry"
newrec.Address = "00400000"

-- Get all selected records
local selected = AddressList:getSelectedRecords()
for i, rec in ipairs(selected) do
  print("Selected:", rec.Description)
end

-- Change the selected record
AddressList:setSelectedRecord(AddressList[0])

See also[edit]

Related Functions[edit]

Related Classes[edit]