This script will parse World of Warcraft AddOn metadata files (TOC) and update the Interface version(s) to the most recent version(s) of the game.
This script supports updating the multiple TOC files the game officially supports, such as:
MyAddon.toc
(default)MyAddon_Mainline.toc
(Retail)MyAddon_Vanilla.toc
(Classic Era)MyAddon_Cata.toc
(Cataclysm Classic)
It also supports legacy alternatives, although you should avoid using those.
The interface version used for the default MyAddon.toc
is defined by passing the flavor to the script, which can be any of the following:
retail
(Retail)mainline
(alias forretail
)
classic_era
(Classic Era)vanilla
(alias forclassic_era
)
classic
(Cataclysm Classic)cata
(alias forclassic
)
The script will default to retail
unless specified.
One of BigWigs' packager features is the ability for it to automatically create TOC files for flavors based on ## Interface
suffixes. This script will also check for those.
The script can optionally support Beta and PTR versions. If their versions are newer than the current game version they will be appended to the interface version. E.g. If retail is 110002
and there's a PTR for 110005
then the TOC file will be updated to: ## Interface: 110002, 110005
.
You'll need bash >= 4.0
, md5sum
, nc
, awk
, sed
and find
installed on your system.
Only GNU versions are officially supported, Busybox alternatives (or others) have not been tested.
Then run the script:
bash update.sh # use the default flavor
bash update.sh -f classic # set Classic as the default Interface version
bash update.sh -f classic -b -p # set Classic as the default Interface version,
# and add beta and PTR versions
Run the script with --help
to see all available options.
You can use this in a GitHub workflow by referencing p3lim/toc-interface-updater@v3
.
Options:
flavor
- sets the fallback game version for unsuffixed TOC files, see flavor for valid optionsbeta
- set totrue
if beta versions should be appendedptr
- set totrue
if PTR versions should be appended
This is an example workflow that will do the following:
- check out the project
- use this script as an action
- create a pull request (if there were changes)
This will occur every day at 12:00.
name: Update TOC Interface version(s)
on:
schedule:
- cron: 0 12 * * *
jobs:
run:
runs-on: ubuntu-latest
steps:
- name: Clone project
uses: actions/checkout@v4
- name: Update TOC Interface version
uses: p3lim/toc-interface-updater@v4
with:
flavor: retail # this is the default
beta: true # this is optional
ptr: true # this is optional
- name: Create pull request
uses: peter-evans/create-pull-request@v6
with:
title: Update Interface version
commit-message: Update Interface version
branch: interface-version
delete-branch: true