Extensions

Properties are the main way to set values on objects, but they are limited by the GObject type system in what values they can accept. Some classes, therefore, have specialized syntax for certain features.

Note

Extensions are a feature of Gtk.Buildable–see Gtk.Buildable.custom_tag_start() for internal details.

Because they aren’t part of the type system, they aren’t present in typelib files like properties and signals are. Therefore, if a library adds a new extension, syntax for it must be added to Blueprint manually. If there’s a commonly used extension that isn’t supported by Blueprint, please file an issue.

Extension = ExtAccessibility | ExtAdwAlertDialog | ExtAdwMessageDialog | ExtAdwBreakpoint | ExtComboBoxItems | ExtFileFilterMimeTypes | ExtFileFilterPatterns | ExtFileFilterSuffixes | ExtLayout | ExtListItemFactory | ExtSizeGroupWidgets | ExtStringListStrings | ExtStyles

Accessibility Properties

ExtAccessibility = ‘accessibility’ ‘{’ ExtAccessibilityProp* ‘}’ ExtAccessibilityProp = <name:IDENT> ‘:’ (Value | (‘[’ (:ref: Value <Syntax Value>),* ‘]’) ) ‘;’

Valid in any Gtk.Widget.

The accessibility block defines values relevant to accessibility software. The property names and acceptable values are described in the Gtk.AccessibleRelation, Gtk.AccessibleState, and Gtk.AccessibleProperty enums.

Note

Relations which allow for a list of values, for example labelled-by, must be given as a single relation with a list of values instead of duplicating the relation like done in Gtk.Builder.

Adw.Breakpoint

ExtAdwBreakpointCondition = ‘condition’ ‘(’ <condition:QUOTED> ‘)’ ExtAdwBreakpoint = ‘setters’ ‘{’ ExtAdwBreakpointSetter* ‘}’ ExtAdwBreakpointSetter = <object:IDENT> ‘.’ <property:IDENT> ‘:’ Value ‘;’

Valid in Adw.Breakpoint.

Defines the condition for a breakpoint and the properties that will be set at that breakpoint. See the documentation for Adw.Breakpoint.

Note

The Adw.Breakpoint:condition property has type Adw.BreakpointCondition, which GtkBuilder doesn’t know how to parse from a string. Therefore, the condition syntax is used instead.

Adw.AlertDialog Responses

ExtAdwAlertDialog = ‘responses’ ‘[’ (ExtAdwAlertDialogResponse),* ‘]’ ExtAdwAlertDialogResponse = <id:IDENT> ‘:’ StringValue ExtAdwAlertDialogFlag* ExtAdwAlertDialogFlag = ‘destructive’ | ‘suggested’ | ‘disabled’

Valid in Adw.AlertDialog.

The responses block defines the buttons that will be added to the dialog. The destructive or suggested flag sets the appearance of the button, and the disabled flag can be used to disable the button.

using Adw 1;

Adw.AlertDialog {
  responses [
    cancel: _("Cancel"),
    delete: _("Delete") destructive,
    save: "Save" suggested,
    wipeHardDrive: "Wipe Hard Drive" destructive disabled,
  ]
}

Adw.MessageDialog Responses

ExtAdwMessageDialog = ‘responses’ ‘[’ (ExtAdwMessageDialogResponse),* ‘]’ ExtAdwMessageDialogResponse = <id:IDENT> ‘:’ StringValue ExtAdwMessageDialogFlag* ExtAdwMessageDialogFlag = ‘destructive’ | ‘suggested’ | ‘disabled’

Valid in Adw.MessageDialog.

The responses block defines the buttons that will be added to the dialog. The destructive or suggested flag sets the appearance of the button, and the disabled flag can be used to disable the button.

using Adw 1;

Adw.MessageDialog {
  responses [
    cancel: _("Cancel"),
    delete: _("Delete") destructive,
    save: "Save" suggested,
    wipeHardDrive: "Wipe Hard Drive" destructive disabled,
  ]
}

Gtk.ComboBoxText Items

ExtComboBoxItems = ‘items’ ‘[’ (ExtComboBoxItem),* ‘]’ ExtComboBoxItem = ( <id:IDENT> ‘:’ )? StringValue

Valid in Gtk.ComboBoxText, which is deprecated as of Gtk 4.10.

The items block defines the items that will be added to the combo box. The optional ID can be used to refer to the item rather than its label.

ComboBoxText {
  items [
    item1: "Item 1",
    item2: "Item 2",
    item3: "Item 3",
  ]
}

Gtk.FileFilter Filters

