/wap

A developer-friendly World of Warcraft addon packager

Primary LanguagePythonMIT LicenseMIT

wap (WoW Addon Packager)

GitHub Actions status for master branch Code Coverage on codecov.io Latest release on PyPI Code styled with black MIT licensed Documentation Status

wap is a developer-friendly World of Warcraft addon packager.

wap demo

Features

  • Packages retail or classic WoW addons (or both!)
  • Uploads your addons to CurseForge
  • Automatically installs your addons to your AddOns folder when a file changes in your project
  • Generates valid TOC files automagically
  • Sets up new addon projects quickly, ready to go with one command
  • Consolidates all configuration in one easy-to-edit file
  • Supports and is tested on Windows, macOS, and Linux
  • Has awesome documentation

wap in 5 minutes

This entire set of instructions is runnable without editing a single line of code!

  1. Download Python 3.9 or greater and install it.

  2. Install wap with pip:

    $ pip install --upgrade --user wow-addon-packager
  3. Create a new project:

    $ wap quickstart MyAddon  # or whatever name you'd like!

    and answer the prompted questions. Don't worry too much about your answers -- you can always change them later in your configuration file.

    Then change to your new project's directory

    $ cd "MyAddon"
  4. Package your addon

    $ wap package
  5. Install your addon so you can test it out in your local WoW installation:

    Windows
    $ wap dev-install --wow-addons-path "C:\Program Files (x86)\World of Warcraft\_retail_\Interface\AddOns"
    macOS
    $ wap dev-install --wow-addons-path "/Applications/World of Warcraft/_retail_/Interface/AddOns"

    Note

    Also check out the watch command for automatic repackage and re-dev-installation!

  6. Upload your project to CurseForge

    $ wap upload --addon-version "dev" --curseforge-token "<your-token>"

    You can generate a new token at Curseforge's My API Tokens page.

Further Help

See the official documentation site. There's a lot more information there!

Also, the wap command is fully documented in its help text. View it with:

$ wap --help
$ wap build --help
$ wap upload --help
... etc

Badge

If you'd like to show others in your documentation that you are using wap to package your addon, you can include the following official badge (hosted by https://shields.io/):

Packaged by wap
Markdown
[![Packaged by wap](https://img.shields.io/badge/packaged%20by-wap-d33682)](https://github.com/t-mart/wap)
reStructuredText
.. image:: https://img.shields.io/badge/packaged%20by-wap-d33682
   :target: https://github.com/t-mart/wap
   :alt: Packaged by wap

Contributing

See how to contribute in the official docs.

TODOs

Copyright (c) 2021 Tim Martin