[vte/wip/termprops: 41/42] widget: Add terminal properties
- From: Christian Persch <chpe src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [vte/wip/termprops: 41/42] widget: Add terminal properties
- Date: Tue, 1 Mar 2022 22:40:40 +0000 (UTC)
commit dbbb6d77c60b34ea7c45df66ff6fe63890a5d3c1
Author: Christian Persch <chpe src gnome org>
Date: Tue Mar 1 23:38:31 2022 +0100
widget: Add terminal properties
Part 1: API only, no-op implementation
https://gitlab.gnome.org/GNOME/vte/-/issues/2125
NOTE! Any modified or added code in this patch, and every following on this branch,
is licensed under the GNU Affero General Public License, version 3, only, and
*not* under the LGPL 3+!
doc/reference/vte-sections.txt.in | 12 ++
src/app/app.cc | 47 +++++
src/marshal.list | 1 +
src/vte/vteenums.h | 37 ++++
src/vte/vteterminal.h | 64 +++++-
src/vtegtk.cc | 411 ++++++++++++++++++++++++++++++++++++++
src/vtegtk.hh | 2 +
7 files changed, 573 insertions(+), 1 deletion(-)
---
diff --git a/doc/reference/vte-sections.txt.in b/doc/reference/vte-sections.txt.in
index 4c9680f0..b9d34999 100644
--- a/doc/reference/vte-sections.txt.in
+++ b/doc/reference/vte-sections.txt.in
@@ -10,6 +10,8 @@ VteTextBlinkMode
VteFormat
VteWriteFlags
VteSelectionFunc
+vte_terminal_class_install_termprop
+vte_terminal_class_get_termprop_type
vte_terminal_new
vte_terminal_feed
vte_terminal_feed_child
@@ -113,6 +115,16 @@ vte_terminal_get_xfill
vte_terminal_set_xfill
vte_terminal_get_yfill
vte_terminal_set_yfill
+vte_terminal_get_termprop_bool
+vte_terminal_get_termprop_color
+vte_terminal_get_termprop_data
+vte_terminal_get_termprop_data_bytes
+vte_terminal_get_termprop_int
+vte_terminal_get_termprop_string
+vte_terminal_get_termprop_uint
+vte_terminal_get_termprop_value
+vte_terminal_get_termprop_variant
+vte_terminal_reset_termprop
<SUBSECTION>
VteFeatureFlags
diff --git a/src/app/app.cc b/src/app/app.cc
index 8b1d47ea..07fe0d90 100644
--- a/src/app/app.cc
+++ b/src/app/app.cc
@@ -1376,6 +1376,36 @@ vteapp_terminal_class_init(VteappTerminalClass *klass)
#endif
gtk_widget_class_set_css_name(widget_class, "vteapp-terminal");
+
+ auto const vte_class = VTE_TERMINAL_CLASS(klass);
+ vte_terminal_class_install_termprop(vte_class,
+ "vte.ext.vteapp.valueless",
+ VTE_PROPERTY_VALUELESS,
+ VTE_PROPERTY_FLAG_NONE);
+ vte_terminal_class_install_termprop(vte_class,
+ "vte.ext.vteapp.bool",
+ VTE_PROPERTY_BOOL,
+ VTE_PROPERTY_FLAG_NONE);
+ vte_terminal_class_install_termprop(vte_class,
+ "vte.ext.vteapp.int",
+ VTE_PROPERTY_INT16,
+ VTE_PROPERTY_FLAG_NONE);
+ vte_terminal_class_install_termprop(vte_class,
+ "vte.ext.vteapp.uint",
+ VTE_PROPERTY_UINT16,
+ VTE_PROPERTY_FLAG_NONE);
+ vte_terminal_class_install_termprop(vte_class,
+ "vte.ext.vteapp.color",
+ VTE_PROPERTY_COLOR,
+ VTE_PROPERTY_FLAG_NONE);
+ vte_terminal_class_install_termprop(vte_class,
+ "vte.ext.vteapp.string",
+ VTE_PROPERTY_STRING,
+ VTE_PROPERTY_FLAG_NONE);
+ vte_terminal_class_install_termprop(vte_class,
+ "vte.ext.vteapp.data",
+ VTE_PROPERTY_DATA,
+ VTE_PROPERTY_FLAG_NONE);
}
static void
@@ -2378,6 +2408,22 @@ window_selection_changed_cb(VteTerminal* terminal,
window_update_copy_sensitivity(window);
}
+static void
+window_termprop_changed_cb(VteTerminal* terminal,
+ char const* prop,
+ VteappWindow* window)
+{
+ if (auto const value = vte::take_freeable
+ (vte_terminal_get_termprop_variant(terminal, prop))) {
+ auto str = vte::glib::take_string(g_variant_print(value.get(), true));
+ verbose_print("Termprop '%s' changed to '%s'\n",
+ prop, str.get());
+ } else {
+ verbose_print("Termprop '%s' changed to no-value\n",
+ prop);
+ }
+}
+
static void
window_input_enabled_state_cb(GAction* action,
GParamSpec* pspec,
@@ -2541,6 +2587,7 @@ vteapp_window_constructed(GObject *object)
g_signal_connect(window->terminal, "resize-window", G_CALLBACK(window_resize_window_cb), window);
g_signal_connect(window->terminal, "restore-window", G_CALLBACK(window_restore_window_cb), window);
g_signal_connect(window->terminal, "selection-changed", G_CALLBACK(window_selection_changed_cb),
window);
+ g_signal_connect(window->terminal, "termprop-changed", G_CALLBACK(window_termprop_changed_cb),
window);
g_signal_connect(window->terminal, "window-title-changed",
G_CALLBACK(window_window_title_changed_cb), window);
if (options.object_notifications)
g_signal_connect(window->terminal, "notify", G_CALLBACK(window_notify_cb), window);
diff --git a/src/marshal.list b/src/marshal.list
index 241128c3..16bef201 100644
--- a/src/marshal.list
+++ b/src/marshal.list
@@ -1,3 +1,4 @@
+BOOLEAN:POINTER,INT
VOID:STRING,BOXED
VOID:STRING,UINT
VOID:UINT,UINT
diff --git a/src/vte/vteenums.h b/src/vte/vteenums.h
index 4082fe88..a848317d 100644
--- a/src/vte/vteenums.h
+++ b/src/vte/vteenums.h
@@ -215,4 +215,41 @@ typedef enum {
VTE_ALIGN_END = 3U,
} VteAlign;
+/**
+ * VtePropertyFlags:
+ * @VTE_PROPERTY_FLAG_NONE: no flags, default
+ *
+ * A flags type.
+ *
+ * Since: 0.70
+ */
+typedef enum /*< flags >*/ {
+ VTE_PROPERTY_FLAG_NONE = 0,
+} VtePropertyFlags;
+
+/**
+ * VtePropertyType:
+ * @VTE_PROPERTY_VALUELESS: no value, use for signalling
+ * @VTE_PROPERTY_BOOL: a bool, %FALSE if default
+ * @VTE_PROPERTY_INT16: a signed integer, or 0 if default
+ * @VTE_PROPERTY_UINT16: an integer, or 0 if default
+ * @VTE_PROPERTY_COLOR: a color, or %NULL if default
+ * @VTE_PROPERTY_STRING: a string, or %NULL if default
+ * @VTE_PROPERTY_DATA: binary data, or %NULL if default
+ *
+ * An enumeration type describing types of properties.
+ *
+ * Since: 0.70
+ */
+typedef enum {
+ VTE_PROPERTY_INVALID = -1, /*< skip >*/
+ VTE_PROPERTY_VALUELESS = 0,
+ VTE_PROPERTY_BOOL,
+ VTE_PROPERTY_INT16,
+ VTE_PROPERTY_UINT16,
+ VTE_PROPERTY_COLOR,
+ VTE_PROPERTY_STRING,
+ VTE_PROPERTY_DATA,
+} VtePropertyType;
+
G_END_DECLS
diff --git a/src/vte/vteterminal.h b/src/vte/vteterminal.h
index 0d3cf51c..bca0b4e8 100644
--- a/src/vte/vteterminal.h
+++ b/src/vte/vteterminal.h
@@ -114,11 +114,17 @@ struct _VteTerminalClass {
gpointer _extra_padding[3];
#endif /* _VTE_GTK == 3 */
+ gboolean (* termprops_changed)(VteTerminal* terminal,
+ GQuark const* props,
+ int n_props);
+ void (* termprop_changed)(VteTerminal* terminal,
+ char const* prop);
+
/* Add new vfuncs here, and subtract from the padding below. */
/* Padding for future expansion. */
#if _VTE_GTK == 3
- gpointer _padding[13];
+ gpointer _padding[11];
#elif _VTE_GTK == 4
gpointer _padding[16];
#endif /* _VTE_GTK */
@@ -127,6 +133,16 @@ struct _VteTerminalClass {
VteTerminalClassPrivate *priv;
};
+_VTE_PUBLIC
+void vte_terminal_class_install_termprop(VteTerminalClass *klass,
+ char const* name,
+ VtePropertyType type,
+ VtePropertyFlags flags) _VTE_CXX_NOEXCEPT _VTE_GNUC_NONNULL(1, 2);
+
+_VTE_PUBLIC
+VtePropertyType vte_terminal_class_get_termprop_type(VteTerminalClass *klass,
+ char const* name) _VTE_CXX_NOEXCEPT
_VTE_GNUC_NONNULL(1, 2);
+
typedef gboolean (*VteSelectionFunc)(VteTerminal *terminal,
glong column,
glong row,
@@ -579,6 +595,52 @@ void vte_terminal_set_yfill(VteTerminal* terminal,
_VTE_PUBLIC
gboolean vte_terminal_get_yfill(VteTerminal* terminal) _VTE_CXX_NOEXCEPT _VTE_GNUC_NONNULL(1);
+_VTE_PUBLIC
+gboolean vte_terminal_get_termprop_bool(VteTerminal* terminal,
+ char const* prop,
+ gboolean *value) _VTE_CXX_NOEXCEPT _VTE_GNUC_NONNULL(1, 2);
+
+_VTE_PUBLIC
+gboolean vte_terminal_get_termprop_int(VteTerminal* terminal,
+ char const* prop,
+ int64_t *value) _VTE_CXX_NOEXCEPT _VTE_GNUC_NONNULL(1, 2);
+
+_VTE_PUBLIC
+gboolean vte_terminal_get_termprop_uint(VteTerminal* terminal,
+ char const* prop,
+ uint64_t *value) _VTE_CXX_NOEXCEPT _VTE_GNUC_NONNULL(1, 2);
+
+_VTE_PUBLIC
+gboolean vte_terminal_get_termprop_color(VteTerminal* terminal,
+ char const* prop,
+ GdkRGBA* color) _VTE_CXX_NOEXCEPT _VTE_GNUC_NONNULL(1, 2, 3);
+
+_VTE_PUBLIC
+char const* vte_terminal_get_termprop_string(VteTerminal* terminal,
+ char const* prop) _VTE_CXX_NOEXCEPT _VTE_GNUC_NONNULL(1, 2);
+
+_VTE_PUBLIC
+guint8 const* vte_terminal_get_termprop_data(VteTerminal* terminal,
+ char const* prop,
+ size_t* size) _VTE_CXX_NOEXCEPT _VTE_GNUC_NONNULL(1, 2, 3);
+
+_VTE_PUBLIC
+GBytes* vte_terminal_get_termprop_data_bytes(VteTerminal* terminal,
+ char const* prop) _VTE_CXX_NOEXCEPT _VTE_GNUC_NONNULL(1, 2);
+
+_VTE_PUBLIC
+gboolean vte_terminal_get_termprop_value(VteTerminal* terminal,
+ char const* prop,
+ GValue* gvalue) _VTE_CXX_NOEXCEPT _VTE_GNUC_NONNULL(1, 2, 3);
+
+_VTE_PUBLIC
+GVariant* vte_terminal_get_termprop_variant(VteTerminal* terminal,
+ char const* prop) _VTE_CXX_NOEXCEPT _VTE_GNUC_NONNULL(1, 2);
+
+_VTE_PUBLIC
+void vte_terminal_reset_termprop(VteTerminal* terminal,
+ char const* prop) _VTE_CXX_NOEXCEPT _VTE_GNUC_NONNULL(1, 2);
+
G_DEFINE_AUTOPTR_CLEANUP_FUNC(VteTerminal, g_object_unref)
G_END_DECLS
diff --git a/src/vtegtk.cc b/src/vtegtk.cc
index f94b8121..b6517964 100644
--- a/src/vtegtk.cc
+++ b/src/vtegtk.cc
@@ -276,6 +276,28 @@ catch (...)
vte::log_exception();
}
+static gboolean
+vte_terminal_real_termprops_changed(VteTerminal *terminal,
+ GQuark const* keys,
+ int n_keys) noexcept
+try
+{
+ for (auto i = 0; i < n_keys; ++i) {
+ g_signal_emit(terminal,
+ signals[SIGNAL_TERMPROP_CHANGED],
+ keys[i], /* detail */
+ g_quark_to_string(keys[i]));
+
+ }
+
+ return false;
+}
+catch (...)
+{
+ vte::log_exception();
+ return false;
+}
+
#if VTE_GTK == 3
static void
@@ -1184,6 +1206,14 @@ catch (...)
vte::log_exception();
}
+static void
+_vte_terminal_class_install_termprop(VteTerminalClass* klass,
+ char const* name,
+ VtePropertyType type,
+ VtePropertyFlags flags) noexcept
+{
+}
+
static void
vte_terminal_class_init(VteTerminalClass *klass)
{
@@ -1306,6 +1336,9 @@ vte_terminal_class_init(VteTerminalClass *klass)
klass->bell = NULL;
+ klass->termprops_changed = vte_terminal_real_termprops_changed;
+ klass->termprop_changed = nullptr;
+
/* GtkScrollable interface properties */
g_object_class_override_property (gobject_class, PROP_HADJUSTMENT, "hadjustment");
g_object_class_override_property (gobject_class, PROP_VADJUSTMENT, "vadjustment");
@@ -1924,6 +1957,72 @@ vte_terminal_class_init(VteTerminalClass *klass)
G_OBJECT_CLASS_TYPE(klass),
g_cclosure_marshal_VOID__VOIDv);
+ /**
+ * VteTerminal::termprop-changed:
+ * @vteterminal: the object which received the signal
+ * @name: the name of the changed property
+ *
+ * The "termprop-changed" signal is emitted when a termprop
+ * has changed or been reset. The handler may use one of the
+ * vte_terminal_get_termprop_*() functions to retrieve the
+ * new value, but must not call any other API on @terminal.
+ *
+ * This signal supports detailed connections, so e.g. subscribing
+ * to "termprop-changed::name" only runs the callback when the
+ * termprop "name" has changed.
+ *
+ * Since: 0.70
+ */
+ signals[SIGNAL_TERMPROP_CHANGED] =
+ g_signal_new(I_("termprop-changed"),
+ G_OBJECT_CLASS_TYPE(klass),
+ GSignalFlags(G_SIGNAL_RUN_LAST |
+ G_SIGNAL_DETAILED),
+ G_STRUCT_OFFSET(VteTerminalClass, termprop_changed),
+ nullptr,
+ nullptr,
+ g_cclosure_marshal_VOID__STRING,
+ G_TYPE_NONE,
+ 1,
+ G_TYPE_STRING | G_SIGNAL_TYPE_STATIC_SCOPE);
+ g_signal_set_va_marshaller(signals[SIGNAL_TERMPROP_CHANGED],
+ G_OBJECT_CLASS_TYPE(klass),
+ g_cclosure_marshal_VOID__STRINGv);
+
+ /**
+ * VteTerminal::termprops-changed:
+ * @vteterminal: the object which received the signal
+ * @keys: (array length=n_keys) (element-type GQuark): an array of #GQuark
+ * @n_keys: the length of the @keys array
+ *
+ * Emitted when termprops have changed. @keys is an array containing
+ * #GQuark of the names of the changed properties.
+ *
+ * The default handler for this signal emits the "termprop-changed"
+ * signal for each changed property. Returning %TRUE from a handler
+ * running before the default will prevent this.
+ *
+ * Returns: %TRUE to stop further handlers being invoked for this signal,
+ * or %FALSE to continue signal emission
+ *
+ * Since: 0.70
+ */
+ signals[SIGNAL_TERMPROPS_CHANGED] =
+ g_signal_new(I_("termprops-changed"),
+ G_OBJECT_CLASS_TYPE(klass),
+ G_SIGNAL_RUN_LAST,
+ G_STRUCT_OFFSET(VteTerminalClass, termprops_changed),
+ g_signal_accumulator_true_handled,
+ nullptr,
+ _vte_marshal_BOOLEAN__POINTER_INT,
+ G_TYPE_BOOLEAN,
+ 2,
+ G_TYPE_POINTER,
+ G_TYPE_INT);
+ g_signal_set_va_marshaller(signals[SIGNAL_TERMPROPS_CHANGED],
+ G_OBJECT_CLASS_TYPE(klass),
+ _vte_marshal_BOOLEAN__POINTER_INTv);
+
/**
* VteTerminal::bell:
* @vteterminal: the object which received the signal
@@ -2464,10 +2563,112 @@ vte_terminal_class_init(VteTerminalClass *klass)
gtk_widget_class_set_accessible_type(widget_class, VTE_TYPE_TERMINAL_ACCESSIBLE);
#endif
#endif
+
+ /* Install termprops */
}
/* public API */
+/**
+ * vte_terminal_class_install_termprop:
+ * @klass: the #VteTerminalClass
+ * @name: a namespaced property name
+ * @type: a #VtePropertyType to use for the property
+ * @flags: flags from #VtePropertyFlags
+ *
+ * Installs a new terminal property that can be set by the application.
+ *
+ * Note that @name must contain consist of at least 4 components separated by
+ * a dot ('.'), and each component must only contain the characters [a-z0-9-]
+ * and start with a character from [a-z], and start with "vte.ext.". You should
+ * use an identifier for your terminal as the first component after the prefix
+ * as a namespace marker.
+ *
+ * To set such a property, use the "OSC 777 ; set ( ; <prop> ( =<value> )? )* ST"
+ * sequence containing zero or more "<prop> (= <value>)" assignments delimited
+ * by semicolons (';').
+ * Omitting the "= <value>" part resets the property to its default value.
+ *
+ * The supported values for each type are as follows:
+ *
+ * * A property of type %VTE_PROPERTY_VALUELESS has no value.
+ * This type of property can be used for signalling.
+ *
+ * * A property of type %VTE_PROPERTY_BOOL is a boolean property, and
+ * takes the <value> "0" for %FALSE and and "1" for %TRUE.
+ * The default value is %FALSE.
+ *
+ * * A property of type %VTE_PROPERTY_UINT16 is an int16_t, and takes
+ * a string of digits and an optional leading minus sign, that when
+ * converted to a number must be between -32768 and 32767.
+ * The default value is 0.
+ *
+ * * A property of type %VTE_PROPERTY_UINT16 is an uint16_t, and takes
+ * a string of digits that when converted to a number must be between
+ * 0 and 65535.
+ * The default value is 0.
+ *
+ * * A property of type %VTE_PROPERTY_COLOR is a color, and takes a string
+ * in the format "#xxxxxx" where x is any hexadecimal digit [0-9a-fA-F].
+ * The default value is "#000000".
+ *
+ * * A property of type %VTE_PROPERTY_STRING is a string.
+ * Note that due to the OSC syntax, that string must not contain semicolons (';').
+ * There is no standard way to escape a semicolon, either. The maximum size
+ * of the value is 1024 codepoints.
+ * The default value is %NULL.
+ *
+ * * A property of type %VTE_PROPERTY_DATA is binary data, and takes
+ * a string that is base64-encoded in the default alphabet. The maximum size
+ * of the data (after base64 decoding) is 2048 bytes.
+ * The default value is %NULL.
+ *
+ * Setting a property to a <value> that does not conform to these requirements
+ * resets the value to its default value.
+ *
+ * Note also the limit on the total length of the OSC control string of 4096
+ * unicode codepoints between the OSC and the ST (excluding both).
+ *
+ * On reset, all termprops are reset to their default values.
+ *
+ * The #VteTerminal:termprop-changed signal will be emitted with
+ * the names of the changed properties.
+ *
+ * It is a programming error to call this function after any #VteTerminal
+ * instances have already been created.
+ *
+ * Since: 0.70
+ */
+void
+vte_terminal_class_install_termprop(VteTerminalClass *klass,
+ char const* name,
+ VtePropertyType type,
+ VtePropertyFlags flags) noexcept
+{
+}
+
+/**
+ * vte_terminal_class_get_termprop_type:
+ * @klass: the #VteTerminalClass
+ * @name: a namespaced property name
+ *
+ * Gets the property type of the termprop. Note that in contrast to
+ * vte_terminal_class_install_termprop(), @name must contain the full
+ * name. For properties installed via vte_terminal_class_install_termprop(),
+ * the name starts with "vte.ext.".
+ *
+ * Returns: the #VtePropertyType of the named termprop, or %VTE_PROPERTY_INVALID
+ * if there is no termprop of that name.
+ *
+ * Since: 0.70
+ */
+VtePropertyType
+vte_terminal_class_get_termprop_type(VteTerminalClass *klass,
+ char const* name) noexcept
+{
+ return VTE_PROPERTY_INVALID;
+}
+
/**
* vte_get_features:
*
@@ -6491,3 +6692,213 @@ catch (...)
vte::log_exception();
return true;
}
+
+/**
+ * vte_terminal_get_termprop_bool:
+ * @terminal: a #VteTerminal
+ * @prop: a termprop name
+ * @value: (nullable): a location to store the value, or %NULL
+ *
+ * For a %VTE_PROPERTY_BOOL termprop, sets @value to @prop's value,
+ * or to %FALSE if @prop is unset, or @prop is not a registered property.
+ *
+ * Returns: whether the property is set
+ *
+ * Since: 0.70
+ */
+gboolean
+vte_terminal_get_termprop_bool(VteTerminal* terminal,
+ char const* prop,
+ gboolean *value) noexcept
+{
+ if (value)
+ *value = false;
+ return false;
+}
+
+/**
+ * vte_terminal_get_termprop_int:
+ * @terminal: a #VteTerminal
+ * @prop: a termprop name
+ * @value: (nullable): a location to store the value, or %NULL
+ *
+ * For a %VTE_PROPERTY_INT16 termprop, sets @value to @prop's value,
+ * or to 0 if @prop is unset, or @prop is not a registered property.
+ *
+ * Returns: whether the property is set
+ *
+ * Since: 0.70
+ */
+gboolean
+vte_terminal_get_termprop_int(VteTerminal* terminal,
+ char const* prop,
+ int64_t *value) noexcept
+{
+ if (value)
+ *value = 0;
+ return false;
+}
+
+/**
+ * vte_terminal_get_termprop_uint:
+ * @terminal: a #VteTerminal
+ * @prop: a termprop name
+ * @value: (nullable): a location to store the value, or %NULL
+ *
+ * For a %VTE_PROPERTY_UINT16 termprop, sets @value to @prop's value,
+ * or to 0 if @prop is unset, or @prop is not a registered property.
+ *
+ * Returns: whether the property is set
+ *
+ * Since: 0.70
+ */
+gboolean
+vte_terminal_get_termprop_uint(VteTerminal* terminal,
+ char const* prop,
+ uint64_t *value) noexcept
+{
+ if (value)
+ *value = 0;
+ return false;
+}
+
+/**
+ * vte_terminal_get_termprop_color:
+ * @terminal: a #VteTerminal
+ * @prop: a termprop name
+ * @color: (out): a #GdkRGBA to fill in
+ *
+ * Stores the value of a %VTE_PROPERTY_COLOR termprop in @color and
+ * returns %TRUE if the termprop is set, or stores rgba(0,0,0,0) in @color
+ * and returns %FALSE if the termprop is unset.
+ *
+ * Returns: %TRUE iff the termprop is set
+ *
+ * Since: 0.70
+ */
+gboolean
+vte_terminal_get_termprop_color(VteTerminal* terminal,
+ char const* prop,
+ GdkRGBA* color) noexcept
+{
+ *color = GdkRGBA{0., 0., 0., 0.};
+ return false;
+}
+
+/**
+ * vte_terminal_get_termprop_string:
+ * @terminal: a #VteTerminal
+ * @prop: a termprop name
+ *
+ * Returns the value of a %VTE_PROPERTY_STRING termprop, or %NULL if
+ * @prop is unset, or @prop is not a registered property.
+ *
+ * Returns: (transfer none) (nullable): the property's value, or %NULL
+ *
+ * Since: 0.70
+ */
+char const*
+vte_terminal_get_termprop_string(VteTerminal* terminal,
+ char const* prop) noexcept
+{
+ return nullptr;
+}
+
+/**
+ * vte_terminal_get_termprop_data:
+ * @terminal: a #VteTerminal
+ * @prop: a termprop name
+ * @size: (out): size of the data
+ *
+ * Returns the value of a %VTE_PROPERTY_DATA termprop, or %NULL if
+ * @prop is unset, or @prop is not a registered property.
+ *
+ * Returns: (transfer none) (element-type guint8) (array length=size): the property's value, or %NULL
+ *
+ * Since: 0.70
+ */
+guint8 const*
+vte_terminal_get_termprop_data(VteTerminal* terminal,
+ char const* prop,
+ size_t* size) noexcept
+{
+ *size = 0;
+ return nullptr;
+
+}
+
+/**
+ * vte_terminal_get_termprop_data_bytes:
+ * @terminal: a #VteTerminal
+ * @prop: a termprop name
+ * @size: (out): size of the data
+ *
+ * Returns the value of a %VTE_PROPERTY_DATA termprop as a #GBytes, or %NULL if
+ * @prop is unset, or @prop is not a registered property.
+ *
+ * Returns: (transfer full): the property's value as a #GBytes, or %NULL
+ *
+ * Since: 0.70
+ */
+GBytes*
+vte_terminal_get_termprop_data_bytes(VteTerminal* terminal,
+ char const* prop) noexcept
+{
+ return nullptr;
+}
+
+/**
+ * vte_terminal_get_termprop_value:
+ * @terminal: a #VteTerminal
+ * @prop: a termprop name
+ * @gvalue: (out): a #GValue to be filled in
+ *
+ * Returns %TRUE with the value of @prop stored in @value, or %FALSE if
+ * @prop is not a registered property and @value unset.
+ *
+ * Returns: whether the property exists
+ *
+ * Since: 0.70
+ */
+gboolean
+vte_terminal_get_termprop_value(VteTerminal* terminal,
+ char const* prop,
+ GValue* gvalue) noexcept
+{
+ return false;
+}
+
+/**
+ * vte_terminal_get_termprop_variant:
+ * @terminal: a #VteTerminal
+ * @prop: a termprop name
+ *
+ * Returns the value of @prop as a #GVariant, or %NULL if
+ * @prop is not a registered property @prop.
+ *
+ *
+ * Returns: (transfer full): a floating #GVariant, or %NULL
+ *
+ * Since: 0.70
+ */
+GVariant*
+vte_terminal_get_termprop_variant(VteTerminal* terminal,
+ char const* prop) noexcept
+{
+ return nullptr;
+}
+
+/**
+ * vte_terminal_reset_termprop:
+ * @terminal: a #VteTerminal
+ * @prop: a termprop name
+ *
+ * Resets the termprop @prop to its default value.
+ *
+ * Since: 0.70
+ */
+void
+vte_terminal_reset_termprop(VteTerminal* terminal,
+ char const* prop) noexcept
+{
+}
diff --git a/src/vtegtk.hh b/src/vtegtk.hh
index 778b555a..b92185d1 100644
--- a/src/vtegtk.hh
+++ b/src/vtegtk.hh
@@ -52,6 +52,8 @@ enum {
SIGNAL_RESIZE_WINDOW,
SIGNAL_RESTORE_WINDOW,
SIGNAL_SELECTION_CHANGED,
+ SIGNAL_TERMPROPS_CHANGED,
+ SIGNAL_TERMPROP_CHANGED,
SIGNAL_WINDOW_TITLE_CHANGED,
LAST_SIGNAL
};
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]