Interface

Gtk-4.0GtkCssProviderSignalSignatures

interface SignalSignatures {
    notify: (arg0: GObject.ParamSpec) => void;
    "notify::prefers-color-scheme": (pspec: GObject.ParamSpec) => void;
    "notify::prefers-contrast": (pspec: GObject.ParamSpec) => void;
    "notify::prefers-reduced-motion": (pspec: GObject.ParamSpec) => void;
    "parsing-error": (arg0: Gtk.CssSection, arg1: GLib.Error) => void;
}

Hierarchy (View Summary)

Index

Properties

"notify::prefers-color-scheme": (pspec: GObject.ParamSpec) => void
"notify::prefers-contrast": (pspec: GObject.ParamSpec) => void
"notify::prefers-reduced-motion": (pspec: GObject.ParamSpec) => void
"parsing-error": (arg0: Gtk.CssSection, arg1: GLib.Error) => void

Signals that a parsing error occurred.

The expected error values are in the Gtk.CssParserError and Gtk.CssParserWarning enumerations.

The path, line and position describe the actual location of the error as accurately as possible.

Parsing errors are never fatal, so the parsing will resume after the error. Errors may however cause parts of the given data or even all of it to not be parsed at all. So it is a useful idea to check that the parsing succeeds by connecting to this signal.

Errors in the Gtk.CssParserWarning enumeration should not be treated as fatal errors.

Note that this signal may be emitted at any time as the css provider may opt to defer parsing parts or all of the input to a later time than when a loading function was called.

Properties - Inherited from GObject

notify: (arg0: GObject.ParamSpec) => void

The notify signal is emitted on an object when one of its properties has its value set through g_object_set_property(), g_object_set(), et al.

Note that getting this signal doesn’t itself guarantee that the value of the property has actually changed. When it is emitted is determined by the derived GObject class. If the implementor did not create the property with GObject.ParamFlags.EXPLICIT_NOTIFY, then any call to g_object_set_property() results in ::notify being emitted, even if the new value is the same as the old. If they did pass GObject.ParamFlags.EXPLICIT_NOTIFY, then this signal is emitted only when they explicitly call g_object_notify() or g_object_notify_by_pspec(), and common practice is to do that only when the value has actually changed.

This signal is typically used to obtain change notification for a single property, by specifying the property name as a detail in the g_signal_connect() call, like this:

g_signal_connect (text_view->buffer, "notify::paste-target-list",
G_CALLBACK (gtk_text_view_target_list_notify),
text_view)

It is important to note that you must use [canonical parameter names][class@GObject.ParamSpec#parameter-names] as detail strings for the notify signal.