Difference between revisions of "Lua"
(→Screen) |
|||
(14 intermediate revisions by 7 users not shown) | |||
Line 9: | Line 9: | ||
* [[Lua:TrainerOrigin|TrainerOrigin]]: A variable that contains the path of the trainer that launched cheat engine (Only set when launched as a trainer) | * [[Lua:TrainerOrigin|TrainerOrigin]]: A variable that contains the path of the trainer that launched cheat engine (Only set when launched as a trainer) | ||
* [[Lua:process|process]]: A variable that contains the main modulename of the currently opened process | * [[Lua:process|process]]: A variable that contains the main modulename of the currently opened process | ||
− | * [[Lua:MainForm|MainForm]]: The main | + | * [[Lua:MainForm|MainForm]]: The main Cheat Engine gui |
− | * [[Lua:AddressList|AddressList]]: The address list of the main | + | * [[Lua:AddressList|AddressList]]: The address list of the main Cheat Engine gui |
== Variables == | == Variables == | ||
− | * [[Lua: | + | * [[Lua:Debug_Variables|Debug Variables]] |
** EFLAGS | ** EFLAGS | ||
** '''32/64-bit''': EAX, EBX, ECX, EDX, EDI, ESI, EBP, ESP, EIP | ** '''32/64-bit''': EAX, EBX, ECX, EDX, EDI, ESI, EBP, ESP, EIP | ||
** '''64-bit only''': RAX, RBX, RCX, RDX, RDI, RSI, RBP, RSP, RIP, R8, R9, R10, R11, R12, R13, R14, R15 : The value of the register | ** '''64-bit only''': RAX, RBX, RCX, RDX, RDI, RSI, RBP, RSP, RIP, R8, R9, R10, R11, R12, R13, R14, R15 : The value of the register | ||
− | |||
= Functions = | = Functions = | ||
Line 26: | Line 25: | ||
* [[Lua:getAddressList|getAddressList]]: Returns the cheat table [[Lua:Class:Addresslist|Addresslist]] object | * [[Lua:getAddressList|getAddressList]]: Returns the cheat table [[Lua:Class:Addresslist|Addresslist]] object | ||
* [[Lua:findTableFile|findTableFile]]: Returns a [[Lua:Class:TableFile|TableFile]] stored in the cheat table | * [[Lua:findTableFile|findTableFile]]: Returns a [[Lua:Class:TableFile|TableFile]] stored in the cheat table | ||
+ | * [[Lua:createTableFile|createTableFile]]: Add a new file to a cheat table | ||
* [[Lua:loadTable|loadTable]]: Loads a ".ct" or ".cetrainer" file or stream | * [[Lua:loadTable|loadTable]]: Loads a ".ct" or ".cetrainer" file or stream | ||
* [[Lua:saveTable|saveTable]]: Saves the current table | * [[Lua:saveTable|saveTable]]: Saves the current table | ||
− | |||
== Trainers == | == Trainers == | ||
Line 115: | Line 114: | ||
* [[Lua:mapMemory|mapMemory]]: Maps a specific address to the usermode context from the given PID to the given PID | * [[Lua:mapMemory|mapMemory]]: Maps a specific address to the usermode context from the given PID to the given PID | ||
* [[Lua:unmapMemory|unmapMemory]]: | * [[Lua:unmapMemory|unmapMemory]]: | ||
− | + | * [[Lua:createMemoryStream|createMemoryStream]]: | |
These functions read/write memory from the opened process. | These functions read/write memory from the opened process. | ||
Line 160: | Line 159: | ||
** [[Lua:readSmallInteger|readSmallInteger]], [[Lua:readInteger|readInteger]], [[Lua:readSmallIntegerLocal|readSmallIntegerLocal]], [[Lua:readIntegerLocal|readIntegerLocal]] can also have second boolean parameter. If true, value will be signed. | ** [[Lua:readSmallInteger|readSmallInteger]], [[Lua:readInteger|readInteger]], [[Lua:readSmallIntegerLocal|readSmallIntegerLocal]], [[Lua:readIntegerLocal|readIntegerLocal]] can also have second boolean parameter. If true, value will be signed. | ||
− | == | + | == Conversions == |
− | * [[Lua:ansiToUtf8|ansiToUtf8]]: Converts a string in | + | * [[Lua:ansiToUtf8|ansiToUtf8]]: Converts a string in ANSI encoding to UTF8 |
− | * [[Lua:utf8ToAnsi|utf8ToAnsi]]: Converts a string in UTF8 encoding to | + | * [[Lua:utf8ToAnsi|utf8ToAnsi]]: Converts a string in UTF8 encoding to ANSI |
− | * [[Lua:stringToMD5String|stringToMD5String]]: Returns an | + | * [[Lua:stringToMD5String|stringToMD5String]]: Returns an MD5 hash string from the provided string |
* [[Lua:integerToUserData|integerToUserData]]: Converts a given integer to a userdata variable | * [[Lua:integerToUserData|integerToUserData]]: Converts a given integer to a userdata variable | ||
* [[Lua:userDataToInteger|userDataToInteger]]: Converts a given userdata variable to an integer | * [[Lua:userDataToInteger|userDataToInteger]]: Converts a given userdata variable to an integer | ||
Line 183: | Line 182: | ||
* [[Lua:byteTableToDouble|byteTableToDouble]]: Converts a bytetable to a double | * [[Lua:byteTableToDouble|byteTableToDouble]]: Converts a bytetable to a double | ||
* [[Lua:byteTableToString|byteTableToString]]: Converts a bytetable to a string | * [[Lua:byteTableToString|byteTableToString]]: Converts a bytetable to a string | ||
− | * [[Lua:byteTableToWideString|byteTableToWideString]]: Converts a bytetable to a widestring and | + | * [[Lua:byteTableToWideString|byteTableToWideString]]: Converts a bytetable to a widestring and converts that to a string |
Line 193: | Line 192: | ||
* [[Lua:bShr|bShr]]: Binary shift right | * [[Lua:bShr|bShr]]: Binary shift right | ||
* [[Lua:bNot|bNot]]: Binary not | * [[Lua:bNot|bNot]]: Binary not | ||
− | |||
== Input devices == | == Input devices == | ||
Line 220: | Line 218: | ||
* [[Lua:getScreenHeight|getScreenHeight]]: Returns the screen height | * [[Lua:getScreenHeight|getScreenHeight]]: Returns the screen height | ||
* [[Lua:getScreenWidth|getScreenWidth]]: Returns the screen width | * [[Lua:getScreenWidth|getScreenWidth]]: Returns the screen width | ||
+ | * [[Lua:getScreenDPI|getScreenDPI]]: Returns the screen DPI | ||
* [[Lua:getWorkAreaHeight|getWorkAreaHeight]]: Returns the work area height | * [[Lua:getWorkAreaHeight|getWorkAreaHeight]]: Returns the work area height | ||
* [[Lua:getWorkAreaWidth|getWorkAreaWidth]]: Returns the work area width | * [[Lua:getWorkAreaWidth|getWorkAreaWidth]]: Returns the work area width | ||
* [[Lua:getScreenCanvas|getScreenCanvas]]: Returns a Canvas object you can use to write to the screen (Note: Not as useful as you may think) | * [[Lua:getScreenCanvas|getScreenCanvas]]: Returns a Canvas object you can use to write to the screen (Note: Not as useful as you may think) | ||
* [[Lua:getPixel|getPixel]]: Returns the RGB value of the pixel at the specific screen coordinate | * [[Lua:getPixel|getPixel]]: Returns the RGB value of the pixel at the specific screen coordinate | ||
− | |||
== Sounds == | == Sounds == | ||
Line 423: | Line 421: | ||
== DBVM == | == DBVM == | ||
* [[Lua:dbvm_initialize|dbvm_initialize]]: Initializes the dbvm functions | * [[Lua:dbvm_initialize|dbvm_initialize]]: Initializes the dbvm functions | ||
+ | * [[Lua:dbvm_addMemory|dbvm_addMemory]]: Adds memory to DBVM | ||
* [[Lua:dbvm_readMSR|dbvm_readMSR]]: Reads the msr using dbvm (bypasses the driver) | * [[Lua:dbvm_readMSR|dbvm_readMSR]]: Reads the msr using dbvm (bypasses the driver) | ||
* [[Lua:dbvm_writeMSR|dbvm_writeMSR]]: Writes the msr using dbvm (bypasses the driver) | * [[Lua:dbvm_writeMSR|dbvm_writeMSR]]: Writes the msr using dbvm (bypasses the driver) | ||
* [[Lua:dbvm_getCR4|dbvm_getCR4]]: Returns the real Control Register 4 state | * [[Lua:dbvm_getCR4|dbvm_getCR4]]: Returns the real Control Register 4 state | ||
− | + | * [[Lua:dbvm_readPhysicalMemory|dbvm_readPhysicalMemory]]: Reads physical memory using DBVM | |
+ | * [[Lua:dbvm_writePhysicalMemory|dbvm_writePhysicalMemory]]: Writes physical memory using DBVM | ||
+ | * [[Lua:dbvm_watch_writes|dbvm_watch_writes]]: Starts memory region write monitoring | ||
+ | * [[Lua:dbvm_watch_reads|dbvm_watch_reads]]: Starts memory region read monitoring | ||
+ | * [[Lua:dbvm_watch_retrievelog|dbvm_watch_retrievelog]]: Receives the result of memory region monitoring | ||
+ | * [[Lua:dbvm_watch_disable|dbvm_watch_disable]]: Disables memory region monitoring | ||
+ | * [[Lua:dbvm_cloak_activate|dbvm_cloak_activate]]: Cloak a page so changes to it will become invisible | ||
+ | * [[Lua:dbvm_cloak_deactivate|dbvm_cloak_deactivate]]: Undo the cloak. Also undoes changes | ||
+ | * [[Lua:dbvm_cloak_readOriginal|dbvm_cloak_readOriginal]]: Read the memory that gets executed in a cloaked region | ||
+ | * [[Lua:dbvm_cloak_writeOriginal|dbvm_cloak_writeOriginal]]: Writes the memory that gets executed in a cloaked region | ||
+ | * [[Lua:dbvm_changeregonbp|dbvm_changeregonbp]] : Cloaks and sets a breakpoint at the given address and change registers when executed | ||
+ | * [[Lua:dbvm_removechangeregonbp|dbvm_removechangeregonbp]]: Removes a change reg on bp breakpoint | ||
+ | * [[Lua:dbvm_log_cr3_start|dbvm_log_cr3_start]] : Start logging CR3 values | ||
+ | * [[Lua:dbvm_log_cr3_stop|dbvm_log_cr3_stop]] : Stop logging CR3 values | ||
+ | * [[Lua:dbvm_speedhack_setSpeed|dbvm_speedhack_setSpeed]] : sets the systemwide speedhack | ||
+ | * [[Lua:dbvm_setTSCAdjust|dbvm_setTSCAdjust]] : Lets you specify what happens when a program tries to detect a virtual machine by calling rdtsc | ||
== Translation == | == Translation == | ||
Line 452: | Line 466: | ||
* [[Lua:shellExecute|shellExecute]]: Executes a given command | * [[Lua:shellExecute|shellExecute]]: Executes a given command | ||
* [[Lua:executeCode|executeCode]]: Executes a stdcall function with 1 parameter at the given address in the target process and wait for it to return | * [[Lua:executeCode|executeCode]]: Executes a stdcall function with 1 parameter at the given address in the target process and wait for it to return | ||
+ | * [[Lua:executeCodeEx|executeCodeEx]]: | ||
* [[Lua:executeCodeLocal|executeCodeLocal]]: Executes a stdcall function with 1 parameter at the given address in the target process | * [[Lua:executeCodeLocal|executeCodeLocal]]: Executes a stdcall function with 1 parameter at the given address in the target process | ||
+ | * [[Lua:executeCodeLocalEx|executeCodeLocalEx]]: | ||
* [[Lua:onAPIPointerChange|onAPIPointerChange]]: Registers a callback when an api pointer is changed | * [[Lua:onAPIPointerChange|onAPIPointerChange]]: Registers a callback when an api pointer is changed | ||
* [[Lua:setAPIPointer|setAPIPointer]]: Sets the pointer of the given api to the given address | * [[Lua:setAPIPointer|setAPIPointer]]: Sets the pointer of the given api to the given address | ||
Line 463: | Line 479: | ||
* [[Lua:broadcastEnvironmentUpdate|broadcastEnvironmentUpdate]]: Call this when you've changed the environment variables in the registry | * [[Lua:broadcastEnvironmentUpdate|broadcastEnvironmentUpdate]]: Call this when you've changed the environment variables in the registry | ||
* [[Lua:getApplication|getApplication]]: Returns the application object (the titlebar) | * [[Lua:getApplication|getApplication]]: Returns the application object (the titlebar) | ||
− | + | * [[Lua:getInternet|getInternet]]: Returns an internet class object. The string provided will be the name of the client provided | |
= Classes = | = Classes = | ||
Line 536: | Line 552: | ||
* [[Lua:Class:Object|Object]]: Most basic class. All classes inherit from this class | * [[Lua:Class:Object|Object]]: Most basic class. All classes inherit from this class | ||
* [[Lua:Class:PaintBox|PaintBox]]: | * [[Lua:Class:PaintBox|PaintBox]]: | ||
− | * [[Lua:Class: | + | * [[Lua:Class:PageControl|PageControl]]: This is an object that can hold multiple pages |
* [[Lua:Class:Panel|Panel]]: The Panel class is like a form which can contain visual components. | * [[Lua:Class:Panel|Panel]]: The Panel class is like a form which can contain visual components. | ||
* [[Lua:Class:Pen|Pen]]: The Pen class is part of the Canvas object. It's used to draw lines | * [[Lua:Class:Pen|Pen]]: The Pen class is part of the Canvas object. It's used to draw lines | ||
Line 569: | Line 585: | ||
* [[Lua:Class:TreeNodes|TreeNodes]]: | * [[Lua:Class:TreeNodes|TreeNodes]]: | ||
* [[Lua:Class:Treeview|Treeview]]: | * [[Lua:Class:Treeview|Treeview]]: | ||
− | * [[Lua:Class: | + | * [[Lua:Class:WinControl|WinControl]]: Base class for controls which can contain other controls. |
* [[Lua:Class:xmplayer|xmplayer]]: | * [[Lua:Class:xmplayer|xmplayer]]: | ||
Latest revision as of 13:51, 30 September 2023
Cheat Engine comes with an extensive set of Lua functions you can use inside cheat tables, trainers and standalone scripts.
Contents
- 1 Variables
- 2 Functions
- 2.1 Cheat table
- 2.2 Trainers
- 2.3 Protection
- 2.4 Scanning
- 2.5 Process
- 2.6 Threads
- 2.7 Handles
- 2.8 Addresses
- 2.9 Memory
- 2.10 Conversions
- 2.11 Input devices
- 2.12 Screen
- 2.13 Sounds
- 2.14 Text to Speech
- 2.15 Fonts
- 2.16 Forms and Windows
- 2.17 Cheat Engine
- 2.18 Lua
- 2.19 Types
- 2.20 Object-oriented
- 2.21 Assembly
- 2.22 Auto Assembler
- 2.23 Debugger
- 2.24 DBK
- 2.25 DBVM
- 2.26 Translation
- 2.27 Files
- 2.28 Structures
- 2.29 Miscellaneous
- 3 Classes
Variables[edit]
Globals[edit]
- TrainerOrigin: A variable that contains the path of the trainer that launched cheat engine (Only set when launched as a trainer)
- process: A variable that contains the main modulename of the currently opened process
- MainForm: The main Cheat Engine gui
- AddressList: The address list of the main Cheat Engine gui
Variables[edit]
- Debug Variables
- EFLAGS
- 32/64-bit: EAX, EBX, ECX, EDX, EDI, ESI, EBP, ESP, EIP
- 64-bit only: RAX, RBX, RCX, RDX, RDI, RSI, RBP, RSP, RIP, R8, R9, R10, R11, R12, R13, R14, R15 : The value of the register
Functions[edit]
Cheat table[edit]
These functions help manage the cheat table.
- getAddressList: Returns the cheat table Addresslist object
- findTableFile: Returns a TableFile stored in the cheat table
- createTableFile: Add a new file to a cheat table
- loadTable: Loads a ".ct" or ".cetrainer" file or stream
- saveTable: Saves the current table
Trainers[edit]
- registerEXETrainerFeature: Adds a new feature to the exe trainer generator window, and calls your function when the user builds an .exe trainer
- unregisterEXETrainerFeature: Unregisters the trainer feature
Protection[edit]
- activateProtection: Prevents basic memory scanners from opening the cheat engine process
- enableDRM: Prevents normal memory scanners from reading the Cheat Engine process (kernelmode)
- encodeFunction: Converts a given function into an encoded string that you can pass on to decodeFunction
- decodeFunction: Converts an encoded string back into a function
Scanning[edit]
These functions control Cheat Engine's scanning.
- AOBScan: Scans the currently opened process and returns a StringList object containing all the results
- getCurrentMemscan: Returns the currently active scan session as a MemScan object
Process[edit]
- createProcess: Creates a process with or without debugging
- openProcess: Causes cheat engine to open the given processname or id
- onOpenProcess: Called by CE when it opens a process (userdefined)
- getForegroundProcess: Returns the process ID of the process that is currently on top
- getOpenedProcessID: Returns the currently opened process
- getProcessIDFromProcessName: Returns a processid
- openFileAsProcess: Causes cheat engine to open the file with memory access as if it's a process
- saveOpenedFile: Saves the changes of the opened file
- setPointerSize: Sets the size cheat engine will deal with pointers in bytes. (Some 64-bit processes can only use 32-bit addresses)
- setAssemblerMode: Sets the assembler's bit size mode (0=32-bit, 1=64-bit)
- getProcesslist: Returns a processlist of the system
- getWindowlist: Returns the top-window list of the system
- pause: Pauses the current opened process
- unpause: Resumes the current opened process
- targetIs64Bit: Returns true if the target process is 64-bit, false if 32-bit
- enumModules: Returns a table containing information about each module in the current process, or the specified process ID
- closeRemoteHandle: Closes the handle of a process
Threads[edit]
- getCPUCount: Returns the number of CPU's
- getThreadlist: Fills a List object with the threadlist of the currently opened process
- inMainThread: Returns true if the current code is running inside the main thread (6.4+)
- synchronize: Calls the given function from the main thread. Returns the return value of the given function
- queue: Calls the given function from the main thread. Does not wait for the result
- checkSynchronize: Call this from an infinite loop in the main thread when using threading and synchronize calls
Handles[edit]
- getHandleList: Returns a table with all the handles in the system
Addresses[edit]
These functions help convert between memory addresses and symbols/CEAddressStrings.
- getAddress: Returns the address of a symbol. Can be a modulename or an export
- getAddressSafe: Returns the address of a symbol, or nil if not found. Similar to getAddress when errorOnLookup is false, but returns nil instead
- getNameFromAddress: Returns the given address in string form, returning the symbol representation if possible
- registerSymbol: Assign the specified symbolname to an address
- unregisterSymbol: Remove the name from the address
- getSymbolInfo: Returns a table as defined by the SymbolList class object (module name, search key, address, size)
- reinitializeSymbolhandler: Reinitializes the symbolhandler. E.g when new modules have been loaded
- inModule: Returns true if the given address is inside a module
- inSystemModule: Returns true if the given address is inside a system module
- getModuleSize: Returns the size of a given module (Use getAddress to get the base address)
- errorOnLookupFailure: Set whether address lookups will throw errors, or just return 0.
- registerSymbolLookupCallback: Registers a function to be called when a a symbol is parsed
- unregisterSymbolLookupCallback: Removes the callback
- registerAddressLookupCallback: Registers a function to be called when the name of an address is requested
- unregisterAddressLookupCallback: Removes the callback
- reinitializeDotNetSymbolhandler: Reinitializes only the DotNet part of the symbol list
Memory[edit]
- allocateMemory: Allocates some memory into the target process
- deAlloc: Frees allocated memory
- allocateSharedMemory: Creates a shared memory object of the given size if it doesn't exist yet
- createSection: Creates a 'section' in memory
- mapViewOfSection: Maps the section to memory
- unMapViewOfSection: Unmaps a section from memory
- copyMemory: Copies memory from the given address to the destination address
- allocateKernelMemory: Allocates a block of nonpaged memory and returns the address
- freeKernelMemory: Frees the given memory region
- mapMemory: Maps a specific address to the usermode context from the given PID to the given PID
- unmapMemory:
- createMemoryStream:
These functions read/write memory from the opened process.
Reading[edit]
- readBytes: Returns the bytes at the given address. If ReturnAsTable is true it will return a table instead of multiple bytes
- readSmallInteger: Reads a 16-bit integer from the specified address.
- readInteger: Reads a 32-bit integer from the specified address.
- readQword: Reads a 64-bit integer from the specified address.
- readPointer: In a 64-bit target this equals readQword, in a 32-bit target readInteger().
- readFloat: Reads a single precision floating point value from the specified address
- readDouble: Reads a double precision floating point value from the specified address
- readString: Reads a string from memory until it hits a 0-terminator. maxlength is just so you won't freeze for too long
- readRegionFromFile: Writes the given file to a specific address
- readBytesLocal: See readBytes but then it's for Cheat engine's memory
- readSmallIntegerLocal: Reads a 16-bit integer from the specified address in CE's memory
- readIntegerLocal: Reads a 32-bit integer from the specified address in CE's memory
- readQwordLocal: Reads a 64-bit integer from the specified address in CE's memory
- readPointerLocal: ReadQwordLocal/ReadIntegerLocal depending on the cheat engine build
- readFloatLocal: Reads a single precision floating point value from the specified address in CE's memory
- readDoubleLocal: Reads a double precision floating point value from the specified address in CE's memory
- readStringLocal: Reads a string from CE's memory until it hits a 0-terminator
Writing[edit]
- writeBytes: Write the given bytes to the given address from a table
- writeSmallInteger: Writes a 16-bit integer to the specified address. Returns true on success.
- writeInteger: Writes a 32-bit integer to the specified address. Returns true on success.
- writeQword: Write a 64-bit integer to the specified address. Returns true on success.
- writeFloat: Writes a single precision floating point to the specified address. Returns true on success.
- writeDouble: Writes a double precision floating point to the specified address. Returns true on success.
- writeString: Write a string to the specified address. Returns true on success.
- writeRegionToFile: Writes the given region to a file. Returns the number of bytes written.
- writeSmallIntegerLocal: Writes a 16-bit integer to the specified address in CE's memory. Returns true on success
- writeIntegerLocal: Writes a 32-bit integer to the specified address in CE's memory. Returns true on success
- writeQwordLocal: Writes a 64-bit integer to the specified address in CE's memory. Returns true on success
- writeFloatLocal: Writes a single precision floating point to the specified address in CE's memory. Returns true on success
- writeDoubleLocal: Writes a double precision floating point to the specified address in CE's memory. Returns true on success
- writeStringLocal: Write a string to the specified address. Returns true on success.
- writeBytesLocal: See writeBytes but then it's for Cheat Engine's memory
- readSmallInteger, readInteger, readSmallIntegerLocal, readIntegerLocal can also have second boolean parameter. If true, value will be signed.
Conversions[edit]
- ansiToUtf8: Converts a string in ANSI encoding to UTF8
- utf8ToAnsi: Converts a string in UTF8 encoding to ANSI
- stringToMD5String: Returns an MD5 hash string from the provided string
- integerToUserData: Converts a given integer to a userdata variable
- userDataToInteger: Converts a given userdata variable to an integer
To Byte Table[edit]
- wordToByteTable: Converts a word to a bytetable
- dwordToByteTable: Converts a dword to a bytetable
- qwordToByteTable: Converts a qword to a bytetable
- floatToByteTable: Converts a float to a bytetable
- doubleToByteTable: Converts a double to a bytetable
- stringToByteTable: Converts a string to a bytetable
- wideStringToByteTable: Converts a string to a widestring and converts that to a bytetable
From Byte Table[edit]
- byteTableToWord: Converts a bytetable to a word
- byteTableToDword: Converts a bytetable to a dword
- byteTableToQword: Converts a bytetable to a qword
- byteTableToFloat: Converts a bytetable to a float
- byteTableToDouble: Converts a bytetable to a double
- byteTableToString: Converts a bytetable to a string
- byteTableToWideString: Converts a bytetable to a widestring and converts that to a string
Binary[edit]
- bOr: Binary Or
- bXor: Binary Xor
- bAnd: Binary And
- bShl: Binary shift left
- bShr: Binary shift right
- bNot: Binary not
Input devices[edit]
These functions get/set keyboard/mouse input.
- getMousePos: Returns the X and Y coordinates of the mouse
- setMousePos: Sets the mouse position
- isKeyPressed: Returns true if the specified key is currently pressed
- keyDown: Causes the key to go into down state
- keyUp: Causes the key to go up
- doKeyPress: Simulates a key press
- mouse_event: The Windows' API "mouse_event". msdn.microsoft.com/en-us/library/windows/desktop/ms646260(v=vs.85).aspx
- setGlobalKeyPollInterval: Sets the global keypoll interval
- setGlobalDelayBetweenHotkeyActivation: Sets the minimum delay between the activation of the same hotey in milliseconds
Game Controller[edit]
- getXBox360ControllerState: Fetches the state of the connected XBox controller
- setXBox360ControllerVibration: Sets the speed of the left and right vibrating motor inside the controller
Clipboard[edit]
- writeToClipboard: Writes the given text to the clipboard
- readFromClipboard: Reads the text from the clipboard
Screen[edit]
- getScreenHeight: Returns the screen height
- getScreenWidth: Returns the screen width
- getScreenDPI: Returns the screen DPI
- getWorkAreaHeight: Returns the work area height
- getWorkAreaWidth: Returns the work area width
- getScreenCanvas: Returns a Canvas object you can use to write to the screen (Note: Not as useful as you may think)
- getPixel: Returns the RGB value of the pixel at the specific screen coordinate
Sounds[edit]
- playSound: Plays a sound file
- beep: Plays the fabulous beep/ping sound!
- speak: Speaks a given text using the given flags msdn.microsoft.com/en-us/library/speechplatform_speakflags.aspx
- speakEnglish: Will try the English voice by wrapping the given text into an XML statement specifying the English voice
xmplayer[edit]
- xmplayer_playXM: Plays the given filename using the xmplayer
- xmplayer_pause: Pauses the current xm audio file
- xmplayer_resume: Resumes the current xm audio file
- xmplayer_stop: Stops the current xm audio file
- xmplayer_isPlaying: Returns true if there is currently an xm audio file being played
Text to Speech[edit]
- speak: Speaks a given text.
- speakEnglish: Speaks a given text with English voice.
Fonts[edit]
- loadFontFromStream: Loads a font from a memory stream and returns an id (handle) to the font for use with unloadLoadedFont
- unloadLoadedFont: Unloads a font from a memory stream
Forms and Windows[edit]
- findWindow: Finds a window with the given classname and/or windowname
- getWindow: Gets a specific window based on the given window (Check MSDN getWindow for the command description)
- getWindowCaption: Returns the caption of the window
- getWindowClassName: Returns the classname of the window
- getWindowProcessID: Returns the processid of the process this window belongs to
- getForegroundWindow: Returns the windowhandle of the topmost window
- sendMessage: Sends a message to a window
- hookWndProc: Hooks a window's wndproc procedure
- unhookWndProc: Called when done with the hook from hookWndProc
Cheat Engine[edit]
These functions help manage Cheat Engine itself.
- getCEVersion: Returns a floating point value specifying the version of cheat engine
- getCheatEngineFileVersion: Returns the full version data of the cheat engine version. A raw integer, and a table containing major, minor, release and build
- getFreezeTimer: Returns the Timer object responsible for freezing values
- getUpdateTimer: Returns the Timer object responsible for updating the value list
- getCommonModuleList: Returns the commonModuleList StringList object
- getCheatEngineProcessID: Returns the processid of cheat engine
- cheatEngineIs64Bit: Returns true if Cheat Engine is 64-bit, false if 32-bit
- closeCE: Closes Cheat Engine
- getAutoAttachList: Returns the AutoAttach StringList object
- connectToCEServer: Connects to the given host and port. On success, most commands subsequent will be handled by the server
- supportCheatEngine: Will show an advertising window which will help keep the development of Cheat Engine going.
- fuckCheatEngine: Removes the ad window if it was showing
- getCheatEngineDir: Returns the folder Cheat Engine (or the trainer) is located at.
- getComment: Gets the userdefined comment at the specified address
- setComment: Sets a userdefined comment at the specifried address
- getHeader: Gets the userdefined header at the specified address
- setHeader: Sets the userdefined header at the specified address
- registerBinUtil: Registers a binutils toolset with Cheat Engine
- reloadSettingsFromRegistry: This will cause cheat engine to reload the settings from the registry and apply them
- loadPlugin: Loads the given plugin
- getSettings: Returns a settings object
Forms[edit]
- getFormCount: Returns the total number of forms assigned to the main CE application
- getForm: Returns the form at the specific index
- getMemoryViewForm: Returns the first Memoryview form class object
- getMainForm: Returns the first Mainform class object
- getSettingsForm: Returns the main settings form
- getLuaEngine: Returns the lua engine form object (Creates it if needed)
- unhideMainCEwindow: Shows the main Cheat Engine window
- hideAllCEWindows: Makes all normal Cheat Engine windows invisible (e.g trainer table)
- registerFormAddNotification: Registers a function to be called when a form is attached to Cheat Engine's form list
- unregisterFormAddNotification: unregister the FormAddNotification call back
Messages[edit]
- showMessage: Shows a message box with the given text
- messageDialog: Pops up a message box
- outputDebugString: Outputs a message using the windows OutputDebugString message
- processMessages: Lets the main eventhandler process the new messages (allows for new button clicks)
Input[edit]
- inputQuery: Shows a dialog where the user can input a string. This function returns the given string, or nil on cancel (CE6.4+)
Shortcuts[edit]
- shortCutToText: Returns the textual representation of the given shortcut value (integer) (6.4+)
- textToShortCut: Returns an shortcut integer that the given string represents. (6.4+)
- convertKeyComboToString: Returns a string representation of the given keys like the hot-key handler does
Speed Hack[edit]
- speedhack_setSpeed: Enables the speed hack if it was not active yet and sets the given speed
- speedhack_getSpeed: Returns the last set speed
Lua[edit]
These functions help manage Lua itself.
- resetLuaState: This will create a new Lua state that will be used.
- sleep: Pauses for the number of specified milliseconds
- createRef: Integer - Returns an integer reference that you can use with getRef
- getRef: Returns whatever the reference points out
- destroyRef: Removes the reference
Types[edit]
These functions help structure a process's memory into datatypes.
- onAutoGuess: Registers an function to be called whenever autoguess is used to predict a variable type.
- registerCustomTypeLua: Registers a custom type based on Lua functions.
- registerCustomTypeAutoAssembler: Registers a custom type based on an auto assembler script.
Object-oriented[edit]
These functions determine how a Lua object fits in the class hierarchy.
- inheritsFromObject: Returns true if given any class
- inheritsFromComponent: Returns true if the given object inherits from the Component class
- inheritsFromControl: Returns true if the given object inherits from the Control class
- inheritsFromWinControl: Returns true if the given object inherits from the WinControl class
Assembly[edit]
These functions help work with the x86 machine code as assembly.
- autoAssemble: Runs the auto assembler with the given text
- autoAssembleCheck: Checks the script for syntax errors. Returns true on succes, false with an error message on failure
- disassemble: Disassembles the given address and returns a string in the format of "address - bytes - opcode extra"
- splitDisassembledString: Returns 4 strings. The address, bytes, opcode and extra field
- getInstructionSize: Returns the size of an instruction
- getPreviousOpcode: Returns the address of the previous opcode (guess)
- registerAssembler: Registers a function to be called when the single line assembler is invoked to convert an instruction to a list of bytes
- unregisterAssembler: Unregisters the registered assembler
Auto Assembler[edit]
- registerAutoAssemblerCommand: Registers an auto assembler command to call the specified function
- unregisterAutoAssemblerCommand: Unregisters an auto assembler command
- registerAutoAssemblerPrologue: Registers a function to be called when the auto assembler is about to parse an auto assembler script
- unregisterAutoAssemblerPrologue: Unregisters an auto assembler prologue
- fullAccess: Changes the protection of a block of memory to writable and executable
Scripts[edit]
- registerAutoAssemblerTemplate: Registers a template for the auto assembler
- unregisterAutoAssemblerTemplate: Unregisters a template for the auto assembler
- generateCodeInjectionScript: Adds a default code injection script to the given script
- generateAOBInjectionScript: Adds an AOB injection script to the given script
- generateFullInjectionScript: Adds a Full Injection script to the given script
- generateAPIHookScript: Generates an auto assembler script which will hook the given address when executed
Debugger[edit]
These functions manage the debugger. See Lua Debugging.
- debug_isDebugging: Returns true if the debugger has been started
- debug_getCurrentDebuggerInterface: Returns the current debuggerinterface used (1=windows, 2=VEH 3=Kernel, nil=no debugging active)
- debug_canBreak: Returns true if there is a possibility the target can stop on a breakpoint. 6.4+
- debug_isBroken: Returns true if the debugger is currently halted on a thread
- debug_getBreakpointList: Returns a lua table containing all the breakpoint addresses
- debugProcess: Debugs the currently attached process
- debug_setBreakpoint: Sets a breakpoint of a specific size at the given address
- debugger_onBreakpoint: Called by CE when a breakpoint hits (userdefined)
- debug_removeBreakpoint: Removes a breakpoint
- debug_continueFromBreakpoint: Continues the debugger when it's halted on a breakpoint
- debug_setLastBranchRecording: Tells the kernelmode debugger to record the last few branches before the breakpoint got hit
- debug_getMaxLastBranchRecord: Returns the maximum number of branch records this cpu supports
- debug_getLastBranchRecord: Returns the value of the Last Branch Record at the given index (when handling a breakpoint)
- debugger_onModuleLoad: Called by CE when the windows debugger interface loads a module (userdefined)
- debug_getContext (since 6.5): Force-update the Lua variables representing the registers?
- debug_setContext (since 6.5[1]): Force-update the registers to the Lua variables which represent them?
- debug_updateGUI: Will refresh the userinterface to reflect the new context if the debugger was broken
- detachIfPossible: Detaches the debugger from the target process (if it was attached)
- debug_addThreadToNoBreakList: This will cause breakpoints on the provided thread to be ignored
- debug_removeThreadFromNoBreakList: removed the threadid from the list
- debug_getXMMPointer: Returns the address of the specified xmm register of the thread that is currently broken
- debugger_onModuleLoad: This routine is called when a module is loaded. Only works for the windows debugger
DBK[edit]
- dbk_initialize: Loads the DBK driver into memory if possible
- dbk_useKernelmodeOpenProcess: Switches the internal pointer of the OpenProcess api to dbk_OpenProcess
- dbk_useKernelmodeProcessMemoryAccess: Switches the internal pointer to the ReadProcessMemory and WriteProcessMemory apis to dbk_ReadProcessMemory and dbk_WriteProcessMemory
- dbk_useKernelmodeQueryMemoryRegions: Switches the internal pointer to the QueryVirtualMemory api to dbk_QueryVirtualMemory
- dbk_getPEProcess: Returns the pointer of the EProcess structure of the selected processid
- dbk_getPEThread: Gets the pointer to the EThread structure of a threadid
- dbk_readMSR: Reads the msr using the dbk driver
- dbk_writeMSR: Writes the msr using the dbk driver
- dbk_executeKernelMemory: Executes a routine from kernelmode (e.g a routine written there with auto assembler)
- dbk_getCR0: Returns Control Register 0
- dbk_getCR3: Returns Control Register 3 of the currently opened process
- dbk_getCR4: Returns Control Register 4
- dbk_getPhysicalAddress: Returns the physical address of the given address
- dbk_writesIgnoreWriteProtection: Set to true if you do not wish to initiate copy-on-write behaviour
DBVM[edit]
- dbvm_initialize: Initializes the dbvm functions
- dbvm_addMemory: Adds memory to DBVM
- dbvm_readMSR: Reads the msr using dbvm (bypasses the driver)
- dbvm_writeMSR: Writes the msr using dbvm (bypasses the driver)
- dbvm_getCR4: Returns the real Control Register 4 state
- dbvm_readPhysicalMemory: Reads physical memory using DBVM
- dbvm_writePhysicalMemory: Writes physical memory using DBVM
- dbvm_watch_writes: Starts memory region write monitoring
- dbvm_watch_reads: Starts memory region read monitoring
- dbvm_watch_retrievelog: Receives the result of memory region monitoring
- dbvm_watch_disable: Disables memory region monitoring
- dbvm_cloak_activate: Cloak a page so changes to it will become invisible
- dbvm_cloak_deactivate: Undo the cloak. Also undoes changes
- dbvm_cloak_readOriginal: Read the memory that gets executed in a cloaked region
- dbvm_cloak_writeOriginal: Writes the memory that gets executed in a cloaked region
- dbvm_changeregonbp : Cloaks and sets a breakpoint at the given address and change registers when executed
- dbvm_removechangeregonbp: Removes a change reg on bp breakpoint
- dbvm_log_cr3_start : Start logging CR3 values
- dbvm_log_cr3_stop : Stop logging CR3 values
- dbvm_speedhack_setSpeed : sets the systemwide speedhack
- dbvm_setTSCAdjust : Lets you specify what happens when a program tries to detect a virtual machine by calling rdtsc
Translation[edit]
- getTranslationFolder: Returns the path of the current translation files, empty if there is no translation going on
- loadPOFile: Loads a ".PO" file used for translation
- translate: Returns a translation of the string, returns the same string if it can't be found
- translateID: Returns a translation of the string ID
Files[edit]
- getFileVersion: Returns the 64-bit file version, and a table that has split up the file version into major, minor, release and build
- getFileList: Returns an indexed table with filenames
- getDirectoryList: Returns an indexed table with directory names
Structures[edit]
- registerStructureDissectOverride: same as onAutoGuess, but is called by the structure dissect window when the user chooses to let cheat engine guess the structure for them
- unregisterStructureDissectOverride: unregisters the structure dissect auto guess override
- registerStructureNameLookup: Registers a function to be called when dissect data asks the user for the name of a new structure define
- unregisterStructureNameLookup:
Miscellaneous[edit]
- injectDll: Injects a dll
- shellExecute: Executes a given command
- executeCode: Executes a stdcall function with 1 parameter at the given address in the target process and wait for it to return
- executeCodeEx:
- executeCodeLocal: Executes a stdcall function with 1 parameter at the given address in the target process
- executeCodeLocalEx:
- onAPIPointerChange: Registers a callback when an api pointer is changed
- setAPIPointer: Sets the pointer of the given api to the given address
- md5memory: Returns a md5 sum calculated from the provided memory
- md5file: Returns a md5 sum calculated from the file
- getSystemMetrics: Retrieves the specified system metric or system configuration setting msdn.microsoft.com/en-us/library/windows/desktop/ms724385.aspx
- getTickCount: Returns the current tickcount since windows was started. Each tick is one millisecond
- getUserRegistryEnvironmentVariable: Returns the environment variable stored in the user registry environment
- setUserRegistryEnvironmentVariable: Sets the environment variable stored in the user registry environment
- broadcastEnvironmentUpdate: Call this when you've changed the environment variables in the registry
- getApplication: Returns the application object (the titlebar)
- getInternet: Returns an internet class object. The string provided will be the name of the client provided
Classes[edit]
Besides the above functions, Cheat Engine also implements some classes.
- Addresslist: The addresslist class is a container for memory records
- Bitmap: Bitmap based Graphic object
- Brush: The brush class is part of the Canvas object. It's used to fill surfaces
- Button: The button class is a visual component in the shape of a button.
- ButtonControl: Common ancestor of several button like objects.
- Canvas: The canvas class is a graphical class. It allows you do draw lines, pictures, and text on top of other object. Usually used in onPaint events and other graphical events
- Calendar:
- CEForm:
- CheatComponent: The cheatcomponent class is the component used in Cheat Engine 5.x trainers
- CheckBox: The Checkbox is a visual component that lets the user click it and change state between checked, unchecked, and if possible, grayed
- Component : Base class for all components that need owner-owned functionality.
- Control : Base class for visible controls.
- Collection: The Collection class is an abstract class that the ListColumns class implements (And perhaps other classes as well)
- CollectionItem: Basic object that is managed by a Collection class
- ComboBox: The Combobox is like an edit field with a ListBox attached to it
- CriticalSection:
- CustomControl: Base class for windowed controls which paint themselves
- CustomType: The custom type is an convertor of raw data, to a human readable interpretation.
- D3DHOOK: The d3dhook functions provide a method to render graphics and text inside the game, as long as it is running in directx9, 10 or 11
- D3DHook_FontMap: A fontmap is a texture that contains extra data regarding the characters
- D3DHook_Texture: This class controls the texture in memory. Without a sprite to use it, it won't show
- D3Dhook_TextContainer: A d3dhook_sprite class draws a piece of text on the screen based on the used fontmap
- D3DHook_RenderObject: The renderobject is the abstract class used to control in what manner objects are rendered.
- D3DHook_Sprite: A d3dhook_sprite class is a visible texture on the screen
- Disassembler:
- Disassemblerview: The visual disassembler used in the memory view window
- DisassemblerviewLine:
- DissectCode:
- Edit: The Edit class is a visual component that lets the user type in data (Use control_getCaption to get the user input)
- Event:
- FileStream: The FileStream class is a Stream class that is linked to an open file on disk
- FileDialog:
- FindDialog:
- Font: Class that defines a font
- Form: Class that defines a window
- FoundList: The foundlist is an companion class to MemScan. It opens the current memscan's result file and provides an interface for reading out the addresses
- GenericHotkey: Lets you register hotkeys to Cheat Engine's internal hotkey handler
- Graphic: Base class for dealing with Graphic images (Abstract)
- GraphicControl: Class that supports simple lightweight controls that do not need the ability to accept keyboard input or contain other controls.
- GroupBox: The groupbox class is like a Panel, but then has a header on top
- Hexadecimal: The visual hexadecimal object used on the memory view window
- Hexadecimalview: The visual hexadecimal object used on the memory view window
- Icon:
- Image: The Image class is a visual component that lets you show an image
- Internet:
- JpegImage:
- Label: The Label class is a visual component that lets you display text
- LuaPipe: Abstract class that LuaPipeServer and LuaPipeclient inherit from
- LuaPipeClient: Class implementing a client that connects to a pipe
- LuaPipeServer: Class launching the server side of a pipe
- ListBox: The listbox class is a visual component with a list of selectable strings
- ListColumn: The listcolumn class is an implemented CollectionItem class which is used by the ListColumns class of the listview class
- ListColumns: The ListColumns class contains the Column class objects of a ListView object
- ListItem: The ListItem class object is an entry in a ListView
- ListItems: The listItems class is a container for the ListItem class objects of a Listview
- Listview: The listview class lets you have a listbox like component with resizable columns
- MainMenu: The menu at the top of a form
- Memo: The Memo class is a multiline edit field
- MemScan: The memscan class is the memory scanner of Cheat engine
- Menu: Common Class ancestor for the MainMenu and PopupMenu classes
- MenuItem: Holds the menuitems of a Menu, PopupMenu or even another MenuItem
- MemoryRecord: The Memoryrecord class object describes a Cheat Table's Cheat Entry.
- MemoryRecordHotkey: The memoryRecordHotkey class object is part of a MemoryRecord class. It's used as an interface to each individual hotkey inside a Cheat Table
- MemoryStream: The memorystream class is a Stream class that is stored completely in memory. Because it's a stream there are multiple functions that can work with it
- Memoryview: The memoryview class is the Memory view window of Cheat Engine. Use this as a basis to access the objects inside this window
- MultiReadExclusiveWriteSynchronizer:
- Object: Most basic class. All classes inherit from this class
- PaintBox:
- PageControl: This is an object that can hold multiple pages
- Panel: The Panel class is like a form which can contain visual components.
- Pen: The Pen class is part of the Canvas object. It's used to draw lines
- Picture: Container for the Graphic class
- PopupMenu: The menu that shows when rightclicking on an object
- PortableNetworkGraphic:
- ProgressBar: The progressbar class is a visual representation for a bar that can show the current progress on something
- RadioGroup: The radiogroup is like a GroupBox but autopopulated using the Items(Strings object)
- RasterImage: Base class for some graphical controls
- RIPRelativeScanner:
- OpenDialog: The OpenDialog class is used for selecting files to open.
- SaveDialog: The SaveDialog class is based on the OpenDialog class but is used to select a file for saving
- SelectDirectoryDialog:
- Semaphore:
- Settings: This class can be used to read out and set settings of cheat engine and of plugins, and store your own data
- Splitter: The Splitter class is a visual component that lets the user re-size neighboring components)
- Stringlist: Class that holds a list of strings
- Strings: Abstract class that some text based classes make use of
- StringStream:
- Structure:
- StructureElement:
- StructureFrm:
- structGroup:
- SymbolList: This class can be used to look up an address to a symbolname, and a symbolname to an address
- TabSheet: Part of a page control
- TableFile: Tablefiles are files stored into a Cheat Table. You can access the data of such a file using this class
- Thread:
- Timer: The timer class is an non visual component that when active triggers an onTimer event every few milliseconds, based on the given interval
- ToggleBox: The togglebox is like a button, but can stay down. Use with the checkbox methods
- TrackBar: The trackbar class is a slider you can drag arround and read/set the state
- TreeNode:
- TreeNodes:
- Treeview:
- WinControl: Base class for controls which can contain other controls.
- xmplayer:
SQL Classes[edit]
- CustomConnection:
- Database:
- SQLConnection:
- SQLite3Connection:
- ODBCConnection:
- DBTransaction:
- SQLTransaction:
- Param:
- Params:
- Fields:
- Dataset:
- DBDataset:
- CustomBufDataset:
- CustomSQLQuery:
- SQLQuery:
Class Helper Functions[edit]
- inheritsFromObject: Returns true if given any class
- inheritsFromComponent: Returns true if the given object inherits from the Component class
- inheritsFromControl: Returns true if the given object inherits from the Control class
- inheritsFromWinControl: Returns true if the given object inherits from the WinControl class
- createClass: Creates an object of the specified class (Assuming it's a registered class and has a default constructor)
- createComponentClass: Creates an object of the specified component inherited class
Undefined Class Property Functions[edit]
Not all properties of all classes have been explicitly exposed to lua, but if you know the name of a property of a specific class you can still access them (assuming they are declared as published in the pascal class declaration)
- getPropertyList: Returns a StringList object containing all the published properties of the specified class
- setProperty: Sets the value of a published property of a class (Won't work for method properties)
- getProperty: Gets the value of a published property of a class (Won't work for method properties)
- setMethodProperty: Sets the method property to the specific function
- getMethodProperty: Returns a function you can use to call the original function