NOTE: If you are looking to just download this to use debugging tools, download the Sumneko extension mentioned below and then open up RPFM and use its "check tw_autogen" feature. It will automatically download this repository's necessary files for the game you're modding. If you don't want to use that feature, or want to make direct edits to the tw_autogen, read on!
This is an autogenerator program to create all the necessary files to set up a development environment, to make creating Lua mods for Total War significantly easier. This process uses the script documentation provided by Creative Assembly, translates their HTML files to Lua files, and uses a Lua plugin to incorporate pretty good error checking.
All information on how to install and set this up to follow.
NOTE: This is very much in-progress, and will see a few following updates. I'm assuming basic adequacy with VSCode and Lua, I can't handhold the entire way through right now until my tutorial series is finished.
First things first, you need to download Visual Studio Code. You should also download Rusted Pack File Manager and GitHub Destkop if you haven't already, as well as create a GitHub account. The latter is optional, but very convenient for controlling your versioning and source of your Lua files.
After opening Visual Studio Code, click the "Extensions" button on the left-hand sidebar, and look up "vscode-lua". Search for the extension created by Sumneko, and download it.
I also recommend the following plugins, while you're at it:
- Bookmarks, so you can quickly return to important spots in your code.
- Code Runner, which I use to test non-TW Lua code (for instance, this autogenerator) NOT NEEDED for TW code.
- Lines of Code so you can get some statistics about how much you've written.
- TODO Tree so you can quickly find todo items you have left in your code.
If you haven't already, using RPFM, set up your "MyMod" folder. Set it wherever - mine is S:/modding, where S is my SSD backup drive. RPFM will then create a subfolder for each game, and a subfolder for each mod within each game - ie., S:/modding/warhammer3/mod_configuration_tool.
Within this repository, navigate to output -> your game. If you're modding Warhammer 3, go to output/wh3. You can use the github directory downloader to download just that folder, or clone the entire repository to your PC somewhere and utilize that directory later. Navigate to your MyMod folder, create a new folder (I call my tw_autogen), and paste the contents of the .zip file from the directory downloader into there.
!Your directory should look something like this! Your directory should end up looking like this.
Within Visual Studio Code, when you're working on a mod, you should either use File -> Open Folder, or File -> New Workspace. If you don't know what a Workspace is, I don't care to teach you, but you'll know what I mean if you do.
Within your opened folder, either create or open up the .vscode/ folder, and either create or open up settings.json. To enable debugging, paste in the following:
{
"Lua.workspace.library": [
"S:/modding/tw_autogen/output/wh3/global/",
"S:/modding/tw_autogen/output/wh3/campaign/",
"S:/modding/tw_autogen/output/wh3/frontend/",
"S:/modding/tw_autogen/output/wh3/battle/"
]
}
If the file is already there, add in the lines between the {}'s but don't interrupt them. VSCode will yell at you if you goof up.
If you're only doing a battle mod, erase the /campaign/ and /frontend/ folders; if you're doing a campaign mod, erase the /battle/ and /frontend/ folders; and so on.
Finally, go to the Extensions tab, scroll down to "Lua by sumneko", press the cog icon and press "Extension settings". On the page that follows, make sure you have "User" selected instead of "Workspace" on the top bar. I recommend the following settings:
- Disable "Auto Require".
- Adding "lowercase-global" and "trailing-space" in "Lua > Diagnostics: Disable".
- Setting "Lua > Diagnostics: Workspace Delay" to 500.
- Settings "Lua > Diagnostics: Workspace Rate" between 20-40.
- Set all "Lua.Intelli Sense" settings to true.
- Set "Lua > Runtime: Version" to Lua 5.1
- Set "Lua > Workspace: Ignore Submodules" to false
- Set "Lua > Workspace: Preload File Size" to 1500
With the output files on your computer, and the Visual Studio Code plugin aware of what folder those files are in, you will now get automatic warnings of various types, the plugin will autocomplete for you, and you can basically access the documentation from directly within VSCode.
Enjoy!
If you'd like to help with this project, feel free to make a pull request to fix up any of the standing issues. You can also make an overrides/ file, which are used to "fix" any incorrect definitions from the documentations files. You can see examples therein.
Uses a modified version of 30log Uses the LuaFileSystem