X-Git-Url: http://pileus.org/git/?a=blobdiff_plain;f=gtk%2Fgtktexttag.c;h=8674e92c9f0cd74a2be7f9a049c56bfc5dd3e026;hb=1247a842a228980a06893e6167ae8c73a4bb6eed;hp=fbd90eb4cac3f25cd7b8b7fefe7216458cebd380;hpb=be317eb291fa14d548aa5dcf7de0fd129657d740;p=~andy%2Fgtk
diff --git a/gtk/gtktexttag.c b/gtk/gtktexttag.c
index fbd90eb4c..8674e92c9 100644
--- a/gtk/gtktexttag.c
+++ b/gtk/gtktexttag.c
@@ -47,18 +47,40 @@
*
*/
-#include "gtkmain.h"
+/**
+ * SECTION:gtktexttag
+ * @Title: GtkTextTag
+ * @Short_description: A tag that can be applied to text in a GtkTextBuffer
+ *
+ * You may wish to begin by reading the text widget
+ * conceptual overview which gives an overview of all the objects and
+ * data types related to the text widget and how they work together.
+ *
+ * Tags should be in the #GtkTextTagTable for a given #GtkTextBuffer
+ * before using them with that buffer.
+ *
+ * gtk_text_buffer_create_tag() is the best way to create tags.
+ * See gtk3-demo for numerous examples.
+ *
+ * For each property of #GtkTextTag, there is a "set" property, e.g.
+ * "font-set" corresponds to "font". These "set" properties reflect
+ * whether a property has been set or not.
+ * They are maintained by GTK+ and you should not set them independently.
+ */
+
+#include "config.h"
+
+#include
+#include
+
#include "gtktexttag.h"
#include "gtktexttypes.h"
#include "gtktexttagtable.h"
-#include "gtksignal.h"
-#include "gtkmain.h"
#include "gtkintl.h"
+#include "gtkmarshalers.h"
+#include "gtkprivate.h"
#include "gtktypebuiltins.h"
-#include
-#include
-
enum {
EVENT,
LAST_SIGNAL
@@ -74,8 +96,8 @@ enum {
PROP_FOREGROUND,
PROP_BACKGROUND_GDK,
PROP_FOREGROUND_GDK,
- PROP_BACKGROUND_STIPPLE,
- PROP_FOREGROUND_STIPPLE,
+ PROP_BACKGROUND_RGBA,
+ PROP_FOREGROUND_RGBA,
PROP_FONT,
PROP_FONT_DESC,
PROP_FAMILY,
@@ -99,16 +121,20 @@ enum {
PROP_RIGHT_MARGIN,
PROP_UNDERLINE,
PROP_RISE,
- PROP_BG_FULL_HEIGHT,
+ PROP_BACKGROUND_FULL_HEIGHT,
PROP_LANGUAGE,
PROP_TABS,
PROP_INVISIBLE,
+ PROP_PARAGRAPH_BACKGROUND,
+ PROP_PARAGRAPH_BACKGROUND_GDK,
+ PROP_PARAGRAPH_BACKGROUND_RGBA,
+
+ /* Behavior args */
+ PROP_ACCUMULATIVE_MARGIN,
/* Whether-a-style-arg-is-set args */
PROP_BACKGROUND_SET,
PROP_FOREGROUND_SET,
- PROP_BACKGROUND_STIPPLE_SET,
- PROP_FOREGROUND_STIPPLE_SET,
PROP_FAMILY_SET,
PROP_STYLE_SET,
PROP_VARIANT_SET,
@@ -128,15 +154,14 @@ enum {
PROP_RIGHT_MARGIN_SET,
PROP_UNDERLINE_SET,
PROP_RISE_SET,
- PROP_BG_FULL_HEIGHT_SET,
+ PROP_BACKGROUND_FULL_HEIGHT_SET,
PROP_LANGUAGE_SET,
PROP_TABS_SET,
PROP_INVISIBLE_SET,
+ PROP_PARAGRAPH_BACKGROUND_SET,
LAST_ARG
};
-static void gtk_text_tag_init (GtkTextTag *text_tag);
-static void gtk_text_tag_class_init (GtkTextTagClass *klass);
static void gtk_text_tag_finalize (GObject *object);
static void gtk_text_tag_set_property (GObject *object,
guint prop_id,
@@ -147,45 +172,15 @@ static void gtk_text_tag_get_property (GObject *object,
GValue *value,
GParamSpec *pspec);
-static GObjectClass *parent_class = NULL;
static guint signals[LAST_SIGNAL] = { 0 };
-GType
-gtk_text_tag_get_type (void)
-{
- static GType our_type = 0;
-
- if (our_type == 0)
- {
- static const GTypeInfo our_info =
- {
- sizeof (GtkTextTagClass),
- (GBaseInitFunc) NULL,
- (GBaseFinalizeFunc) NULL,
- (GClassInitFunc) gtk_text_tag_class_init,
- NULL, /* class_finalize */
- NULL, /* class_data */
- sizeof (GtkTextTag),
- 0, /* n_preallocs */
- (GInstanceInitFunc) gtk_text_tag_init
- };
-
- our_type = g_type_register_static (G_TYPE_OBJECT,
- "GtkTextTag",
- &our_info,
- 0);
- }
-
- return our_type;
-}
+G_DEFINE_TYPE (GtkTextTag, gtk_text_tag, G_TYPE_OBJECT)
static void
gtk_text_tag_class_init (GtkTextTagClass *klass)
{
GObjectClass *object_class = G_OBJECT_CLASS (klass);
- parent_class = g_type_class_peek_parent (klass);
-
object_class->set_property = gtk_text_tag_set_property;
object_class->get_property = gtk_text_tag_get_property;
@@ -195,452 +190,586 @@ gtk_text_tag_class_init (GtkTextTagClass *klass)
g_object_class_install_property (object_class,
PROP_NAME,
g_param_spec_string ("name",
- _("Tag name"),
- _("Name used to refer to the text tag"),
+ P_("Tag name"),
+ P_("Name used to refer to the text tag. NULL for anonymous tags"),
NULL,
- G_PARAM_READABLE | G_PARAM_WRITABLE | G_PARAM_CONSTRUCT_ONLY));
+ GTK_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY));
/* Style args */
g_object_class_install_property (object_class,
PROP_BACKGROUND,
g_param_spec_string ("background",
- _("Background color name"),
- _("Background color as a string"),
+ P_("Background color name"),
+ P_("Background color as a string"),
NULL,
- G_PARAM_WRITABLE));
-
+ GTK_PARAM_WRITABLE));
+
+ /**
+ * GtkTextTag:background-gdk:
+ *
+ * Background color as a #GdkColor.
+ *
+ * Deprecated: 3.4: Use #GtkTextTag:background-rgba instead.
+ */
g_object_class_install_property (object_class,
PROP_BACKGROUND_GDK,
- g_param_spec_boxed ("background_gdk",
- _("Background color"),
- _("Background color as a GdkColor"),
+ g_param_spec_boxed ("background-gdk",
+ P_("Background color"),
+ P_("Background color as a GdkColor"),
GDK_TYPE_COLOR,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE | G_PARAM_DEPRECATED));
+
+ /**
+ * GtkTextTag:background-rgba:
+ *
+ * Background color as a #GdkRGBA.
+ *
+ * Since: 3.2
+ */
+ g_object_class_install_property (object_class,
+ PROP_BACKGROUND_RGBA,
+ g_param_spec_boxed ("background-rgba",
+ P_("Background RGBA"),
+ P_("Background color as a GdkRGBA"),
+ GDK_TYPE_RGBA,
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
- PROP_BG_FULL_HEIGHT,
- g_param_spec_boolean ("background_full_height",
- _("Background full height"),
- _("Whether the background color fills the entire line height or only the height of the tagged characters"),
+ PROP_BACKGROUND_FULL_HEIGHT,
+ g_param_spec_boolean ("background-full-height",
+ P_("Background full height"),
+ P_("Whether the background color fills the entire line height or only the height of the tagged characters"),
FALSE,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
-
+ GTK_PARAM_READWRITE));
- g_object_class_install_property (object_class,
- PROP_BACKGROUND_STIPPLE,
- g_param_spec_object ("background_stipple",
- _("Background stipple mask"),
- _("Bitmap to use as a mask when drawing the text background"),
- GDK_TYPE_PIXMAP,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
-
-
g_object_class_install_property (object_class,
PROP_FOREGROUND,
g_param_spec_string ("foreground",
- _("Foreground color name"),
- _("Foreground color as a string"),
+ P_("Foreground color name"),
+ P_("Foreground color as a string"),
NULL,
- G_PARAM_WRITABLE));
-
+ GTK_PARAM_WRITABLE));
+
+ /**
+ * GtkTextTag:foreground-gdk:
+ *
+ * Foreground color as a #GdkColor.
+ *
+ * Deprecated: 3.4: Use #GtkTextTag:foreground-rgba instead.
+ */
g_object_class_install_property (object_class,
PROP_FOREGROUND_GDK,
- g_param_spec_boxed ("foreground_gdk",
- _("Foreground color"),
- _("Foreground color as a GdkColor"),
+ g_param_spec_boxed ("foreground-gdk",
+ P_("Foreground color"),
+ P_("Foreground color as a GdkColor"),
GDK_TYPE_COLOR,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
-
-
+ GTK_PARAM_READWRITE | G_PARAM_DEPRECATED));
+
+ /**
+ * GtkTextTag:foreground-rgba:
+ *
+ * Foreground color as a #GdkRGBA.
+ *
+ * Since: 3.2
+ */
g_object_class_install_property (object_class,
- PROP_FOREGROUND_STIPPLE,
- g_param_spec_object ("foreground_stipple",
- _("Foreground stipple mask"),
- _("Bitmap to use as a mask when drawing the text foreground"),
- GDK_TYPE_PIXMAP,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
-
+ PROP_FOREGROUND_RGBA,
+ g_param_spec_boxed ("foreground-rgba",
+ P_("Foreground RGBA"),
+ P_("Foreground color as a GdkRGBA"),
+ GDK_TYPE_RGBA,
+ GTK_PARAM_READWRITE));
+
g_object_class_install_property (object_class,
PROP_DIRECTION,
g_param_spec_enum ("direction",
- _("Text direction"),
- _("Text direction, e.g. right-to-left or left-to-right"),
+ P_("Text direction"),
+ P_("Text direction, e.g. right-to-left or left-to-right"),
GTK_TYPE_TEXT_DIRECTION,
- GTK_TEXT_DIR_LTR,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_TEXT_DIR_NONE,
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_EDITABLE,
g_param_spec_boolean ("editable",
- _("Editable"),
- _("Whether the text can be modified by the user"),
+ P_("Editable"),
+ P_("Whether the text can be modified by the user"),
TRUE,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
-
+ GTK_PARAM_READWRITE));
+
+ /**
+ * GtkTextTag:font:
+ *
+ * Font description as string, e.g. \"Sans Italic 12\".
+ *
+ * Note that the initial value of this property depends on
+ * the internals of #PangoFontDescription.
+ */
g_object_class_install_property (object_class,
PROP_FONT,
g_param_spec_string ("font",
- _("Font"),
- _("Font description as a string"),
+ P_("Font"),
+ P_("Font description as a string, e.g. \"Sans Italic 12\""),
NULL,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_FONT_DESC,
- g_param_spec_boxed ("font_desc",
- _("Font"),
- _("Font description as a PangoFontDescription struct"),
+ g_param_spec_boxed ("font-desc",
+ P_("Font"),
+ P_("Font description as a PangoFontDescription struct"),
PANGO_TYPE_FONT_DESCRIPTION,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
-
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_FAMILY,
g_param_spec_string ("family",
- _("Font family"),
- _("Name of the font family, e.g. Sans, Helvetica, Times, Monospace"),
+ P_("Font family"),
+ P_("Name of the font family, e.g. Sans, Helvetica, Times, Monospace"),
NULL,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_STYLE,
g_param_spec_enum ("style",
- _("Font style"),
- _("Font style"),
+ P_("Font style"),
+ P_("Font style as a PangoStyle, e.g. PANGO_STYLE_ITALIC"),
PANGO_TYPE_STYLE,
PANGO_STYLE_NORMAL,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_VARIANT,
g_param_spec_enum ("variant",
- _("Font variant"),
- _("Font variant"),
+ P_("Font variant"),
+ P_("Font variant as a PangoVariant, e.g. PANGO_VARIANT_SMALL_CAPS"),
PANGO_TYPE_VARIANT,
PANGO_VARIANT_NORMAL,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_WEIGHT,
g_param_spec_int ("weight",
- _("Font weight"),
- _("Font weight"),
+ P_("Font weight"),
+ P_("Font weight as an integer, see predefined values in PangoWeight; for example, PANGO_WEIGHT_BOLD"),
0,
G_MAXINT,
PANGO_WEIGHT_NORMAL,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_STRETCH,
g_param_spec_enum ("stretch",
- _("Font stretch"),
- _("Font stretch"),
+ P_("Font stretch"),
+ P_("Font stretch as a PangoStretch, e.g. PANGO_STRETCH_CONDENSED"),
PANGO_TYPE_STRETCH,
PANGO_STRETCH_NORMAL,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_SIZE,
g_param_spec_int ("size",
- _("Font size"),
- _("Font size"),
+ P_("Font size"),
+ P_("Font size in Pango units"),
0,
G_MAXINT,
0,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_SCALE,
g_param_spec_double ("scale",
- _("Font scale"),
- _("Font scale"),
+ P_("Font scale"),
+ P_("Font size as a scale factor relative to the default font size. This properly adapts to theme changes etc. so is recommended. Pango predefines some scales such as PANGO_SCALE_X_LARGE"),
0.0,
G_MAXDOUBLE,
1.0,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_SIZE_POINTS,
- g_param_spec_double ("size_points",
- _("Font points"),
- _("Font size in points"),
+ g_param_spec_double ("size-points",
+ P_("Font points"),
+ P_("Font size in points"),
0.0,
G_MAXDOUBLE,
0.0,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_JUSTIFICATION,
g_param_spec_enum ("justification",
- _("Justification"),
- _("Left, right, or center justification"),
+ P_("Justification"),
+ P_("Left, right, or center justification"),
GTK_TYPE_JUSTIFICATION,
GTK_JUSTIFY_LEFT,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
-
+ GTK_PARAM_READWRITE));
+
+ /**
+ * GtkTextTag:language:
+ *
+ * The language this text is in, as an ISO code. Pango can use this as a
+ * hint when rendering the text. If not set, an appropriate default will be
+ * used.
+ *
+ * Note that the initial value of this property depends on the current
+ * locale, see also gtk_get_default_language().
+ */
g_object_class_install_property (object_class,
PROP_LANGUAGE,
g_param_spec_string ("language",
- _("Language"),
- _("Language engine code to use for rendering the text"),
+ P_("Language"),
+ P_("The language this text is in, as an ISO code. Pango can use this as a hint when rendering the text. If not set, an appropriate default will be used."),
NULL,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_LEFT_MARGIN,
- g_param_spec_int ("left_margin",
- _("Left margin"),
- _("Width of the left margin in pixels"),
+ g_param_spec_int ("left-margin",
+ P_("Left margin"),
+ P_("Width of the left margin in pixels"),
0,
G_MAXINT,
0,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_RIGHT_MARGIN,
- g_param_spec_int ("right_margin",
- _("Right margin"),
- _("Width of the right margin in pixels"),
+ g_param_spec_int ("right-margin",
+ P_("Right margin"),
+ P_("Width of the right margin in pixels"),
0,
G_MAXINT,
0,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_INDENT,
g_param_spec_int ("indent",
- _("Indent"),
- _("Amount to indent the paragraph, in pixels"),
- 0,
+ P_("Indent"),
+ P_("Amount to indent the paragraph, in pixels"),
+ G_MININT,
G_MAXINT,
0,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_RISE,
g_param_spec_int ("rise",
- _("Rise"),
- _("Offset of text above the baseline (below the baseline if rise is negative)"),
- -G_MAXINT,
+ P_("Rise"),
+ P_("Offset of text above the baseline (below the baseline if rise is negative) in Pango units"),
+ G_MININT,
G_MAXINT,
0,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_PIXELS_ABOVE_LINES,
- g_param_spec_int ("pixels_above_lines",
- _("Pixels above lines"),
- _("Pixels of blank space above paragraphs"),
+ g_param_spec_int ("pixels-above-lines",
+ P_("Pixels above lines"),
+ P_("Pixels of blank space above paragraphs"),
0,
G_MAXINT,
0,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_PIXELS_BELOW_LINES,
- g_param_spec_int ("pixels_below_lines",
- _("Pixels below lines"),
- _("Pixels of blank space below paragraphs"),
+ g_param_spec_int ("pixels-below-lines",
+ P_("Pixels below lines"),
+ P_("Pixels of blank space below paragraphs"),
0,
G_MAXINT,
0,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_PIXELS_INSIDE_WRAP,
- g_param_spec_int ("pixels_inside_wrap",
- _("Pixels inside wrap"),
- _("Pixels of blank space between wrapped lines in a paragraph"),
+ g_param_spec_int ("pixels-inside-wrap",
+ P_("Pixels inside wrap"),
+ P_("Pixels of blank space between wrapped lines in a paragraph"),
0,
G_MAXINT,
0,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_STRIKETHROUGH,
g_param_spec_boolean ("strikethrough",
- _("Strikethrough"),
- _("Whether to strike through the text"),
+ P_("Strikethrough"),
+ P_("Whether to strike through the text"),
FALSE,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_UNDERLINE,
g_param_spec_enum ("underline",
- _("Underline"),
- _("Style of underline for this text"),
+ P_("Underline"),
+ P_("Style of underline for this text"),
PANGO_TYPE_UNDERLINE,
PANGO_UNDERLINE_NONE,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_WRAP_MODE,
- g_param_spec_enum ("wrap_mode",
- _("Wrap mode"),
- _("Whether to wrap lines never, at word boundaries, or at character boundaries"),
+ g_param_spec_enum ("wrap-mode",
+ P_("Wrap mode"),
+ P_("Whether to wrap lines never, at word boundaries, or at character boundaries"),
GTK_TYPE_WRAP_MODE,
GTK_WRAP_NONE,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_TABS,
g_param_spec_boxed ("tabs",
- _("Tabs"),
- _("Custom tabs for this text"),
+ P_("Tabs"),
+ P_("Custom tabs for this text"),
PANGO_TYPE_TAB_ARRAY,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
+ /**
+ * GtkTextTag:invisible:
+ *
+ * Whether this text is hidden.
+ *
+ * Note that there may still be problems with the support for invisible
+ * text, in particular when navigating programmatically inside a buffer
+ * containing invisible segments.
+ *
+ * Since: 2.8
+ */
g_object_class_install_property (object_class,
PROP_INVISIBLE,
g_param_spec_boolean ("invisible",
- _("Invisible"),
- _("Whether this text is hidden"),
+ P_("Invisible"),
+ P_("Whether this text is hidden."),
FALSE,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
+ GTK_PARAM_READWRITE));
+
+ /**
+ * GtkTextTag:paragraph-background:
+ *
+ * The paragraph background color as a string.
+ *
+ * Since: 2.8
+ */
+ g_object_class_install_property (object_class,
+ PROP_PARAGRAPH_BACKGROUND,
+ g_param_spec_string ("paragraph-background",
+ P_("Paragraph background color name"),
+ P_("Paragraph background color as a string"),
+ NULL,
+ GTK_PARAM_WRITABLE));
+
+ /**
+ * GtkTextTag:paragraph-background-gdk:
+ *
+ * The paragraph background color as a as a #GdkColor.
+ *
+ * Since: 2.8
+ *
+ * Deprecated: 3.4: Use #GtkTextTag:paragraph-background-rgba instead.
+ */
+ g_object_class_install_property (object_class,
+ PROP_PARAGRAPH_BACKGROUND_GDK,
+ g_param_spec_boxed ("paragraph-background-gdk",
+ P_("Paragraph background color"),
+ P_("Paragraph background color as a GdkColor"),
+ GDK_TYPE_COLOR,
+ GTK_PARAM_READWRITE | G_PARAM_DEPRECATED));
+
+ /**
+ * GtkTextTag:paragraph-background-rgba:
+ *
+ * The paragraph background color as a as a #GdkRGBA.
+ *
+ * Since: 3.2
+ */
+ g_object_class_install_property (object_class,
+ PROP_PARAGRAPH_BACKGROUND_RGBA,
+ g_param_spec_boxed ("paragraph-background-rgba",
+ P_("Paragraph background RGBA"),
+ P_("Paragraph background RGBA as a GdkRGBA"),
+ GDK_TYPE_RGBA,
+ GTK_PARAM_READWRITE));
+
+ /**
+ * GtkTextTag:accumulative-margin:
+ *
+ * Whether the margins accumulate or override each other.
+ *
+ * When set to %TRUE the margins of this tag are added to the margins
+ * of any other non-accumulative margins present. When set to %FALSE
+ * the margins override one another (the default).
+ *
+ * Since: 2.12
+ */
+ g_object_class_install_property (object_class,
+ PROP_ACCUMULATIVE_MARGIN,
+ g_param_spec_boolean ("accumulative-margin",
+ P_("Margin Accumulates"),
+ P_("Whether left and right margins accumulate."),
+ FALSE,
+ GTK_PARAM_READWRITE));
/* Style props are set or not */
-#define ADD_SET_PROP(propname, propval, nick, blurb) g_object_class_install_property (object_class, propval, g_param_spec_boolean (propname, nick, blurb, FALSE, G_PARAM_READABLE | G_PARAM_WRITABLE))
+#define ADD_SET_PROP(propname, propval, nick, blurb) g_object_class_install_property (object_class, propval, g_param_spec_boolean (propname, nick, blurb, FALSE, GTK_PARAM_READWRITE))
- ADD_SET_PROP ("background_set", PROP_BACKGROUND_SET,
- _("Background set"),
- _("Whether this tag affects the background color"));
+ ADD_SET_PROP ("background-set", PROP_BACKGROUND_SET,
+ P_("Background set"),
+ P_("Whether this tag affects the background color"));
- ADD_SET_PROP ("background_full_height_set", PROP_BG_FULL_HEIGHT_SET,
- _("Background full height set"),
- _("Whether this tag affects background height"));
-
- ADD_SET_PROP ("background_stipple_set", PROP_BACKGROUND_STIPPLE_SET,
- _("Background stipple set"),
- _("Whether this tag affects the background stipple"));
+ ADD_SET_PROP ("background-full-height-set", PROP_BACKGROUND_FULL_HEIGHT_SET,
+ P_("Background full height set"),
+ P_("Whether this tag affects background height"));
- ADD_SET_PROP ("foreground_set", PROP_FOREGROUND_SET,
- _("Foreground set"),
- _("Whether this tag affects the foreground color"));
+ ADD_SET_PROP ("foreground-set", PROP_FOREGROUND_SET,
+ P_("Foreground set"),
+ P_("Whether this tag affects the foreground color"));
- ADD_SET_PROP ("foreground_stipple_set", PROP_FOREGROUND_STIPPLE_SET,
- _("Foreground stipple set"),
- _("Whether this tag affects the foreground stipple"));
-
- ADD_SET_PROP ("editable_set", PROP_EDITABLE_SET,
- _("Editability set"),
- _("Whether this tag affects text editability"));
+ ADD_SET_PROP ("editable-set", PROP_EDITABLE_SET,
+ P_("Editability set"),
+ P_("Whether this tag affects text editability"));
- ADD_SET_PROP ("family_set", PROP_FAMILY_SET,
- _("Font family set"),
- _("Whether this tag affects the font family"));
+ ADD_SET_PROP ("family-set", PROP_FAMILY_SET,
+ P_("Font family set"),
+ P_("Whether this tag affects the font family"));
- ADD_SET_PROP ("style_set", PROP_STYLE_SET,
- _("Font style set"),
- _("Whether this tag affects the font style"));
+ ADD_SET_PROP ("style-set", PROP_STYLE_SET,
+ P_("Font style set"),
+ P_("Whether this tag affects the font style"));
- ADD_SET_PROP ("variant_set", PROP_VARIANT_SET,
- _("Font variant set"),
- _("Whether this tag affects the font variant"));
+ ADD_SET_PROP ("variant-set", PROP_VARIANT_SET,
+ P_("Font variant set"),
+ P_("Whether this tag affects the font variant"));
- ADD_SET_PROP ("weight_set", PROP_WEIGHT_SET,
- _("Font weight set"),
- _("Whether this tag affects the font weight"));
+ ADD_SET_PROP ("weight-set", PROP_WEIGHT_SET,
+ P_("Font weight set"),
+ P_("Whether this tag affects the font weight"));
- ADD_SET_PROP ("stretch_set", PROP_STRETCH_SET,
- _("Font stretch set"),
- _("Whether this tag affects the font stretch"));
+ ADD_SET_PROP ("stretch-set", PROP_STRETCH_SET,
+ P_("Font stretch set"),
+ P_("Whether this tag affects the font stretch"));
- ADD_SET_PROP ("size_set", PROP_SIZE_SET,
- _("Font size set"),
- _("Whether this tag affects the font size"));
+ ADD_SET_PROP ("size-set", PROP_SIZE_SET,
+ P_("Font size set"),
+ P_("Whether this tag affects the font size"));
- ADD_SET_PROP ("scale_set", PROP_SCALE_SET,
- _("Font scale set"),
- _("Whether this tag scales the font size by a factor"));
+ ADD_SET_PROP ("scale-set", PROP_SCALE_SET,
+ P_("Font scale set"),
+ P_("Whether this tag scales the font size by a factor"));
- ADD_SET_PROP ("justification_set", PROP_JUSTIFICATION_SET,
- _("Justification set"),
- _("Whether this tag affects paragraph justification"));
+ ADD_SET_PROP ("justification-set", PROP_JUSTIFICATION_SET,
+ P_("Justification set"),
+ P_("Whether this tag affects paragraph justification"));
- ADD_SET_PROP ("language_set", PROP_LANGUAGE_SET,
- _("Language set"),
- _("Whether this tag affects the language the text is rendered as"));
+ ADD_SET_PROP ("language-set", PROP_LANGUAGE_SET,
+ P_("Language set"),
+ P_("Whether this tag affects the language the text is rendered as"));
- ADD_SET_PROP ("left_margin_set", PROP_LEFT_MARGIN_SET,
- _("Left margin set"),
- _("Whether this tag affects the left margin"));
+ ADD_SET_PROP ("left-margin-set", PROP_LEFT_MARGIN_SET,
+ P_("Left margin set"),
+ P_("Whether this tag affects the left margin"));
- ADD_SET_PROP ("indent_set", PROP_INDENT_SET,
- _("Indent set"),
- _("Whether this tag affects indentation"));
+ ADD_SET_PROP ("indent-set", PROP_INDENT_SET,
+ P_("Indent set"),
+ P_("Whether this tag affects indentation"));
- ADD_SET_PROP ("rise_set", PROP_RISE_SET,
- _("Rise set"),
- _("Whether this tag affects the rise"));
+ ADD_SET_PROP ("rise-set", PROP_RISE_SET,
+ P_("Rise set"),
+ P_("Whether this tag affects the rise"));
- ADD_SET_PROP ("pixels_above_lines_set", PROP_PIXELS_ABOVE_LINES_SET,
- _("Pixels above lines set"),
- _("Whether this tag affects the number of pixels above lines"));
+ ADD_SET_PROP ("pixels-above-lines-set", PROP_PIXELS_ABOVE_LINES_SET,
+ P_("Pixels above lines set"),
+ P_("Whether this tag affects the number of pixels above lines"));
- ADD_SET_PROP ("pixels_below_lines_set", PROP_PIXELS_BELOW_LINES_SET,
- _("Pixels below lines set"),
- _("Whether this tag affects the number of pixels above lines"));
+ ADD_SET_PROP ("pixels-below-lines-set", PROP_PIXELS_BELOW_LINES_SET,
+ P_("Pixels below lines set"),
+ P_("Whether this tag affects the number of pixels above lines"));
- ADD_SET_PROP ("pixels_inside_wrap_set", PROP_PIXELS_INSIDE_WRAP_SET,
- _("Pixels inside wrap set"),
- _("Whether this tag affects the number of pixels between wrapped lines"));
+ ADD_SET_PROP ("pixels-inside-wrap-set", PROP_PIXELS_INSIDE_WRAP_SET,
+ P_("Pixels inside wrap set"),
+ P_("Whether this tag affects the number of pixels between wrapped lines"));
- ADD_SET_PROP ("strikethrough_set", PROP_STRIKETHROUGH_SET,
- _("Strikethrough set"),
- _("Whether this tag affects strikethrough"));
+ ADD_SET_PROP ("strikethrough-set", PROP_STRIKETHROUGH_SET,
+ P_("Strikethrough set"),
+ P_("Whether this tag affects strikethrough"));
- ADD_SET_PROP ("right_margin_set", PROP_RIGHT_MARGIN_SET,
- _("Right margin set"),
- _("Whether this tag affects the right margin"));
-
- ADD_SET_PROP ("underline_set", PROP_UNDERLINE_SET,
- _("Underline set"),
- _("Whether this tag affects underlining"));
-
- ADD_SET_PROP ("wrap_mode_set", PROP_WRAP_MODE_SET,
- _("Wrap mode set"),
- _("Whether this tag affects line wrap mode"));
-
- ADD_SET_PROP ("tabs_set", PROP_TABS_SET,
- _("Tabs set"),
- _("Whether this tag affects tabs"));
-
- ADD_SET_PROP ("invisible_set", PROP_INVISIBLE_SET,
- _("Invisible set"),
- _("Whether this tag affects text visibility"));
-
+ ADD_SET_PROP ("right-margin-set", PROP_RIGHT_MARGIN_SET,
+ P_("Right margin set"),
+ P_("Whether this tag affects the right margin"));
+
+ ADD_SET_PROP ("underline-set", PROP_UNDERLINE_SET,
+ P_("Underline set"),
+ P_("Whether this tag affects underlining"));
+
+ ADD_SET_PROP ("wrap-mode-set", PROP_WRAP_MODE_SET,
+ P_("Wrap mode set"),
+ P_("Whether this tag affects line wrap mode"));
+
+ ADD_SET_PROP ("tabs-set", PROP_TABS_SET,
+ P_("Tabs set"),
+ P_("Whether this tag affects tabs"));
+
+ ADD_SET_PROP ("invisible-set", PROP_INVISIBLE_SET,
+ P_("Invisible set"),
+ P_("Whether this tag affects text visibility"));
+
+ ADD_SET_PROP ("paragraph-background-set", PROP_PARAGRAPH_BACKGROUND_SET,
+ P_("Paragraph background set"),
+ P_("Whether this tag affects the paragraph background color"));
+
+ /**
+ * GtkTextTag::event:
+ * @tag: the #GtkTextTag on which the signal is emitted
+ * @object: the object the event was fired from (typically a #GtkTextView)
+ * @event: the event which triggered the signal
+ * @iter: a #GtkTextIter pointing at the location the event occured
+ *
+ * The ::event signal is emitted when an event occurs on a region of the
+ * buffer marked with this tag.
+ *
+ * Returns: %TRUE to stop other handlers from being invoked for the
+ * event. %FALSE to propagate the event further.
+ */
signals[EVENT] =
- g_signal_new ("event",
+ g_signal_new (I_("event"),
G_OBJECT_CLASS_TYPE (object_class),
G_SIGNAL_RUN_LAST,
- GTK_SIGNAL_OFFSET (GtkTextTagClass, event),
+ G_STRUCT_OFFSET (GtkTextTagClass, event),
_gtk_boolean_handled_accumulator, NULL,
- gtk_marshal_BOOLEAN__OBJECT_BOXED_BOXED,
+ _gtk_marshal_BOOLEAN__OBJECT_BOXED_BOXED,
G_TYPE_BOOLEAN,
3,
G_TYPE_OBJECT,
GDK_TYPE_EVENT | G_SIGNAL_TYPE_STATIC_SCOPE,
GTK_TYPE_TEXT_ITER);
+
+ g_type_class_add_private (klass, sizeof (GtkTextTagPrivate));
}
-void
+static void
gtk_text_tag_init (GtkTextTag *text_tag)
{
- /* 0 is basically a fine way to initialize everything in the
- entire struct */
-
- text_tag->values = gtk_text_attributes_new ();
+ GtkTextTagPrivate *priv;
+
+ text_tag->priv = G_TYPE_INSTANCE_GET_PRIVATE (text_tag,
+ GTK_TYPE_TEXT_TAG,
+ GtkTextTagPrivate);
+ priv = text_tag->priv;
+
+ priv->values = gtk_text_attributes_new ();
}
/**
* gtk_text_tag_new:
- * @name: tag name, or %NULL
+ * @name: (allow-none): tag name, or %NULL
*
* Creates a #GtkTextTag. Configure the tag using object arguments,
* i.e. using g_object_set().
@@ -652,9 +781,7 @@ gtk_text_tag_new (const gchar *name)
{
GtkTextTag *tag;
- tag = GTK_TEXT_TAG (g_object_new (gtk_text_tag_get_type (),
- "name", name,
- NULL));
+ tag = g_object_new (GTK_TYPE_TEXT_TAG, "name", name, NULL);
return tag;
}
@@ -662,71 +789,188 @@ gtk_text_tag_new (const gchar *name)
static void
gtk_text_tag_finalize (GObject *object)
{
- GtkTextTag *text_tag;
+ GtkTextTag *text_tag = GTK_TEXT_TAG (object);
+ GtkTextTagPrivate *priv = text_tag->priv;
- text_tag = GTK_TEXT_TAG (object);
+ if (priv->table)
+ gtk_text_tag_table_remove (priv->table, text_tag);
- g_assert (!text_tag->values->realized);
+ g_assert (priv->table == NULL);
- if (text_tag->table)
- gtk_text_tag_table_remove (text_tag->table, text_tag);
+ gtk_text_attributes_unref (priv->values);
+ priv->values = NULL;
- g_assert (text_tag->table == NULL);
+ g_free (priv->name);
+ priv->name = NULL;
- gtk_text_attributes_unref (text_tag->values);
- text_tag->values = NULL;
-
- g_free (text_tag->name);
- text_tag->name = NULL;
+ G_OBJECT_CLASS (gtk_text_tag_parent_class)->finalize (object);
+}
+
+static void
+copy_rgba_to_gdk_color (GdkRGBA *src,
+ GdkColor *dest)
+{
+ dest->red = CLAMP (src->red, 0.0, 1.0) * 65535.0;
+ dest->green = CLAMP (src->green, 0.0, 1.0) * 65535.0;
+ dest->blue = CLAMP (src->blue, 0.0, 1.0) * 65535.0;
+}
- (* G_OBJECT_CLASS (parent_class)->finalize) (object);
+static void
+copy_gdk_color_to_rgba (GdkColor *src,
+ GdkRGBA *dest)
+{
+ dest->red = src->red / 65535.;
+ dest->green = src->green / 65535.;
+ dest->blue = src->blue / 65535.;
+ dest->alpha = 1;
}
static void
-set_bg_color (GtkTextTag *tag, GdkColor *color)
+set_bg_rgba (GtkTextTag *tag, GdkRGBA *rgba)
{
- if (color)
+ GtkTextTagPrivate *priv = tag->priv;
+
+ if (priv->values->appearance.rgba[0])
+ gdk_rgba_free (priv->values->appearance.rgba[0]);
+
+ priv->values->appearance.rgba[0] = NULL;
+
+ if (rgba)
{
- if (!tag->bg_color_set)
+ if (!priv->bg_color_set)
{
- tag->bg_color_set = TRUE;
- g_object_notify (G_OBJECT (tag), "background_set");
+ priv->bg_color_set = TRUE;
+ g_object_notify (G_OBJECT (tag), "background-set");
}
-
- tag->values->appearance.bg_color = *color;
+
+ priv->values->appearance.rgba[0] = gdk_rgba_copy (rgba);
+
+ copy_rgba_to_gdk_color (rgba, &priv->values->appearance.bg_color);
}
else
{
- if (tag->bg_color_set)
+ if (priv->bg_color_set)
{
- tag->bg_color_set = FALSE;
- g_object_notify (G_OBJECT (tag), "background_set");
+ priv->bg_color_set = FALSE;
+ g_object_notify (G_OBJECT (tag), "background-set");
}
}
}
static void
-set_fg_color (GtkTextTag *tag, GdkColor *color)
+set_fg_rgba (GtkTextTag *tag, GdkRGBA *rgba)
{
- if (color)
+ GtkTextTagPrivate *priv = tag->priv;
+
+ if (priv->values->appearance.rgba[1])
+ gdk_rgba_free (priv->values->appearance.rgba[1]);
+
+ priv->values->appearance.rgba[1] = NULL;
+
+ if (rgba)
{
- if (!tag->fg_color_set)
+ if (!priv->fg_color_set)
{
- tag->fg_color_set = TRUE;
- g_object_notify (G_OBJECT (tag), "foreground_set");
+ priv->fg_color_set = TRUE;
+ g_object_notify (G_OBJECT (tag), "foreground-set");
}
- tag->values->appearance.fg_color = *color;
+
+ priv->values->appearance.rgba[1] = gdk_rgba_copy (rgba);
+
+ copy_rgba_to_gdk_color (rgba, &priv->values->appearance.fg_color);
}
else
{
- if (tag->fg_color_set)
+ if (priv->fg_color_set)
{
- tag->fg_color_set = FALSE;
- g_object_notify (G_OBJECT (tag), "foreground_set");
+ priv->fg_color_set = FALSE;
+ g_object_notify (G_OBJECT (tag), "foreground-set");
}
}
}
+static void
+set_pg_bg_rgba (GtkTextTag *tag, GdkRGBA *rgba)
+{
+ GtkTextTagPrivate *priv = tag->priv;
+
+ if (priv->values->pg_bg_rgba)
+ gdk_rgba_free (priv->values->pg_bg_rgba);
+
+ if (priv->values->pg_bg_color)
+ gdk_color_free (priv->values->pg_bg_color);
+
+ priv->values->pg_bg_rgba = NULL;
+ priv->values->pg_bg_color = NULL;
+
+ if (rgba)
+ {
+ GdkColor color = { 0, };
+
+ if (!priv->pg_bg_color_set)
+ {
+ priv->pg_bg_color_set = TRUE;
+ g_object_notify (G_OBJECT (tag), "paragraph-background-set");
+ }
+
+ priv->values->pg_bg_rgba = gdk_rgba_copy (rgba);
+
+ copy_rgba_to_gdk_color (rgba, &color);
+ priv->values->pg_bg_color = gdk_color_copy (&color);
+ }
+ else
+ {
+ if (priv->pg_bg_color_set)
+ {
+ priv->pg_bg_color_set = FALSE;
+ g_object_notify (G_OBJECT (tag), "paragraph-background-set");
+ }
+ }
+}
+
+
+static void
+set_bg_color (GtkTextTag *tag, GdkColor *color)
+{
+ if (color)
+ {
+ GdkRGBA rgba;
+
+ copy_gdk_color_to_rgba (color, &rgba);
+ set_bg_rgba (tag, &rgba);
+ }
+ else
+ set_bg_rgba (tag, NULL);
+}
+
+static void
+set_fg_color (GtkTextTag *tag, GdkColor *color)
+{
+ if (color)
+ {
+ GdkRGBA rgba;
+
+ copy_gdk_color_to_rgba (color, &rgba);
+ set_fg_rgba (tag, &rgba);
+ }
+ else
+ set_fg_rgba (tag, NULL);
+}
+
+static void
+set_pg_bg_color (GtkTextTag *tag, GdkColor *color)
+{
+ if (color)
+ {
+ GdkRGBA rgba;
+
+ copy_gdk_color_to_rgba (color, &rgba);
+ set_pg_bg_rgba (tag, &rgba);
+ }
+ else
+ set_pg_bg_rgba (tag, NULL);
+}
+
static PangoFontMask
get_property_font_set_mask (guint prop_id)
{
@@ -749,28 +993,87 @@ get_property_font_set_mask (guint prop_id)
return 0;
}
+static PangoFontMask
+set_font_desc_fields (PangoFontDescription *desc,
+ PangoFontMask to_set)
+{
+ PangoFontMask changed_mask = 0;
+
+ if (to_set & PANGO_FONT_MASK_FAMILY)
+ {
+ const char *family = pango_font_description_get_family (desc);
+ if (!family)
+ {
+ family = "sans";
+ changed_mask |= PANGO_FONT_MASK_FAMILY;
+ }
+
+ pango_font_description_set_family (desc, family);
+ }
+ if (to_set & PANGO_FONT_MASK_STYLE)
+ pango_font_description_set_style (desc, pango_font_description_get_style (desc));
+ if (to_set & PANGO_FONT_MASK_VARIANT)
+ pango_font_description_set_variant (desc, pango_font_description_get_variant (desc));
+ if (to_set & PANGO_FONT_MASK_WEIGHT)
+ pango_font_description_set_weight (desc, pango_font_description_get_weight (desc));
+ if (to_set & PANGO_FONT_MASK_STRETCH)
+ pango_font_description_set_stretch (desc, pango_font_description_get_stretch (desc));
+ if (to_set & PANGO_FONT_MASK_SIZE)
+ {
+ gint size = pango_font_description_get_size (desc);
+ if (size <= 0)
+ {
+ size = 10 * PANGO_SCALE;
+ changed_mask |= PANGO_FONT_MASK_SIZE;
+ }
+
+ pango_font_description_set_size (desc, size);
+ }
+
+ return changed_mask;
+}
+
static void
notify_set_changed (GObject *object,
PangoFontMask changed_mask)
{
if (changed_mask & PANGO_FONT_MASK_FAMILY)
- g_object_notify (object, "family_set");
+ g_object_notify (object, "family-set");
+ if (changed_mask & PANGO_FONT_MASK_STYLE)
+ g_object_notify (object, "style-set");
+ if (changed_mask & PANGO_FONT_MASK_VARIANT)
+ g_object_notify (object, "variant-set");
+ if (changed_mask & PANGO_FONT_MASK_WEIGHT)
+ g_object_notify (object, "weight-set");
+ if (changed_mask & PANGO_FONT_MASK_STRETCH)
+ g_object_notify (object, "stretch-set");
+ if (changed_mask & PANGO_FONT_MASK_SIZE)
+ g_object_notify (object, "size-set");
+}
+
+static void
+notify_fields_changed (GObject *object,
+ PangoFontMask changed_mask)
+{
+ if (changed_mask & PANGO_FONT_MASK_FAMILY)
+ g_object_notify (object, "family");
if (changed_mask & PANGO_FONT_MASK_STYLE)
- g_object_notify (object, "style_set");
+ g_object_notify (object, "style");
if (changed_mask & PANGO_FONT_MASK_VARIANT)
- g_object_notify (object, "variant_set");
+ g_object_notify (object, "variant");
if (changed_mask & PANGO_FONT_MASK_WEIGHT)
- g_object_notify (object, "weight_set");
+ g_object_notify (object, "weight");
if (changed_mask & PANGO_FONT_MASK_STRETCH)
- g_object_notify (object, "stretch_set");
+ g_object_notify (object, "stretch");
if (changed_mask & PANGO_FONT_MASK_SIZE)
- g_object_notify (object, "size_set");
+ g_object_notify (object, "size");
}
static void
set_font_description (GtkTextTag *text_tag,
PangoFontDescription *font_desc)
{
+ GtkTextTagPrivate *priv = text_tag->priv;
GObject *object = G_OBJECT (text_tag);
PangoFontDescription *new_font_desc;
PangoFontMask old_mask, new_mask, changed_mask, set_changed_mask;
@@ -780,8 +1083,8 @@ set_font_description (GtkTextTag *text_tag,
else
new_font_desc = pango_font_description_new ();
- if (text_tag->values->font)
- old_mask = pango_font_description_get_set_fields (text_tag->values->font);
+ if (priv->values->font)
+ old_mask = pango_font_description_get_set_fields (priv->values->font);
else
old_mask = 0;
@@ -790,13 +1093,13 @@ set_font_description (GtkTextTag *text_tag,
changed_mask = old_mask | new_mask;
set_changed_mask = old_mask ^ new_mask;
- if (text_tag->values->font)
- pango_font_description_free (text_tag->values->font);
- text_tag->values->font = new_font_desc;
-
+ if (priv->values->font)
+ pango_font_description_free (priv->values->font);
+ priv->values->font = new_font_desc;
+
g_object_freeze_notify (object);
- g_object_notify (object, "font_desc");
+ g_object_notify (object, "font-desc");
g_object_notify (object, "font");
if (changed_mask & PANGO_FONT_MASK_FAMILY)
@@ -812,7 +1115,7 @@ set_font_description (GtkTextTag *text_tag,
if (changed_mask & PANGO_FONT_MASK_SIZE)
{
g_object_notify (object, "size");
- g_object_notify (object, "size_points");
+ g_object_notify (object, "size-points");
}
notify_set_changed (object, set_changed_mask);
@@ -823,8 +1126,10 @@ set_font_description (GtkTextTag *text_tag,
static void
gtk_text_tag_ensure_font (GtkTextTag *text_tag)
{
- if (!text_tag->values->font)
- text_tag->values->font = pango_font_description_new ();
+ GtkTextTagPrivate *priv = text_tag->priv;
+
+ if (!priv->values->font)
+ priv->values->font = pango_font_description_new ();
}
static void
@@ -833,43 +1138,44 @@ gtk_text_tag_set_property (GObject *object,
const GValue *value,
GParamSpec *pspec)
{
- GtkTextTag *text_tag;
+ GtkTextTag *text_tag = GTK_TEXT_TAG (object);
+ GtkTextTagPrivate *priv = text_tag->priv;
gboolean size_changed = FALSE;
- text_tag = GTK_TEXT_TAG (object);
-
- g_return_if_fail (!text_tag->values->realized);
-
switch (prop_id)
{
case PROP_NAME:
- g_return_if_fail (text_tag->name == NULL);
- text_tag->name = g_strdup (g_value_get_string (value));
+ g_return_if_fail (priv->name == NULL);
+ priv->name = g_value_dup_string (value);
break;
case PROP_BACKGROUND:
{
- GdkColor color;
+ GdkRGBA rgba;
- if (gdk_color_parse (g_value_get_string (value), &color))
- set_bg_color (text_tag, &color);
+ if (!g_value_get_string (value))
+ set_bg_rgba (text_tag, NULL); /* reset background_set to FALSE */
+ else if (gdk_rgba_parse (&rgba, g_value_get_string (value)))
+ set_bg_rgba (text_tag, &rgba);
else
g_warning ("Don't know color `%s'", g_value_get_string (value));
- g_object_notify (object, "background_gdk");
+ g_object_notify (object, "background-gdk");
}
break;
case PROP_FOREGROUND:
{
- GdkColor color;
+ GdkRGBA rgba;
- if (gdk_color_parse (g_value_get_string (value), &color))
- set_fg_color (text_tag, &color);
+ if (!g_value_get_string (value))
+ set_fg_rgba (text_tag, NULL); /* reset to foreground_set to FALSE */
+ else if (gdk_rgba_parse (&rgba, g_value_get_string (value)))
+ set_fg_rgba (text_tag, &rgba);
else
g_warning ("Don't know color `%s'", g_value_get_string (value));
- g_object_notify (object, "foreground_gdk");
+ g_object_notify (object, "foreground-gdk");
}
break;
@@ -889,43 +1195,19 @@ gtk_text_tag_set_property (GObject *object,
}
break;
- case PROP_BACKGROUND_STIPPLE:
+ case PROP_BACKGROUND_RGBA:
{
- GdkBitmap *bitmap = g_value_get_object (value);
-
- text_tag->bg_stipple_set = TRUE;
- g_object_notify (object, "background_stipple_set");
-
- if (text_tag->values->appearance.bg_stipple != bitmap)
- {
- if (bitmap != NULL)
- gdk_bitmap_ref (bitmap);
+ GdkRGBA *color = g_value_get_boxed (value);
- if (text_tag->values->appearance.bg_stipple)
- gdk_bitmap_unref (text_tag->values->appearance.bg_stipple);
-
- text_tag->values->appearance.bg_stipple = bitmap;
- }
+ set_bg_rgba (text_tag, color);
}
break;
- case PROP_FOREGROUND_STIPPLE:
+ case PROP_FOREGROUND_RGBA:
{
- GdkBitmap *bitmap = g_value_get_object (value);
-
- text_tag->fg_stipple_set = TRUE;
- g_object_notify (object, "foreground_stipple_set");
-
- if (text_tag->values->appearance.fg_stipple != bitmap)
- {
- if (bitmap != NULL)
- gdk_bitmap_ref (bitmap);
+ GdkRGBA *color = g_value_get_boxed (value);
- if (text_tag->values->appearance.fg_stipple)
- gdk_bitmap_unref (text_tag->values->appearance.fg_stipple);
-
- text_tag->values->appearance.fg_stipple = bitmap;
- }
+ set_fg_rgba (text_tag, color);
}
break;
@@ -940,6 +1222,8 @@ gtk_text_tag_set_property (GObject *object,
font_desc = pango_font_description_from_string (name);
set_font_description (text_tag, font_desc);
+ if (font_desc)
+ pango_font_description_free (font_desc);
size_changed = TRUE;
}
@@ -968,204 +1252,221 @@ gtk_text_tag_set_property (GObject *object,
PangoFontMask old_set_mask;
gtk_text_tag_ensure_font (text_tag);
- old_set_mask = pango_font_description_get_set_fields (text_tag->values->font);
+ old_set_mask = pango_font_description_get_set_fields (priv->values->font);
switch (prop_id)
{
case PROP_FAMILY:
- pango_font_description_set_family (text_tag->values->font,
+ pango_font_description_set_family (priv->values->font,
g_value_get_string (value));
break;
case PROP_STYLE:
- pango_font_description_set_style (text_tag->values->font,
+ pango_font_description_set_style (priv->values->font,
g_value_get_enum (value));
break;
case PROP_VARIANT:
- pango_font_description_set_variant (text_tag->values->font,
+ pango_font_description_set_variant (priv->values->font,
g_value_get_enum (value));
break;
case PROP_WEIGHT:
- pango_font_description_set_weight (text_tag->values->font,
+ pango_font_description_set_weight (priv->values->font,
g_value_get_int (value));
break;
case PROP_STRETCH:
- pango_font_description_set_stretch (text_tag->values->font,
+ pango_font_description_set_stretch (priv->values->font,
g_value_get_enum (value));
break;
case PROP_SIZE:
- pango_font_description_set_size (text_tag->values->font,
+ pango_font_description_set_size (priv->values->font,
g_value_get_int (value));
- g_object_notify (object, "size_points");
+ g_object_notify (object, "size-points");
break;
case PROP_SIZE_POINTS:
- pango_font_description_set_size (text_tag->values->font,
+ pango_font_description_set_size (priv->values->font,
g_value_get_double (value) * PANGO_SCALE);
g_object_notify (object, "size");
break;
}
size_changed = TRUE;
- notify_set_changed (object, old_set_mask & pango_font_description_get_set_fields (text_tag->values->font));
- g_object_notify (object, "font_desc");
+ notify_set_changed (object, old_set_mask & pango_font_description_get_set_fields (priv->values->font));
+ g_object_notify (object, "font-desc");
g_object_notify (object, "font");
break;
}
case PROP_SCALE:
- text_tag->values->font_scale = g_value_get_double (value);
- text_tag->scale_set = TRUE;
- g_object_notify (object, "scale_set");
+ priv->values->font_scale = g_value_get_double (value);
+ priv->scale_set = TRUE;
+ g_object_notify (object, "scale-set");
size_changed = TRUE;
break;
case PROP_PIXELS_ABOVE_LINES:
- text_tag->pixels_above_lines_set = TRUE;
- text_tag->values->pixels_above_lines = g_value_get_int (value);
- g_object_notify (object, "pixels_above_lines_set");
+ priv->pixels_above_lines_set = TRUE;
+ priv->values->pixels_above_lines = g_value_get_int (value);
+ g_object_notify (object, "pixels-above-lines-set");
size_changed = TRUE;
break;
case PROP_PIXELS_BELOW_LINES:
- text_tag->pixels_below_lines_set = TRUE;
- text_tag->values->pixels_below_lines = g_value_get_int (value);
- g_object_notify (object, "pixels_below_lines_set");
+ priv->pixels_below_lines_set = TRUE;
+ priv->values->pixels_below_lines = g_value_get_int (value);
+ g_object_notify (object, "pixels-below-lines-set");
size_changed = TRUE;
break;
case PROP_PIXELS_INSIDE_WRAP:
- text_tag->pixels_inside_wrap_set = TRUE;
- text_tag->values->pixels_inside_wrap = g_value_get_int (value);
- g_object_notify (object, "pixels_inside_wrap_set");
+ priv->pixels_inside_wrap_set = TRUE;
+ priv->values->pixels_inside_wrap = g_value_get_int (value);
+ g_object_notify (object, "pixels-inside-wrap-set");
size_changed = TRUE;
break;
case PROP_EDITABLE:
- text_tag->editable_set = TRUE;
- text_tag->values->editable = g_value_get_boolean (value);
- g_object_notify (object, "editable_set");
+ priv->editable_set = TRUE;
+ priv->values->editable = g_value_get_boolean (value);
+ g_object_notify (object, "editable-set");
break;
case PROP_WRAP_MODE:
- text_tag->wrap_mode_set = TRUE;
- text_tag->values->wrap_mode = g_value_get_enum (value);
- g_object_notify (object, "wrap_mode_set");
+ priv->wrap_mode_set = TRUE;
+ priv->values->wrap_mode = g_value_get_enum (value);
+ g_object_notify (object, "wrap-mode-set");
size_changed = TRUE;
break;
case PROP_JUSTIFICATION:
- text_tag->justification_set = TRUE;
- text_tag->values->justification = g_value_get_enum (value);
- g_object_notify (object, "justification_set");
+ priv->justification_set = TRUE;
+ priv->values->justification = g_value_get_enum (value);
+ g_object_notify (object, "justification-set");
size_changed = TRUE;
break;
case PROP_DIRECTION:
- text_tag->values->direction = g_value_get_enum (value);
+ priv->values->direction = g_value_get_enum (value);
break;
case PROP_LEFT_MARGIN:
- text_tag->left_margin_set = TRUE;
- text_tag->values->left_margin = g_value_get_int (value);
- g_object_notify (object, "left_margin_set");
+ priv->left_margin_set = TRUE;
+ priv->values->left_margin = g_value_get_int (value);
+ g_object_notify (object, "left-margin-set");
size_changed = TRUE;
break;
case PROP_INDENT:
- text_tag->indent_set = TRUE;
- text_tag->values->indent = g_value_get_int (value);
- g_object_notify (object, "indent_set");
+ priv->indent_set = TRUE;
+ priv->values->indent = g_value_get_int (value);
+ g_object_notify (object, "indent-set");
size_changed = TRUE;
break;
case PROP_STRIKETHROUGH:
- text_tag->strikethrough_set = TRUE;
- text_tag->values->appearance.strikethrough = g_value_get_boolean (value);
- g_object_notify (object, "strikethrough_set");
+ priv->strikethrough_set = TRUE;
+ priv->values->appearance.strikethrough = g_value_get_boolean (value);
+ g_object_notify (object, "strikethrough-set");
break;
case PROP_RIGHT_MARGIN:
- text_tag->right_margin_set = TRUE;
- text_tag->values->right_margin = g_value_get_int (value);
- g_object_notify (object, "right_margin_set");
+ priv->right_margin_set = TRUE;
+ priv->values->right_margin = g_value_get_int (value);
+ g_object_notify (object, "right-margin-set");
size_changed = TRUE;
break;
case PROP_UNDERLINE:
- text_tag->underline_set = TRUE;
- text_tag->values->appearance.underline = g_value_get_enum (value);
- g_object_notify (object, "underline_set");
+ priv->underline_set = TRUE;
+ priv->values->appearance.underline = g_value_get_enum (value);
+ g_object_notify (object, "underline-set");
break;
case PROP_RISE:
- text_tag->rise_set = TRUE;
- text_tag->values->appearance.rise = g_value_get_int (value);
- g_object_notify (object, "rise_set");
+ priv->rise_set = TRUE;
+ priv->values->appearance.rise = g_value_get_int (value);
+ g_object_notify (object, "rise-set");
size_changed = TRUE;
break;
- case PROP_BG_FULL_HEIGHT:
- text_tag->bg_full_height_set = TRUE;
- text_tag->values->bg_full_height = g_value_get_boolean (value);
- g_object_notify (object, "bg_full_height_set");
+ case PROP_BACKGROUND_FULL_HEIGHT:
+ priv->bg_full_height_set = TRUE;
+ priv->values->bg_full_height = g_value_get_boolean (value);
+ g_object_notify (object, "background-full-height-set");
break;
case PROP_LANGUAGE:
- text_tag->language_set = TRUE;
- text_tag->values->language = pango_language_from_string (g_value_get_string (value));
- g_object_notify (object, "language_set");
+ priv->language_set = TRUE;
+ priv->values->language = pango_language_from_string (g_value_get_string (value));
+ g_object_notify (object, "language-set");
break;
case PROP_TABS:
- text_tag->tabs_set = TRUE;
+ priv->tabs_set = TRUE;
- if (text_tag->values->tabs)
- pango_tab_array_free (text_tag->values->tabs);
+ if (priv->values->tabs)
+ pango_tab_array_free (priv->values->tabs);
/* FIXME I'm not sure if this is a memleak or not */
- text_tag->values->tabs =
+ priv->values->tabs =
pango_tab_array_copy (g_value_get_boxed (value));
- g_object_notify (object, "tabs_set");
+ g_object_notify (object, "tabs-set");
size_changed = TRUE;
break;
case PROP_INVISIBLE:
- text_tag->invisible_set = TRUE;
- text_tag->values->invisible = g_value_get_boolean (value);
- g_object_notify (object, "invisible_set");
+ priv->invisible_set = TRUE;
+ priv->values->invisible = g_value_get_boolean (value);
+ g_object_notify (object, "invisible-set");
size_changed = TRUE;
break;
- /* Whether the value should be used... */
+ case PROP_PARAGRAPH_BACKGROUND:
+ {
+ GdkRGBA rgba;
- case PROP_BACKGROUND_SET:
- text_tag->bg_color_set = g_value_get_boolean (value);
+ if (!g_value_get_string (value))
+ set_pg_bg_rgba (text_tag, NULL); /* reset paragraph_background_set to FALSE */
+ else if (gdk_rgba_parse (&rgba, g_value_get_string (value)))
+ set_pg_bg_rgba (text_tag, &rgba);
+ else
+ g_warning ("Don't know color `%s'", g_value_get_string (value));
+
+ g_object_notify (object, "paragraph-background-gdk");
+ }
break;
- case PROP_FOREGROUND_SET:
- text_tag->fg_color_set = g_value_get_boolean (value);
+ case PROP_PARAGRAPH_BACKGROUND_GDK:
+ {
+ GdkColor *color = g_value_get_boxed (value);
+
+ set_pg_bg_color (text_tag, color);
+ }
break;
- case PROP_BACKGROUND_STIPPLE_SET:
- text_tag->bg_stipple_set = g_value_get_boolean (value);
- if (!text_tag->bg_stipple_set &&
- text_tag->values->appearance.bg_stipple)
- {
- g_object_unref (G_OBJECT (text_tag->values->appearance.bg_stipple));
- text_tag->values->appearance.bg_stipple = NULL;
- }
+ case PROP_PARAGRAPH_BACKGROUND_RGBA:
+ {
+ GdkRGBA *color = g_value_get_boxed (value);
+
+ set_pg_bg_rgba (text_tag, color);
+ }
break;
- case PROP_FOREGROUND_STIPPLE_SET:
- text_tag->fg_stipple_set = g_value_get_boolean (value);
- if (!text_tag->fg_stipple_set &&
- text_tag->values->appearance.fg_stipple)
- {
- g_object_unref (G_OBJECT (text_tag->values->appearance.fg_stipple));
- text_tag->values->appearance.fg_stipple = NULL;
- }
+ case PROP_ACCUMULATIVE_MARGIN:
+ priv->accumulative_margin = g_value_get_boolean (value);
+ g_object_notify (object, "accumulative-margin");
+ size_changed = TRUE;
+ break;
+
+ /* Whether the value should be used... */
+
+ case PROP_BACKGROUND_SET:
+ priv->bg_color_set = g_value_get_boolean (value);
+ break;
+
+ case PROP_FOREGROUND_SET:
+ priv->fg_color_set = g_value_get_boolean (value);
break;
case PROP_FAMILY_SET:
@@ -1174,92 +1475,108 @@ gtk_text_tag_set_property (GObject *object,
case PROP_WEIGHT_SET:
case PROP_STRETCH_SET:
case PROP_SIZE_SET:
- if (!g_value_get_boolean (value) && text_tag->values->font)
- pango_font_description_unset_fields (text_tag->values->font,
- get_property_font_set_mask (prop_id));
+ if (!g_value_get_boolean (value))
+ {
+ if (priv->values->font)
+ pango_font_description_unset_fields (priv->values->font,
+ get_property_font_set_mask (prop_id));
+ }
+ else
+ {
+ PangoFontMask changed_mask;
+
+ gtk_text_tag_ensure_font (text_tag);
+ changed_mask = set_font_desc_fields (priv->values->font,
+ get_property_font_set_mask (prop_id));
+ notify_fields_changed (G_OBJECT (text_tag), changed_mask);
+ }
break;
case PROP_SCALE_SET:
- text_tag->scale_set = g_value_get_boolean (value);
+ priv->scale_set = g_value_get_boolean (value);
size_changed = TRUE;
break;
case PROP_PIXELS_ABOVE_LINES_SET:
- text_tag->pixels_above_lines_set = g_value_get_boolean (value);
+ priv->pixels_above_lines_set = g_value_get_boolean (value);
size_changed = TRUE;
break;
case PROP_PIXELS_BELOW_LINES_SET:
- text_tag->pixels_below_lines_set = g_value_get_boolean (value);
+ priv->pixels_below_lines_set = g_value_get_boolean (value);
size_changed = TRUE;
break;
case PROP_PIXELS_INSIDE_WRAP_SET:
- text_tag->pixels_inside_wrap_set = g_value_get_boolean (value);
+ priv->pixels_inside_wrap_set = g_value_get_boolean (value);
size_changed = TRUE;
break;
case PROP_EDITABLE_SET:
- text_tag->editable_set = g_value_get_boolean (value);
+ priv->editable_set = g_value_get_boolean (value);
break;
case PROP_WRAP_MODE_SET:
- text_tag->wrap_mode_set = g_value_get_boolean (value);
+ priv->wrap_mode_set = g_value_get_boolean (value);
size_changed = TRUE;
break;
case PROP_JUSTIFICATION_SET:
- text_tag->justification_set = g_value_get_boolean (value);
+ priv->justification_set = g_value_get_boolean (value);
size_changed = TRUE;
break;
case PROP_LEFT_MARGIN_SET:
- text_tag->left_margin_set = g_value_get_boolean (value);
+ priv->left_margin_set = g_value_get_boolean (value);
size_changed = TRUE;
break;
case PROP_INDENT_SET:
- text_tag->indent_set = g_value_get_boolean (value);
+ priv->indent_set = g_value_get_boolean (value);
size_changed = TRUE;
break;
case PROP_STRIKETHROUGH_SET:
- text_tag->strikethrough_set = g_value_get_boolean (value);
+ priv->strikethrough_set = g_value_get_boolean (value);
break;
case PROP_RIGHT_MARGIN_SET:
- text_tag->right_margin_set = g_value_get_boolean (value);
+ priv->right_margin_set = g_value_get_boolean (value);
size_changed = TRUE;
break;
case PROP_UNDERLINE_SET:
- text_tag->underline_set = g_value_get_boolean (value);
+ priv->underline_set = g_value_get_boolean (value);
break;
case PROP_RISE_SET:
- text_tag->rise_set = g_value_get_boolean (value);
+ priv->rise_set = g_value_get_boolean (value);
size_changed = TRUE;
break;
- case PROP_BG_FULL_HEIGHT_SET:
- text_tag->bg_full_height_set = g_value_get_boolean (value);
+ case PROP_BACKGROUND_FULL_HEIGHT_SET:
+ priv->bg_full_height_set = g_value_get_boolean (value);
break;
case PROP_LANGUAGE_SET:
- text_tag->language_set = g_value_get_boolean (value);
+ priv->language_set = g_value_get_boolean (value);
size_changed = TRUE;
break;
case PROP_TABS_SET:
- text_tag->tabs_set = g_value_get_boolean (value);
+ priv->tabs_set = g_value_get_boolean (value);
size_changed = TRUE;
break;
case PROP_INVISIBLE_SET:
- text_tag->invisible_set = g_value_get_boolean (value);
+ priv->invisible_set = g_value_get_boolean (value);
size_changed = TRUE;
break;
+ case PROP_PARAGRAPH_BACKGROUND_SET:
+ priv->pg_bg_color_set = g_value_get_boolean (value);
+ break;
+
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
@@ -1275,75 +1592,57 @@ gtk_text_tag_set_property (GObject *object,
* signal here, but the two objects are already tightly bound.
*/
- if (text_tag->table)
- g_signal_emit_by_name (G_OBJECT (text_tag->table),
+ if (priv->table)
+ g_signal_emit_by_name (priv->table,
"tag_changed",
text_tag, size_changed);
}
-static void
-get_color_arg (GValue *value, GdkColor *orig)
-{
- GdkColor *color;
-
- color = g_new (GdkColor, 1);
- *color = *orig;
- g_value_init (value, GDK_TYPE_COLOR);
- g_value_set_boxed (value, color);
-}
-
static void
gtk_text_tag_get_property (GObject *object,
guint prop_id,
GValue *value,
GParamSpec *pspec)
{
- GtkTextTag *tag;
-
- tag = GTK_TEXT_TAG (object);
+ GtkTextTag *tag = GTK_TEXT_TAG (object);
+ GtkTextTagPrivate *priv = tag->priv;
switch (prop_id)
{
case PROP_NAME:
- g_value_set_string (value, tag->name);
+ g_value_set_string (value, priv->name);
break;
case PROP_BACKGROUND_GDK:
- get_color_arg (value, &tag->values->appearance.bg_color);
+ g_value_set_boxed (value, &priv->values->appearance.bg_color);
break;
- case PROP_FOREGROUND_GDK:
- get_color_arg (value, &tag->values->appearance.fg_color);
+ case PROP_BACKGROUND_RGBA:
+ g_value_set_boxed (value, priv->values->appearance.rgba[0]);
break;
- case PROP_BACKGROUND_STIPPLE:
- if (tag->bg_stipple_set)
- g_value_set_boxed (value, tag->values->appearance.bg_stipple);
+ case PROP_FOREGROUND_GDK:
+ g_value_set_boxed (value, &priv->values->appearance.fg_color);
break;
- case PROP_FOREGROUND_STIPPLE:
- if (tag->fg_stipple_set)
- g_value_set_boxed (value, tag->values->appearance.fg_stipple);
+ case PROP_FOREGROUND_RGBA:
+ g_value_set_boxed (value, priv->values->appearance.rgba[1]);
break;
case PROP_FONT:
{
- /* FIXME GValue imposes a totally gratuitous string copy
- * here, we could just hand off string ownership
- */
gchar *str;
gtk_text_tag_ensure_font (tag);
-
- str = pango_font_description_to_string (tag->values->font);
- g_value_set_string (value, str);
- g_free (str);
+
+ str = pango_font_description_to_string (priv->values->font);
+ g_value_take_string (value, str);
}
break;
case PROP_FONT_DESC:
gtk_text_tag_ensure_font (tag);
- g_value_set_boxed (value, tag->values->font);
+ g_value_set_boxed (value, priv->values->font);
break;
case PROP_FAMILY:
@@ -1357,122 +1656,126 @@ gtk_text_tag_get_property (GObject *object,
switch (prop_id)
{
case PROP_FAMILY:
- g_value_set_string (value, pango_font_description_get_family (tag->values->font));
+ g_value_set_string (value, pango_font_description_get_family (priv->values->font));
break;
case PROP_STYLE:
- g_value_set_enum (value, pango_font_description_get_style (tag->values->font));
+ g_value_set_enum (value, pango_font_description_get_style (priv->values->font));
break;
case PROP_VARIANT:
- g_value_set_enum (value, pango_font_description_get_variant (tag->values->font));
+ g_value_set_enum (value, pango_font_description_get_variant (priv->values->font));
break;
case PROP_WEIGHT:
- g_value_set_int (value, pango_font_description_get_weight (tag->values->font));
+ g_value_set_int (value, pango_font_description_get_weight (priv->values->font));
break;
case PROP_STRETCH:
- g_value_set_enum (value, pango_font_description_get_stretch (tag->values->font));
+ g_value_set_enum (value, pango_font_description_get_stretch (priv->values->font));
break;
case PROP_SIZE:
- g_value_set_int (value, pango_font_description_get_size (tag->values->font));
+ g_value_set_int (value, pango_font_description_get_size (priv->values->font));
break;
case PROP_SIZE_POINTS:
- g_value_set_double (value, ((double)pango_font_description_get_size (tag->values->font)) / (double)PANGO_SCALE);
+ g_value_set_double (value, ((double)pango_font_description_get_size (priv->values->font)) / (double)PANGO_SCALE);
break;
}
break;
case PROP_SCALE:
- g_value_set_double (value, tag->values->font_scale);
+ g_value_set_double (value, priv->values->font_scale);
break;
case PROP_PIXELS_ABOVE_LINES:
- g_value_set_int (value, tag->values->pixels_above_lines);
+ g_value_set_int (value, priv->values->pixels_above_lines);
break;
case PROP_PIXELS_BELOW_LINES:
- g_value_set_int (value, tag->values->pixels_below_lines);
+ g_value_set_int (value, priv->values->pixels_below_lines);
break;
case PROP_PIXELS_INSIDE_WRAP:
- g_value_set_int (value, tag->values->pixels_inside_wrap);
+ g_value_set_int (value, priv->values->pixels_inside_wrap);
break;
case PROP_EDITABLE:
- g_value_set_boolean (value, tag->values->editable);
+ g_value_set_boolean (value, priv->values->editable);
break;
case PROP_WRAP_MODE:
- g_value_set_enum (value, tag->values->wrap_mode);
+ g_value_set_enum (value, priv->values->wrap_mode);
break;
case PROP_JUSTIFICATION:
- g_value_set_enum (value, tag->values->justification);
+ g_value_set_enum (value, priv->values->justification);
break;
case PROP_DIRECTION:
- g_value_set_enum (value, tag->values->direction);
+ g_value_set_enum (value, priv->values->direction);
break;
case PROP_LEFT_MARGIN:
- g_value_set_int (value, tag->values->left_margin);
+ g_value_set_int (value, priv->values->left_margin);
break;
case PROP_INDENT:
- g_value_set_int (value, tag->values->indent);
+ g_value_set_int (value, priv->values->indent);
break;
case PROP_STRIKETHROUGH:
- g_value_set_boolean (value, tag->values->appearance.strikethrough);
+ g_value_set_boolean (value, priv->values->appearance.strikethrough);
break;
case PROP_RIGHT_MARGIN:
- g_value_set_int (value, tag->values->right_margin);
+ g_value_set_int (value, priv->values->right_margin);
break;
case PROP_UNDERLINE:
- g_value_set_enum (value, tag->values->appearance.underline);
+ g_value_set_enum (value, priv->values->appearance.underline);
break;
case PROP_RISE:
- g_value_set_int (value, tag->values->appearance.rise);
+ g_value_set_int (value, priv->values->appearance.rise);
break;
- case PROP_BG_FULL_HEIGHT:
- g_value_set_boolean (value, tag->values->bg_full_height);
+ case PROP_BACKGROUND_FULL_HEIGHT:
+ g_value_set_boolean (value, priv->values->bg_full_height);
break;
case PROP_LANGUAGE:
- g_value_set_string (value, pango_language_to_string (tag->values->language));
+ g_value_set_string (value, pango_language_to_string (priv->values->language));
break;
case PROP_TABS:
- if (tag->values->tabs)
- g_value_set_boxed (value, tag->values->tabs);
+ if (priv->values->tabs)
+ g_value_set_boxed (value, priv->values->tabs);
break;
case PROP_INVISIBLE:
- g_value_set_boolean (value, tag->values->invisible);
+ g_value_set_boolean (value, priv->values->invisible);
break;
- case PROP_BACKGROUND_SET:
- g_value_set_boolean (value, tag->bg_color_set);
+ case PROP_PARAGRAPH_BACKGROUND_GDK:
+ g_value_set_boxed (value, priv->values->pg_bg_color);
break;
- case PROP_FOREGROUND_SET:
- g_value_set_boolean (value, tag->fg_color_set);
+ case PROP_PARAGRAPH_BACKGROUND_RGBA:
+ g_value_set_boxed (value, priv->values->pg_bg_rgba);
+ break;
+
+ case PROP_ACCUMULATIVE_MARGIN:
+ g_value_set_boolean (value, priv->accumulative_margin);
break;
- case PROP_BACKGROUND_STIPPLE_SET:
- g_value_set_boolean (value, tag->bg_stipple_set);
+ case PROP_BACKGROUND_SET:
+ g_value_set_boolean (value, priv->bg_color_set);
break;
- case PROP_FOREGROUND_STIPPLE_SET:
- g_value_set_boolean (value, tag->fg_stipple_set);
+ case PROP_FOREGROUND_SET:
+ g_value_set_boolean (value, priv->fg_color_set);
break;
case PROP_FAMILY_SET:
@@ -1482,7 +1785,7 @@ gtk_text_tag_get_property (GObject *object,
case PROP_STRETCH_SET:
case PROP_SIZE_SET:
{
- PangoFontMask set_mask = tag->values->font ? pango_font_description_get_set_fields (tag->values->font) : 0;
+ PangoFontMask set_mask = priv->values->font ? pango_font_description_get_set_fields (priv->values->font) : 0;
PangoFontMask test_mask = get_property_font_set_mask (prop_id);
g_value_set_boolean (value, (set_mask & test_mask) != 0);
@@ -1490,76 +1793,82 @@ gtk_text_tag_get_property (GObject *object,
}
case PROP_SCALE_SET:
- g_value_set_boolean (value, tag->scale_set);
+ g_value_set_boolean (value, priv->scale_set);
break;
case PROP_PIXELS_ABOVE_LINES_SET:
- g_value_set_boolean (value, tag->pixels_above_lines_set);
+ g_value_set_boolean (value, priv->pixels_above_lines_set);
break;
case PROP_PIXELS_BELOW_LINES_SET:
- g_value_set_boolean (value, tag->pixels_below_lines_set);
+ g_value_set_boolean (value, priv->pixels_below_lines_set);
break;
case PROP_PIXELS_INSIDE_WRAP_SET:
- g_value_set_boolean (value, tag->pixels_inside_wrap_set);
+ g_value_set_boolean (value, priv->pixels_inside_wrap_set);
break;
case PROP_EDITABLE_SET:
- g_value_set_boolean (value, tag->editable_set);
+ g_value_set_boolean (value, priv->editable_set);
break;
case PROP_WRAP_MODE_SET:
- g_value_set_boolean (value, tag->wrap_mode_set);
+ g_value_set_boolean (value, priv->wrap_mode_set);
break;
case PROP_JUSTIFICATION_SET:
- g_value_set_boolean (value, tag->justification_set);
+ g_value_set_boolean (value, priv->justification_set);
break;
case PROP_LEFT_MARGIN_SET:
- g_value_set_boolean (value, tag->left_margin_set);
+ g_value_set_boolean (value, priv->left_margin_set);
break;
case PROP_INDENT_SET:
- g_value_set_boolean (value, tag->indent_set);
+ g_value_set_boolean (value, priv->indent_set);
break;
case PROP_STRIKETHROUGH_SET:
- g_value_set_boolean (value, tag->strikethrough_set);
+ g_value_set_boolean (value, priv->strikethrough_set);
break;
case PROP_RIGHT_MARGIN_SET:
- g_value_set_boolean (value, tag->right_margin_set);
+ g_value_set_boolean (value, priv->right_margin_set);
break;
case PROP_UNDERLINE_SET:
- g_value_set_boolean (value, tag->underline_set);
+ g_value_set_boolean (value, priv->underline_set);
break;
case PROP_RISE_SET:
- g_value_set_boolean (value, tag->rise_set);
+ g_value_set_boolean (value, priv->rise_set);
break;
- case PROP_BG_FULL_HEIGHT_SET:
- g_value_set_boolean (value, tag->bg_full_height_set);
+ case PROP_BACKGROUND_FULL_HEIGHT_SET:
+ g_value_set_boolean (value, priv->bg_full_height_set);
break;
case PROP_LANGUAGE_SET:
- g_value_set_boolean (value, tag->language_set);
+ g_value_set_boolean (value, priv->language_set);
break;
case PROP_TABS_SET:
- g_value_set_boolean (value, tag->tabs_set);
+ g_value_set_boolean (value, priv->tabs_set);
break;
case PROP_INVISIBLE_SET:
- g_value_set_boolean (value, tag->invisible_set);
+ g_value_set_boolean (value, priv->invisible_set);
break;
+ case PROP_PARAGRAPH_BACKGROUND_SET:
+ g_value_set_boolean (value, priv->pg_bg_color_set);
+ break;
+
case PROP_BACKGROUND:
case PROP_FOREGROUND:
- g_warning ("'foreground' and 'background' properties are not readable, use 'foreground_gdk' and 'background_gdk'");
+ case PROP_PARAGRAPH_BACKGROUND:
+ g_warning ("'foreground', 'background' and 'paragraph_background' properties are not readable, use 'foreground_gdk', 'background_gdk' and 'paragraph_background_gdk'");
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
@@ -1579,10 +1888,11 @@ typedef struct {
static void
delta_priority_foreach (GtkTextTag *tag, gpointer user_data)
{
+ GtkTextTagPrivate *priv = tag->priv;
DeltaData *dd = user_data;
- if (tag->priority >= dd->low && tag->priority <= dd->high)
- tag->priority += dd->delta;
+ if (priv->priority >= dd->low && priv->priority <= dd->high)
+ priv->priority += dd->delta;
}
/**
@@ -1598,7 +1908,7 @@ gtk_text_tag_get_priority (GtkTextTag *tag)
{
g_return_val_if_fail (GTK_IS_TEXT_TAG (tag), 0);
- return tag->priority;
+ return tag->priv->priority;
}
/**
@@ -1622,34 +1932,38 @@ void
gtk_text_tag_set_priority (GtkTextTag *tag,
gint priority)
{
+ GtkTextTagPrivate *priv;
DeltaData dd;
g_return_if_fail (GTK_IS_TEXT_TAG (tag));
- g_return_if_fail (tag->table != NULL);
+
+ priv = tag->priv;
+
+ g_return_if_fail (priv->table != NULL);
g_return_if_fail (priority >= 0);
- g_return_if_fail (priority < gtk_text_tag_table_get_size (tag->table));
+ g_return_if_fail (priority < gtk_text_tag_table_get_size (priv->table));
- if (priority == tag->priority)
+ if (priority == priv->priority)
return;
- if (priority < tag->priority)
+ if (priority < priv->priority)
{
dd.low = priority;
- dd.high = tag->priority - 1;
+ dd.high = priv->priority - 1;
dd.delta = 1;
}
else
{
- dd.low = tag->priority + 1;
+ dd.low = priv->priority + 1;
dd.high = priority;
dd.delta = -1;
}
- gtk_text_tag_table_foreach (tag->table,
+ gtk_text_tag_table_foreach (priv->table,
delta_priority_foreach,
&dd);
- tag->priority = priority;
+ priv->priority = priority;
}
/**
@@ -1672,10 +1986,10 @@ gtk_text_tag_event (GtkTextTag *tag,
gboolean retval = FALSE;
g_return_val_if_fail (GTK_IS_TEXT_TAG (tag), FALSE);
- g_return_val_if_fail (GTK_IS_OBJECT (event_object), FALSE);
+ g_return_val_if_fail (G_IS_OBJECT (event_object), FALSE);
g_return_val_if_fail (event != NULL, FALSE);
- g_signal_emit (G_OBJECT (tag),
+ g_signal_emit (tag,
signals[EVENT],
0,
event_object,
@@ -1693,7 +2007,7 @@ tag_sort_func (gconstpointer first, gconstpointer second)
tag1 = * (GtkTextTag **) first;
tag2 = * (GtkTextTag **) second;
- return tag1->priority - tag2->priority;
+ return tag1->priv->priority - tag2->priv->priority;
}
void
@@ -1715,10 +2029,10 @@ _gtk_text_tag_array_sort (GtkTextTag** tag_array_p,
for (i = len-1; i > 0; i--, iter++) {
maxPtrPtr = tag = iter;
- prio = tag[0]->priority;
+ prio = tag[0]->priv->priority;
for (j = i, tag++; j > 0; j--, tag++) {
- if (tag[0]->priority < prio) {
- prio = tag[0]->priority;
+ if (tag[0]->priv->priority < prio) {
+ prio = tag[0]->priv->priority;
maxPtrPtr = tag;
}
}
@@ -1746,350 +2060,3 @@ _gtk_text_tag_array_sort (GtkTextTag** tag_array_p,
#endif
}
-/*
- * Attributes
- */
-
-/**
- * gtk_text_attributes_new:
- *
- * Creates a #GtkTextAttributes, which describes
- * a set of properties on some text.
- *
- * Return value: a new #GtkTextAttributes
- **/
-GtkTextAttributes*
-gtk_text_attributes_new (void)
-{
- GtkTextAttributes *values;
-
- values = g_new0 (GtkTextAttributes, 1);
-
- /* 0 is a valid value for most of the struct */
-
- values->refcount = 1;
-
- values->language = gtk_get_default_language ();
-
- values->font_scale = 1.0;
-
- return values;
-}
-
-/**
- * gtk_text_attributes_copy:
- * @src: a #GtkTextAttributes to be copied
- *
- * Copies @src and returns a new #GtkTextAttributes.
- *
- * Return value: a copy of @src
- **/
-GtkTextAttributes*
-gtk_text_attributes_copy (GtkTextAttributes *src)
-{
- GtkTextAttributes *dest;
-
- dest = gtk_text_attributes_new ();
- gtk_text_attributes_copy_values (src, dest);
-
- return dest;
-}
-
-/**
- * gtk_text_attributes_copy_values:
- * @src: a #GtkTextAttributes
- * @dest: another #GtkTextAttributes
- *
- * Copies the values from @src to @dest so that @dest has the same values
- * as @src. Frees existing values in @dest.
- **/
-void
-gtk_text_attributes_copy_values (GtkTextAttributes *src,
- GtkTextAttributes *dest)
-{
- guint orig_refcount;
-
- g_return_if_fail (!dest->realized);
-
- if (src == dest)
- return;
-
- /* Add refs */
-
- if (src->appearance.bg_stipple)
- gdk_bitmap_ref (src->appearance.bg_stipple);
-
- if (src->appearance.fg_stipple)
- gdk_bitmap_ref (src->appearance.fg_stipple);
-
- /* Remove refs */
-
- if (dest->appearance.bg_stipple)
- gdk_bitmap_unref (dest->appearance.bg_stipple);
-
- if (dest->appearance.fg_stipple)
- gdk_bitmap_unref (dest->appearance.fg_stipple);
-
- if (dest->font)
- pango_font_description_free (dest->font);
-
- /* Copy */
- orig_refcount = dest->refcount;
-
- *dest = *src;
-
- if (src->tabs)
- dest->tabs = pango_tab_array_copy (src->tabs);
-
- dest->language = src->language;
-
- if (dest->font)
- dest->font = pango_font_description_copy (src->font);
-
- dest->refcount = orig_refcount;
- dest->realized = FALSE;
-}
-
-/**
- * gtk_text_attributes_ref:
- * @values: a #GtkTextAttributes
- *
- * Increments the reference count on @values.
- **/
-void
-gtk_text_attributes_ref (GtkTextAttributes *values)
-{
- g_return_if_fail (values != NULL);
-
- values->refcount += 1;
-}
-
-/**
- * gtk_text_attributes_unref:
- * @values: a #GtkTextAttributes
- *
- * Decrements the reference count on @values, freeing the structure
- * if the reference count reaches 0.
- **/
-void
-gtk_text_attributes_unref (GtkTextAttributes *values)
-{
- g_return_if_fail (values != NULL);
- g_return_if_fail (values->refcount > 0);
-
- values->refcount -= 1;
-
- if (values->refcount == 0)
- {
- g_assert (!values->realized);
-
- if (values->appearance.bg_stipple)
- gdk_bitmap_unref (values->appearance.bg_stipple);
-
- if (values->appearance.fg_stipple)
- gdk_bitmap_unref (values->appearance.fg_stipple);
-
- if (values->tabs)
- pango_tab_array_free (values->tabs);
-
- if (values->font)
- pango_font_description_free (values->font);
-
- g_free (values);
- }
-}
-
-void
-_gtk_text_attributes_realize (GtkTextAttributes *values,
- GdkColormap *cmap,
- GdkVisual *visual)
-{
- g_return_if_fail (values != NULL);
- g_return_if_fail (values->refcount > 0);
- g_return_if_fail (!values->realized);
-
- /* It is wrong to use this colormap, FIXME */
- gdk_colormap_alloc_color (cmap,
- &values->appearance.fg_color,
- FALSE, TRUE);
-
- gdk_colormap_alloc_color (cmap,
- &values->appearance.bg_color,
- FALSE, TRUE);
-
- values->realized = TRUE;
-}
-
-void
-_gtk_text_attributes_unrealize (GtkTextAttributes *values,
- GdkColormap *cmap,
- GdkVisual *visual)
-{
- g_return_if_fail (values != NULL);
- g_return_if_fail (values->refcount > 0);
- g_return_if_fail (values->realized);
-
- gdk_colormap_free_colors (cmap,
- &values->appearance.fg_color, 1);
-
-
- gdk_colormap_free_colors (cmap,
- &values->appearance.bg_color, 1);
-
- values->appearance.fg_color.pixel = 0;
- values->appearance.bg_color.pixel = 0;
-
- values->realized = FALSE;
-}
-
-void
-_gtk_text_attributes_fill_from_tags (GtkTextAttributes *dest,
- GtkTextTag** tags,
- guint n_tags)
-{
- guint n = 0;
-
- g_return_if_fail (!dest->realized);
-
- while (n < n_tags)
- {
- GtkTextTag *tag = tags[n];
- GtkTextAttributes *vals = tag->values;
-
- g_assert (tag->table != NULL);
- if (n > 0)
- g_assert (tags[n]->priority > tags[n-1]->priority);
-
- if (tag->bg_color_set)
- {
- dest->appearance.bg_color = vals->appearance.bg_color;
-
- dest->appearance.draw_bg = TRUE;
- }
- if (tag->fg_color_set)
- dest->appearance.fg_color = vals->appearance.fg_color;
-
- if (tag->bg_stipple_set)
- {
- gdk_bitmap_ref (vals->appearance.bg_stipple);
- if (dest->appearance.bg_stipple)
- gdk_bitmap_unref (dest->appearance.bg_stipple);
- dest->appearance.bg_stipple = vals->appearance.bg_stipple;
-
- dest->appearance.draw_bg = TRUE;
- }
-
- if (tag->fg_stipple_set)
- {
- gdk_bitmap_ref (vals->appearance.fg_stipple);
- if (dest->appearance.fg_stipple)
- gdk_bitmap_unref (dest->appearance.fg_stipple);
- dest->appearance.fg_stipple = vals->appearance.fg_stipple;
- }
-
- if (vals->font)
- {
- if (dest->font)
- pango_font_description_merge (dest->font, vals->font, TRUE);
- else
- dest->font = pango_font_description_copy (vals->font);
- }
-
- /* multiply all the scales together to get a composite */
- if (tag->scale_set)
- dest->font_scale *= vals->font_scale;
-
- if (tag->justification_set)
- dest->justification = vals->justification;
-
- if (vals->direction != GTK_TEXT_DIR_NONE)
- dest->direction = vals->direction;
-
- if (tag->left_margin_set)
- dest->left_margin = vals->left_margin;
-
- if (tag->indent_set)
- dest->indent = vals->indent;
-
- if (tag->rise_set)
- dest->appearance.rise = vals->appearance.rise;
-
- if (tag->right_margin_set)
- dest->right_margin = vals->right_margin;
-
- if (tag->pixels_above_lines_set)
- dest->pixels_above_lines = vals->pixels_above_lines;
-
- if (tag->pixels_below_lines_set)
- dest->pixels_below_lines = vals->pixels_below_lines;
-
- if (tag->pixels_inside_wrap_set)
- dest->pixels_inside_wrap = vals->pixels_inside_wrap;
-
- if (tag->tabs_set)
- {
- if (dest->tabs)
- pango_tab_array_free (dest->tabs);
- dest->tabs = pango_tab_array_copy (vals->tabs);
- }
-
- if (tag->wrap_mode_set)
- dest->wrap_mode = vals->wrap_mode;
-
- if (tag->underline_set)
- dest->appearance.underline = vals->appearance.underline;
-
- if (tag->strikethrough_set)
- dest->appearance.strikethrough = vals->appearance.strikethrough;
-
- if (tag->invisible_set)
- dest->invisible = vals->invisible;
-
- if (tag->editable_set)
- dest->editable = vals->editable;
-
- if (tag->bg_full_height_set)
- dest->bg_full_height = vals->bg_full_height;
-
- if (tag->language_set)
- dest->language = vals->language;
-
- ++n;
- }
-}
-
-gboolean
-_gtk_text_tag_affects_size (GtkTextTag *tag)
-{
- g_return_val_if_fail (GTK_IS_TEXT_TAG (tag), FALSE);
-
- return
- (tag->values->font && pango_font_description_get_set_fields (tag->values->font) != 0) ||
- tag->scale_set ||
- tag->justification_set ||
- tag->left_margin_set ||
- tag->indent_set ||
- tag->rise_set ||
- tag->right_margin_set ||
- tag->pixels_above_lines_set ||
- tag->pixels_below_lines_set ||
- tag->pixels_inside_wrap_set ||
- tag->tabs_set ||
- tag->underline_set ||
- tag->wrap_mode_set ||
- tag->invisible_set;
-}
-
-gboolean
-_gtk_text_tag_affects_nonsize_appearance (GtkTextTag *tag)
-{
- g_return_val_if_fail (GTK_IS_TEXT_TAG (tag), FALSE);
-
- return
- tag->bg_color_set ||
- tag->bg_stipple_set ||
- tag->fg_color_set ||
- tag->fg_stipple_set ||
- tag->strikethrough_set ||
- tag->bg_full_height_set;
-}