/libwarcraft

All-in-one managed library for reading and writing World of Warcraft data files.

Primary LanguageC#GNU General Public License v3.0GPL-3.0

libwarcraft

DoxygenDoc Bountysource

Buy Me a Coffee at ko-fi.com

Build Status

CI Build Defects
Travis Build Status CodeCov Badge Soon

About

libwarcraft is a managed C# library for interacting with binary file formats created by Blizzard Activision. The goal of the library is to be fully compatible with all proprietary file formats used in their games, and to serve as an all-in-one backend solution for applications wishing to read and modify these files.

The primary focus for the library at the moment is to provide a complete implementation of all formats used up to and including Wrath of the Lich King. Anyone is free to use this library to write their own applications for performing operations on the file formats, and is in fact encouraged. The library is not meant for specialized applications (adding water to terrain, repacking images, adding animations or editing geometry of models) but rather strives to expose all functionality needed for other applications to implement that functionality as is best for their use case.

libwarcraft currently implements the following file formats:

  • BLP (Blizzard Picture). Read/Write, versions 0, 1 and 2
  • MPQ (Mike O'Brien Package). Read, Basic to extended v1 format.
  • DBC (Database - Client). Read, DB1 format.
  • TRS (Hashmap Translation Table): Read support.
  • MDX (Model). Read support, up to and including Wrath of the Lich King. External .skin and .anim files cannot be loaded yet.
  • WDT (World Tables): Fully compliant Read & Write.
  • WDL (World LOD): Fully compliant Read & Write.
  • WMO (World Model). Fully compliant Read & Write.

The following formats are still in progress, and may not work as intended (or at all):

  • ADT (Areadata Tile). Near-full read support, up to and including Wrath of the Lich King. However, the code is old and works like arse.

The following formats are not implemented yet:

  • WLW (World Liquids - Water)
  • WLQ (World Liquids)
  • WLM (World Liquid Mapping)
  • LIT (Map Lighting (now obsolete)
  • CHK.NOT (Unknown. Possibly Godrays)
  • DB2 (Cataclysm (and up) DBC files)
  • WDB (Client Cache Database)
  • TBL (Hotfix Identifier)
  • BLS (Blizzard Shader Container)
  • TEX (Streaming Textures)
  • BLOB (Model Bounding Boxes)
  • DNC.DB (Day/Night Cycle Database (now obsolete))

If you want to help out, I'll gladly accept pull requests and patches for the code, as well as further implementations of current or future file formats. If you have a project that uses the library and you want to share it with other people, send me a link and I'll add it to the project list below.

Getting libwarcraft

There are a number of ways you could use libwarcraft. For Windows users, the current method is, unfortunately, limited to downloading and compiling from source. You get the latest version, but it's a bit more of a hassle. In the future, the libwarcraft base library will be available through NuGet.

Ubuntu (and Ubuntu derivations) can simply add this PPA to get the library, a development package, and a number of other helper packages as well as the software I develop using the library. This is my main place where I release software that sits under the libwarcraft umbrella.

Debian users can manually download packages from the PPA, or add it manually to their sources.list file. Maybe someday it'll be in the main repo? We can hope!

Other Linux users can get tarballs of the binaries from the PPA as well. I plan on figuring out some better format for you soon. If someone who uses Arch sees this, I'd love some help getting it onto the AUR.

Projects

libwarcraft is still in its infancy, but it is still in a quite usable state. The following is a list of projects that use libwarcraft to power their file format needs. A listing here is not an endorsement, but be sure to check them out! Some of my own projects are listed here as well.

  • Everlook - a cross-platform C# replacement for World of Warcraft Model Viewer.
  • gnome-blp-thumbnailer - A thumbnail generator for BLP images under the GNOME desktop environment.

While not strictly a part of libwarcraft, having the correct mime types available is very useful. You can find a set of FreeDesktop MIME type definitions here:

Licensing

libwarcraft is Free Software, and is distributed under the GPLv3 license. This means, in simple terms, that you are free to do whatever you want with the source code and any binaries compiled or generated from it as long as you pass on those rights to anyone aquiring a copy of the source code or binaries. The full licence can be read in the file "LICENSE" at the root of the source tree, or at http://choosealicense.com/licenses/gpl-3.0/, where a more people-friendly summary is also available.

The use of the GPLv3 license and not the LGPLv3 license is a conscious choice by me. If you're unsure what this means, it means that any software that links to or makes use of this library must also be licensed under the GPLv3 license or later, and carry the same rights and grants of rights as the library itself. I am of the firm opinion that closed source software (with certain exceptions) stifles creativity and inhibits technological progress. Share, develop, and be wonderful to each other. Don't adhere to the old closed-source ways, and embrace the wonderful world of free software.

Credits

Most file documentation has been gathered from https://wowdev.wiki/ - a great big thanks to everyone who contributed and is contributing to that wiki! The implementation of the MPQ format was mainly taken from devklog.net and zezula.net. The former has shut down, but is still available through the wayback machine, while the latter is nice as complementary information.

Special thanks to:

  • Justin Olbrantz & Jean-Francois Roy for their thorough documentation of the MPQ format. Although their wiki page is down and has been for a while, the Wayback Machine has a cached copy which proved invaluable.
  • Ladislav Zezula, whose C/C++ implementation of the MPQ format in StormLib provided me with complementary information to the wiki above. Many small crucial details pile up!
  • Nick Acaves for his C# implementation of the MPQ encryption algorithm, without which I never would have understood it.
  • James Telfer & Mark Adler for James' work on the Blast compression library, which is a C# reimplementation of Mark's C implementation of the PKWare Implode compression algorithm. Legacy game modders have you to thank.
  • Sam Hocevar & Rogueadyn - Rogueadyn for the DotSquish DXTC implementation, with which BLP files spring to life, and Sam for his original code - not to mention his work on Debian and Mono, which are my primary development platforms!
  • Brendan Tompkins for the image quantization algorithms used in generating palettized BLP images from normal file types.
  • Jakob "Rayts5", for his endless will to bounce my stupid ideas and listen to my complaints about the idiocy and/or brilliance of the WoW file formats.