2025-09-26 11:41:02 -06:00
2025-09-29 22:30:57 -06:00
2025-09-28 21:08:29 -06:00
2024-07-23 00:27:03 -06:00
2025-09-26 12:01:15 -06:00
2025-09-28 17:00:38 -06:00
2025-09-28 17:00:38 -06:00

wibo

A minimal, low-fuss wrapper that can run really simple command-line 32-bit Windows binaries on Linux - with less faff and fewer dependencies than WINE.

Don't run this on any untrusted executables, I implore you. (Or probably just don't run it at all... :p)

Building

cmake -B build -G Ninja -DCMAKE_BUILD_TYPE=Debug
cmake --build build --target wibo

Set -DCMAKE_BUILD_TYPE=Release to produce an optimized binary instead.

Running

./build/wibo /path/to/program.exe [arguments...]

Supported command line options:

  • --help: Print usage information.
  • -D, --debug: Enable shim debug logging (equivalent to WIBO_DEBUG=1).
  • -C DIR, --chdir DIR, --chdir=DIR: Change to DIR before running the guest program.
  • --cmdline STRING, --cmdline=STRING: Use STRING as the exact guest command line. (Including the program name as the first argument.)
  • --: Stop option parsing; following arguments are interpreted as the exact guest command line. (Including the program name as the first argument.)

Tests

Self-checking Windows fixtures run through CTest. They require a 32-bit MinGW cross toolchain (i686-w64-mingw32-gcc and i686-w64-mingw32-windres).

With the toolchain installed:

cmake -B build -DBUILD_TESTING=ON
cmake --build build
ctest --test-dir build --output-on-failure

This will cross-compile the fixture executables, run them through wibo, and fail if any WinAPI expectations are not met.


Rough to-do list:

  • Implement more APIs

Related projects:

Description
Quick-and-dirty wrapper that tries to run 32-bit Windows command-line executables on Linux
Readme MIT 2.3 MiB
Languages
C++ 84.3%
C 13.9%
CMake 1.6%
Dockerfile 0.2%