Go to file
2025-08-23 13:48:34 +04:00
.github/workflows fix(github): okay, try runner.os == 'Linux' 2024-07-21 20:50:58 -04:00
docs/img chore(docs): add screenshot to README 2023-01-06 14:52:59 -06:00
lib chore(build): update common library 2025-08-23 13:41:34 +04:00
src fix(gx): fix FindDisplayDevice enumerator argument 2025-08-23 13:48:34 +04:00
test fix(test): resort link order to prevent error 2024-09-07 01:01:10 -04:00
vendor feat(glue): add realm and character handling (#7) 2025-04-16 17:32:37 -04:00
.clang-format chore(style): add .clang-format 2023-01-05 22:51:18 -06:00
.clang-format-ignore chore(style): add .clang-format 2023-01-05 22:51:18 -06:00
.editorconfig chore: initial commit 2023-01-02 13:17:18 -06:00
.gitignore chore(build): upgrade .gitignore 2025-06-15 20:48:25 +04:00
.gitmodules chore(build): rehome dependencies 2023-08-04 01:58:43 -04:00
build.zig fix(build): pass WHOA_BUILD_GLSDL option as C define in zig build script 2024-07-22 17:26:08 -04:00
build.zig.zon chore(build): make Thunderbrew zig-buildable 2024-07-21 16:41:14 -04:00
CMakeLists.txt chore(build): upgrade minimum CMake version to 3.10 2025-08-22 21:09:22 -04:00
CONTRIBUTING.md chore(docs): expand contribution guidelines 2023-01-15 11:03:32 -06:00
LICENSE chore(license): add license 2023-01-02 13:18:47 -06:00
README.md chore(doc): improve README.md to be more relevant to Thunderbrew 2024-02-24 13:37:49 -05:00

Thunderbrew

Push

Welcome to Thunderbrew, a fork of Whoa, an unofficial open source implementation of the World of Warcraft 3.3.5a (build 12340) game client in C++11.

Supported Platforms

Currently, Windows 10+, macOS 10.14+ (including recent versions of macOS on M1 and M2 processors), and Ubuntu 22.04 are supported.

Building

On Ubuntu, the following packages are required to build Thunderbrew:

sudo apt install -y libglx-dev libxext-dev libopengl-dev libglvnd-dev

To build, ensure you have installed a recent version of CMake and an appropriate C++ build environment, and run the following from the whoa directory:

mkdir build && cd build
cmake ..
make install

Assuming all went well, you should see a dist/bin directory appear in the build directory. The dist/bin directory will contain a Whoa executable.

Running

The data directory must either be a fully extracted MPQ archive set for World of Warcraft 3.3.5a (build 12340), or a directory that contains a Data subdirectory with 3.3.5a MPQ archives.

Thunderbrew will attempt change its working directory at startup to the directory that contains the Whoa binary. You can either move your Whoa binary to the same directory that contains Data/ and WTF/, launching it from there, or you can supply a different directory with the -datadir \path\to\game_dir command line switch. Note that the -datadir parameter must be specified with backslashes (\), even on MacOS and Linux.

Assuming all goes well, you should be greeted by the login screen, complete with its flying dragon animation loop.

Whoa is very much a work-in-progress: it does not fully connect to a realm server, does not play back sound or music, and does not support customizing settings. These things will be supported over time.

Whoa in action

Contributing

Please follow the guidelines contained in CONTRIBUTING.md when making contributions.

FAQ

Why?

It's fascinating to explore the development practices used to build a modern major video game.

Why 3.3.5a?

The game and its libraries have become significantly more complex in the intervening 10+ years. By picking 3.3.5a, it's possible to imagine this implementation will eventually be complete.

Can I use this in my own development projects?

It's probably a bad idea. The original game is closed source, and this project is in no way official.

This project is released into the public domain.

World of Warcraft: Wrath of the Lich King ©2008 Blizzard Entertainment, Inc. All rights reserved. Wrath of the Lich King is a trademark, and World of Warcraft, Warcraft and Blizzard Entertainment are trademarks or registered trademarks of Blizzard Entertainment, Inc. in the U.S. and/or other countries.