Skip to main content

Markup compiler for GTK user interface definitions

Project description

Blueprint

A markup language for GTK user interface files.

Motivation

GtkBuilder XML format is quite verbose, and many app developers don't like using WYSIWYG editors for creating UIs. Blueprint files are intended to be a concise, easy-to-read format that makes it easier to create and edit GTK UIs.

Internally, it compiles to GtkBuilder XML as part of an app's build system. It adds no new features, just makes the features that exist more accessible.

Another goal is to have excellent developer tooling--including a language server--so that less knowledge of the format is required. Hopefully this will increase adoption of cool advanced features like GtkExpression.

Example

Here is what the libshumate demo's UI definition looks like ported to this new format:

using Gtk 4.0;
using Shumate 1.0;

template ShumateDemoWindow : Gtk.ApplicationWindow {
  can-focus: yes;
  title: _("Shumate Demo");
  default-width: 800;
  default-height: 600;

  [titlebar]
  Gtk.HeaderBar {
    Gtk.DropDown layers_dropdown {
      notify::selected => on_layers_dropdown_notify_selected() swapped;
    }
  }

  Gtk.Overlay overlay {
    vexpand: true;
    Shumate.Map map {}

    [overlay]
    Shumate.Scale scale {
      halign: start;
      valign: end;
    }

    [overlay]
    Gtk.Box {
      orientation: vertical;
      halign: end;
      valign: end;

      Shumate.Compass compass {
        halign: end;
        map: map;
      }
      Shumate.License license {
        halign: end;
      }
    }
  }
}

Editors

Workbench, GNOME Builder and KDE's Kate have builtin support for Blueprint.

Vim

GNU Emacs

Visual Studio Code

Sublime Text

Zed

Getting in Touch

Matrix room: #blueprint-language:matrix.org

License

Copyright (C) 2021 James Westman james@jwestman.net

This program is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.

You should have received a copy of the GNU Lesser General Public License along with this program. If not, see https://www.gnu.org/licenses/.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

blueprint_compiler-0.20.4.tar.gz (168.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

blueprint_compiler-0.20.4-py3-none-any.whl (157.8 kB view details)

Uploaded Python 3

File details

Details for the file blueprint_compiler-0.20.4.tar.gz.

File metadata

  • Download URL: blueprint_compiler-0.20.4.tar.gz
  • Upload date:
  • Size: 168.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for blueprint_compiler-0.20.4.tar.gz
Algorithm Hash digest
SHA256 5e3420cad7c357617574b29db8a0e69187f221bc69f510a1f69cc421ea1055cc
MD5 4faae1d29d070e51d0e719469176e98a
BLAKE2b-256 d27844a00bf64bf6e7353c42916fa52c5f96e37d719466ddf8c580dbe9927b5b

See more details on using hashes here.

File details

Details for the file blueprint_compiler-0.20.4-py3-none-any.whl.

File metadata

File hashes

Hashes for blueprint_compiler-0.20.4-py3-none-any.whl
Algorithm Hash digest
SHA256 15c6f5a67fb737bd30824163e2a0815ef8b44d9b34b236ea009ede3e426c1ffb
MD5 e43f67c827cd2f7dd621c8b72ee47232
BLAKE2b-256 bfff8b0b758ad6b5078061a6e944e34751acd67f6dded2e1685960b910fd474a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page