ExtFileFilterMimeTypes = ‘mime-types’ ‘[’ (ExtFileFilterItem),* ‘]’ ExtFileFilterPatterns = ‘patterns’ ‘[’ (ExtFileFilterItem),* ‘]’ ExtFileFilterSuffixes = ‘suffixes’ ‘[’ (ExtFileFilterItem),* ‘]’ ExtFileFilterItem = <item:QUOTED>

Valid in Gtk.FileFilter.

The mime-types, patterns, and suffixes blocks define the items that will be added to the file filter. The mime-types block accepts mime types (including wildcards for subtypes, such as image/*). The patterns block accepts glob patterns, and the suffixes block accepts file extensions.

FileFilter {
  mime-types [ "text/plain", "image/*" ]
  patterns [ "*.txt" ]
  suffixes [ "png", "jpg" ]
}

Widget Layouts

ExtLayout = ‘layout’ ‘{’ ExtLayoutProp* ‘}’ ExtLayoutProp = <name:IDENT> ‘:’ Value ‘;’

Valid in Gtk.Widget.

The layout block describes how the widget should be positioned within its parent. The available properties depend on the parent widget’s layout manager.

Grid {
  Button {
    layout {
      column: 0;
      row: 0;
    }
  }
  Button {
    layout {
      column: 1;
      row: 0;
    }
  }
  Button {
    layout {
      column: 0;
      row: 1;
      row-span: 2;
    }
  }
}

Gtk.BuilderListItemFactory Templates

ExtListItemFactory = ‘template’ TypeName ObjectContent

Valid in Gtk.BuilderListItemFactory.

The template block defines the template that will be used to create list items. This block is unique within Blueprint because it defines a completely separate sub-blueprint which is used to create each list item. The sub-blueprint may not reference objects in the main blueprint or vice versa.

The template type must be Gtk.ListItem, Gtk.ColumnViewRow, or Gtk.ColumnViewCell. The template object can be referenced with the template keyword.

ListView {
  factory: BuilderListItemFactory {
    template ListItem {
      child: Label {
        label: bind template.item as <StringObject>.string;
      };
    }
  };

  model: NoSelection {
    model: StringList {
      strings [ "Item 1", "Item 2", "Item 3" ]
    };
  };
}

Gtk.Scale Marks

ExtScaleMarks = ‘marks’ ‘[’ (ExtScaleMark),* ‘]’ ExtScaleMark = ‘mark’ ‘(’ ( ‘-’ | ‘+’ )? <value:NUMBER> ( ‘,’ <position:IDENT> ( ‘,’ StringValue )? )? ‘)’

Valid in Gtk.Scale.

The marks block defines the marks on a scale. A single mark has up to three arguments: a value, an optional position, and an optional label. The position can be left, right, top, or bottom. The label may be translated.

Gtk.SizeGroup Widgets

ExtSizeGroupWidgets = ‘widgets’ ‘[’ (ExtSizeGroupWidget),* ‘]’ ExtSizeGroupWidget = <id:IDENT>

Valid in Gtk.SizeGroup.

The widgets block defines the widgets that will be added to the size group.

Box {
  Button button1 {}
  Button button2 {}
}

SizeGroup {
  widgets [button1, button2]
}

Gtk.StringList Strings

ExtStringListStrings = ‘strings’ ‘[’ (ExtStringListItem),* ‘]’ ExtStringListItem = StringValue

Valid in Gtk.StringList.

The strings block defines the strings in the string list.

StringList {
  strings ["violin", "guitar", _("harp")]
}

CSS Styles

ExtStyles = ‘styles’ ‘[’ ExtStylesProp* ‘]’ ExtStylesProp = <name:QUOTED>

Valid in any Gtk.Widget.

The styles block defines CSS classes that will be added to the widget.

Button {
  styles ["suggested-action"]
}

Child Extensions

ChildExtension = ExtResponse

Child extensions are similar to regular extensions, but they apply to a child of the object rather than the object itself. They are used to add properties to child widgets of a container, such as the buttons in a Gtk.Dialog. The child extension takes the place of a child type inside the square brackets.

Currently, the only child extension is ExtResponse.

Dialog & InfoBar Responses

ExtResponse = ‘action’ ‘response’ ‘=’ ( <name:IDENT> | <id:NUMBER> ) ‘default’?

Valid as a child extension for children of Gtk.Dialog or Gtk.InfoBar, which are both deprecated as of Gtk 4.10.

The action response extension sets the action child type for the child and sets the child’s integer response type. The response type may be either a member of the Gtk.ResponseType enum or a positive, application-defined integer.

No more than one child of a dialog or infobar may have the default flag.

Dialog {
 [action response=ok default]
 Button {}

 [action response=cancel]
 Button {}

 [action response=1]
 Button {}
}