Gtk Comfy

Gtk Comfy is an effort to improve GTK builder files. Whilst the separation between code and interface is a good one, but the implementation is poor. XML is tricky and obtuse:

Example

xml <?xml version="1.0" encoding="UTF-8"?> <interface> <object class="GtkApplicationWindow" id="window"> <property name="title">My GTK App</property> <child> <object class="GtkButton" id="button"> <property name="label">Press me!</property> <property name="margin-top">12</property> <property name="margin-bottom">12</property> <property name="margin-start">12</property> <property name="margin-end">12</property> </object> </child> </object> </interface>

So with GTK Comfy you can instead use any serde compatable format, as shown in the example below:

```yaml

The root interface

interface: # The class of the object (reserverd keyword) class: GtkApplicationWindow

# The id of the widget (reserved keyword) id: window

# The title property. See that properties are automatically infered title: My Gtk App

# The children children: - class: GtkButton id: Button label: Press me! margin-start: "12" margin-top: "12" margin-bottom: "12" margin-end: "12" ```

Features

Gtk Comfy provides many convinience features, such as:

Examples

Attributes

yaml class: GtkLabel label: "This is a red label" attributes: foreground: '#FF0000'

Styles

```yaml class: GtkBox orientation: "horizontal" style: - linked children:

...

```

Grids

yaml class: GtkGrid id: grid children: - class: GtkButton id: button1 label: Button 1 layout: column: 0 row: 0 - class: GtkButton id: button2 label: Button 2 layout: column: 1 row: 0 - class: GtkButton id: button3 label: Button 3 layout: column: 2 row: 0 row-span: 2 - class: GtkButton id: button4 label: Button 4 layout: column: 0 row: 1 column-span: 2

Translation domains

yaml domain: "whatever_this_value_does_i_have_no_idea_what_it_is" interface: class: GtkWindow #...

Translations

Translations can be done by prefixing a string with a \_ such as:

yaml label: \_Save

Which can be escaped like:

yaml label: \\_Save

Extensibility

If you need to extend it to add custom XML (because this app is not perfect) you can use the xml property:

yaml xml: <property name="label">