Debugging
Developer Mode (also known as "cheat") is a special game mode geared towards development of modules and addons for the game.
The easiest way to enable this mode is to select Developer Mode from the Options menu.
Contents
Overview
Developer mode grants the user several privileges and disables others to prevent abuse.
Pros:
- The ability to see hidden modules
- Access to the internal Lua console
- Additional debugging dialogs/options
Cons:
- Disables uploading characters online
- Invalidates game saves loaded while enabled, making them permanently ineligible for achievements.
Config location
Developer Mode is saved as a setting in cheat.cfg
in one of the following directories based off your OS. Deleting this file will disable Developer Mode. If enabled, the value for the cheat
key is either true
or false
.
Windows | HOME\T-Engine\4.0\settings | For example C:\Users\USERNAME\T-Engine\4.0\settings |
Linux | HOME/.t-engine/4.0/settings | |
Mac OSX | HOME\Library\Application Support\T-Engine\4.0\settings |
Game options
Enabling cheat mode gives you the following options:
Key Shortcut | Result |
---|---|
Ctrl+L | Lua console. Click on the console title bar or outside the window to exit. |
(not assigned by default) | Debug menu |
Ctrl+S | Save the game |
Ctrl+Alt+Shift+R | Reload the last save |
Ctrl+G | Hit yourself for ~100 damage |
Mouse | Result |
Ctrl-Left click | Teleport to the targeted square |
Right click | Right-clicking a monster offers several debug functions, such as the ability to inspect inventory. |
Shift-Ctrl-Right click | Instantly kill the targeted creature. This does work on yourself. |
Debug menu (aka debug mode) offers a menu with various options like changing zones, creating items, altering quests, etc. All of this can also be done via the Lua console, but the debug menu is much easier to use.
The keybinding for debug mode may not be assigned by default. Press Esc and go under Key Bindings to assign it.
Lua console
Summary of features:
- Inspect values and execute code
- Cursor positioning
- Tab auto-completion
- Copy and paste with system clipboard
The Lua console drops you into the global namespace and gives you access to the engine. If you want to inspect values, start the line with an equal sign. For example, say you want to inspect the player:
=game.player
The console has cursor positioning so you can use the Left and Right arrows, as well as Home and End to move to the beginning and end of the current line, respectively. You can paste the clipboard's contents to the cursor position with Ctrl+V (note, not CMD+V on Mac). The current line can be copied to the clipboard with Ctrl+C (again, not CMD+C on Mac).
Here are some useful commands to know.
- Level up to level 50
game.player:forceLevelup(50)
- Remove godmode invulnerability
game.player.invulnerable=0
- Change your damage bonus
game.player.inc_damage.all=
- Change your resistance
game.player.resists.all=
- Learn a new talent (1 level in Slash in the example)
game.player:learnTalent(game.player.T_SLASH, true, 1)
- Learn a new talent type (wild-gift/harmony in the example)
game.player:learnTalentType("wild-gift/harmony", true)
- Change category mastery
game.player:setTalentTypeMastery("cunning/survival", 1.5)
- Change base stat - up to 100 max (reduce strength by 20 in the example)
game.player:incStat("str", -20)
- Change stat bonus (set Cunning bonus to 50 in the example)
game.player.inc_stats[game.player.STAT_CUN] = 50
- Apply an effect on the player (frozen for 10 turns)
game.player:setEffect(game.player.EFF_FROZEN, 10, {})
- Change your max HP
game.player.max_life=1
game.player:resetToFull()
- Teleport (to the Assassin Lord)
game:changeLevel(2,"thieves-tunnels")
- Add 5000 gold
game.player:incMoney(5000)
- Give yourself 10 unassigned class skills
game.player.unused_talents=10
- Give yourself 10 unused stat points
game.player.unused_stats=10
- Give yourself an extra stat point each level (default=3)
game.player.stats_per_level=4
- Give yourself 10 unused generic points
game.player.unused_generics=10
- Give yourself 10 unused prodigies points
game.player.unused_prodigies=10
- Give yourself 10 unused category points
game.player.unused_talents_types=10
- Give yourself 10 lives
game.player.easy_mode_lifes=10
- Change another actor's physical resistance to 50
- Right-click then Lua inspect [Actor] to get their actor ID
__uids[ActorID here].resists.PHYSICAL=50
Lua code
To output values into the log file you can use 2 different functions:
- Print any text
print("your message")
- Display the content of an object. This lists all variables contained in the object foo.
table.print(foo)
Output log text to file immediately (only needed on Windows)
Without this, you have to close the game for the log file to be updated!
Instructions:
- Create a shortcut to t-engine.exe.
- Right-click the shortcut and select Properties.
- Add the command to the end of the "Target" line:
--flush-stdout
The end of the Target line should look like this then: \t-engine.exe --flush-stdout
This can be used in combination with a tail program that shows the content of the log file in realtime.
Load module and create character on startup
You can create a character once then use the premade from the command line:
t-engine -Mtome -n -E"auto_quickbirth='player'"
If your premade was named "player." (Or create a shortcut in Windows, similarly to the instructions above for outputting log text to a file.)