/tuw

Tiny GUI wrapper for command-line tools

Primary LanguageC++MIT LicenseMIT

Tuw: a tiny GUI wrapper for command-line tools

  _____
 |_   _|   ___      __
   | || | | \ \ /\ / /
   | || |_| |\ V  V /
   |_| \__,_| \_/\_/
  Tiny UI wrapper for
       CLI tools

build test Codacy Badge

Only 300KB for a portable GUI

Tuw provides a very simple GUI for your scripts.
All you need is a JSON file and a tiny executable.
No need for compilers, browsers, or huge executables!

sample

Features

  • Define GUI in JSON
  • Embed JSON into exe
  • Save arguments
  • Input paths by drag and drop
  • Cross-platform (Windows, macOS, Linux, BSD, etc.)
  • Native look and feel
  • Portable
  • Small size
  • UTF-8 support

Downloads

You can download executables from the release page

  • Tuw-*-Windows-*.zip is for Windows (7 or later.)
  • Tuw-*-Windows10-*.zip requires Windows 10 or later, but it's much smaller than the standard version.
  • Tuw-*-macOS.tar.xz is for macOS (10.9 or later.)
  • Tuw-*-Linux-*.tar.xz is for Linux (with GTK3.14, GLIBC2.28, and GLIBCXX3.4, or later versions of the libraries.)

Note

Tuw also supports Linux distributions using musl and other Unix-like systems (BSD, Haiku, illumos, etc.). While there is no release package available for these systems, you can build Tuw from the source code.

Examples

There are many JSON files to learn how to define GUIs.

JSON Schema

There is a schema for gui_definition.json.
You can use it to validate definitions while editing files.

VSCode

For VSCode, you can add the schema path to settings.json (File > Preferences > Settings > JSON:Schemas > Edit in settings.json.)

"json.schemas": [
    {
        "fileMatch": [ "gui_definition.json", "gui_definition.jsonc" ],
        "url": "https://raw.githubusercontent.com/matyalatte/tuw/main/schema/schema.json"
    }
]

FAQ

Frequently Asked Questions

Building

Building Executables

License

Files in this repository are available under the MIT license.

External Projects

Project About License
libui-ng GUI framework MIT
RapidJSON JSON parser MIT
subprocess.h Command processor Unlicense
c-env-utils Utilities for environment info MIT
tiny-str-match String validator MIT