forked from AuroraMiddleware/gtk
Merge branch 'css-text-transform' into 'master'
css: Implement text-transform See merge request GNOME/gtk!3862
This commit is contained in:
commit
24685612a9
@ -271,6 +271,7 @@ insert_tags_for_attributes (GtkTextBuffer *buffer,
|
||||
break;
|
||||
|
||||
case PANGO_ATTR_TEXT_TRANSFORM:
|
||||
INT_ATTR (text_transform);
|
||||
break;
|
||||
|
||||
case PANGO_ATTR_INVALID:
|
||||
|
@ -21,3 +21,5 @@ Shortcuts: <tt>Monospace</tt> – <b>Bold</b> – <i>Italic</i> – <big>Big</bi
|
||||
|
||||
<span line_height='1.33'>Line height: This is an example of widely spaced text. It was achieved by setting the line-height factor to 1.33. You can set the line-height factor to any value between 0 and 10.
|
||||
Note that the line height affects the spacing between paragraphs as well as between the wrapped lines inside a paragraph.</span>
|
||||
|
||||
Transforms: <span text_transform='uppercase'>straße</span> <span text_transform='capitalize'>up, up and away</span>
|
||||
|
@ -162,6 +162,7 @@ done with
|
||||
|caret-color|[CSS Basic User Interface Level 3](https://www.w3.org/TR/css3-ui/#caret-color) | CSS allows an auto value |
|
||||
|-gtk-secondary-caret-color|[Color](https://www.w3.org/TR/css-color-3/#valuea-def-color) | used for the secondary caret in bidirectional text |
|
||||
|letter-spacing| [CSS Text Level 3](https://www.w3.org/TR/css3-text/#letter-spacing) | |
|
||||
|text-transform| [CSS Text Level 3](https://www.w3.org/TR/css-text-3/#text-transform-property) | CSS allows full-width and full-size-kana. Since 4.6 |
|
||||
|line-height| [CSS Inline Layout Level 3](https://www.w3.org/TR/css-inline-3/#line-height-property) | Since 4.6 |
|
||||
|text-decoration-line| [CSS Text Decoration Level 3](https://www.w3.org/TR/css-text-decor-3/#text-decoration-line-property) | |
|
||||
|text-decoration-color| [CSS Text Decoration Level 3](https://www.w3.org/TR/css-text-decor-3/#text-decoration-color-property) | |
|
||||
|
@ -220,6 +220,10 @@ gtk_css_animated_style_set_animated_value (GtkCssAnimatedStyle *animated,
|
||||
unshare_font_variant (animated);
|
||||
gtk_css_take_value (&style->font_variant->text_decoration_style, value);
|
||||
break;
|
||||
case GTK_CSS_PROPERTY_TEXT_TRANSFORM:
|
||||
unshare_font_variant (animated);
|
||||
gtk_css_take_value (&style->font_variant->text_transform, value);
|
||||
break;
|
||||
case GTK_CSS_PROPERTY_FONT_KERNING:
|
||||
unshare_font_variant (animated);
|
||||
gtk_css_take_value (&style->font_variant->font_kerning, value);
|
||||
|
@ -1568,3 +1568,55 @@ _gtk_css_font_variant_east_asian_value_get (const GtkCssValue *value)
|
||||
|
||||
return value->value;
|
||||
}
|
||||
|
||||
/* GtkTextTransform */
|
||||
|
||||
static const GtkCssValueClass GTK_CSS_VALUE_TEXT_TRANSFORM = {
|
||||
"GtkCssTextTransformValue",
|
||||
gtk_css_value_enum_free,
|
||||
gtk_css_value_enum_compute,
|
||||
gtk_css_value_enum_equal,
|
||||
gtk_css_value_enum_transition,
|
||||
NULL,
|
||||
NULL,
|
||||
gtk_css_value_enum_print
|
||||
};
|
||||
|
||||
static GtkCssValue text_transform_values[] = {
|
||||
{ >K_CSS_VALUE_TEXT_TRANSFORM, 1, TRUE, GTK_CSS_TEXT_TRANSFORM_NONE, "none" },
|
||||
{ >K_CSS_VALUE_TEXT_TRANSFORM, 1, TRUE, GTK_CSS_TEXT_TRANSFORM_LOWERCASE, "lowercase" },
|
||||
{ >K_CSS_VALUE_TEXT_TRANSFORM, 1, TRUE, GTK_CSS_TEXT_TRANSFORM_UPPERCASE, "uppercase" },
|
||||
{ >K_CSS_VALUE_TEXT_TRANSFORM, 1, TRUE, GTK_CSS_TEXT_TRANSFORM_CAPITALIZE, "capitalize" },
|
||||
};
|
||||
|
||||
GtkCssValue *
|
||||
_gtk_css_text_transform_value_new (GtkTextTransform transform)
|
||||
{
|
||||
g_return_val_if_fail (transform < G_N_ELEMENTS (text_transform_values), NULL);
|
||||
|
||||
return _gtk_css_value_ref (&text_transform_values[transform]);
|
||||
}
|
||||
|
||||
GtkCssValue *
|
||||
_gtk_css_text_transform_value_try_parse (GtkCssParser *parser)
|
||||
{
|
||||
guint i;
|
||||
|
||||
g_return_val_if_fail (parser != NULL, NULL);
|
||||
|
||||
for (i = 0; i < G_N_ELEMENTS (text_transform_values); i++)
|
||||
{
|
||||
if (gtk_css_parser_try_ident (parser, text_transform_values[i].name))
|
||||
return _gtk_css_value_ref (&text_transform_values[i]);
|
||||
}
|
||||
|
||||
return NULL;
|
||||
}
|
||||
|
||||
GtkTextTransform
|
||||
_gtk_css_text_transform_value_get (const GtkCssValue *value)
|
||||
{
|
||||
g_return_val_if_fail (value->class == >K_CSS_VALUE_TEXT_TRANSFORM, GTK_CSS_TEXT_TRANSFORM_NONE);
|
||||
|
||||
return value->value;
|
||||
}
|
||||
|
@ -115,6 +115,9 @@ GtkCssFontVariantEastAsian _gtk_css_font_variant_east_asian_try_parse_one (GtkCs
|
||||
GtkCssFontVariantEastAsian base);
|
||||
GtkCssFontVariantEastAsian _gtk_css_font_variant_east_asian_value_get (const GtkCssValue *value);
|
||||
|
||||
GtkCssValue * _gtk_css_text_transform_value_new (GtkTextTransform transform);
|
||||
GtkCssValue * _gtk_css_text_transform_value_try_parse (GtkCssParser *parser);
|
||||
GtkTextTransform _gtk_css_text_transform_value_get (const GtkCssValue *value);
|
||||
G_END_DECLS
|
||||
|
||||
#endif /* __GTK_CSS_ENUM_VALUE_PRIVATE_H__ */
|
||||
|
@ -118,6 +118,7 @@ static const int font_variant_props[] = {
|
||||
GTK_CSS_PROPERTY_TEXT_DECORATION_LINE,
|
||||
GTK_CSS_PROPERTY_TEXT_DECORATION_COLOR,
|
||||
GTK_CSS_PROPERTY_TEXT_DECORATION_STYLE,
|
||||
GTK_CSS_PROPERTY_TEXT_TRANSFORM,
|
||||
GTK_CSS_PROPERTY_FONT_KERNING,
|
||||
GTK_CSS_PROPERTY_FONT_VARIANT_LIGATURES,
|
||||
GTK_CSS_PROPERTY_FONT_VARIANT_POSITION,
|
||||
@ -430,6 +431,9 @@ gtk_css_static_style_set_value (GtkCssStaticStyle *sstyle,
|
||||
case GTK_CSS_PROPERTY_TEXT_DECORATION_STYLE:
|
||||
gtk_css_take_value (&style->font_variant->text_decoration_style, value);
|
||||
break;
|
||||
case GTK_CSS_PROPERTY_TEXT_TRANSFORM:
|
||||
gtk_css_take_value (&style->font_variant->text_transform, value);
|
||||
break;
|
||||
case GTK_CSS_PROPERTY_FONT_KERNING:
|
||||
gtk_css_take_value (&style->font_variant->font_kerning, value);
|
||||
break;
|
||||
@ -810,6 +814,7 @@ gtk_css_font_variant_create_initial_values (void)
|
||||
values->text_decoration_line = _gtk_css_initial_value_new_compute (GTK_CSS_PROPERTY_TEXT_DECORATION_LINE, NULL, NULL, NULL);
|
||||
values->text_decoration_color = NULL;
|
||||
values->text_decoration_style = _gtk_css_initial_value_new_compute (GTK_CSS_PROPERTY_TEXT_DECORATION_STYLE, NULL, NULL, NULL);
|
||||
values->text_transform = _gtk_css_initial_value_new_compute (GTK_CSS_PROPERTY_TEXT_TRANSFORM, NULL, NULL, NULL);
|
||||
values->font_kerning = _gtk_css_initial_value_new_compute (GTK_CSS_PROPERTY_FONT_KERNING, NULL, NULL, NULL);
|
||||
values->font_variant_ligatures = _gtk_css_initial_value_new_compute (GTK_CSS_PROPERTY_FONT_VARIANT_LIGATURES, NULL, NULL, NULL);
|
||||
values->font_variant_position = _gtk_css_initial_value_new_compute (GTK_CSS_PROPERTY_FONT_VARIANT_POSITION, NULL, NULL, NULL);
|
||||
|
@ -126,6 +126,8 @@ gtk_css_style_get_value (GtkCssStyle *style,
|
||||
return style->font_variant->text_decoration_color ? style->font_variant->text_decoration_color : style->core->color;
|
||||
case GTK_CSS_PROPERTY_TEXT_DECORATION_STYLE:
|
||||
return style->font_variant->text_decoration_style;
|
||||
case GTK_CSS_PROPERTY_TEXT_TRANSFORM:
|
||||
return style->font_variant->text_transform;
|
||||
case GTK_CSS_PROPERTY_FONT_KERNING:
|
||||
return style->font_variant->font_kerning;
|
||||
case GTK_CSS_PROPERTY_FONT_VARIANT_LIGATURES:
|
||||
@ -400,6 +402,24 @@ get_pango_underline_from_style (GtkTextDecorationStyle style)
|
||||
g_return_val_if_reached (PANGO_UNDERLINE_SINGLE);
|
||||
}
|
||||
|
||||
static PangoTextTransform
|
||||
get_pango_text_transform_from_style (GtkTextTransform transform)
|
||||
{
|
||||
switch (transform)
|
||||
{
|
||||
case GTK_CSS_TEXT_TRANSFORM_NONE:
|
||||
return PANGO_TEXT_TRANSFORM_NONE;
|
||||
case GTK_CSS_TEXT_TRANSFORM_LOWERCASE:
|
||||
return PANGO_TEXT_TRANSFORM_LOWERCASE;
|
||||
case GTK_CSS_TEXT_TRANSFORM_UPPERCASE:
|
||||
return PANGO_TEXT_TRANSFORM_UPPERCASE;
|
||||
case GTK_CSS_TEXT_TRANSFORM_CAPITALIZE:
|
||||
return PANGO_TEXT_TRANSFORM_CAPITALIZE;
|
||||
default:
|
||||
return PANGO_TEXT_TRANSFORM_NONE;
|
||||
}
|
||||
}
|
||||
|
||||
static PangoOverline
|
||||
get_pango_overline_from_style (GtkTextDecorationStyle style)
|
||||
{
|
||||
@ -445,6 +465,7 @@ gtk_css_style_get_pango_attributes (GtkCssStyle *style)
|
||||
GtkCssFontVariantEastAsian east_asian;
|
||||
GString *s;
|
||||
char *settings;
|
||||
GtkTextTransform transform;
|
||||
|
||||
/* text-decoration */
|
||||
decoration_line = _gtk_css_text_decoration_line_value_get (style->font_variant->text_decoration_line);
|
||||
@ -655,6 +676,11 @@ gtk_css_style_get_pango_attributes (GtkCssStyle *style)
|
||||
g_string_free (s, TRUE);
|
||||
}
|
||||
|
||||
transform = _gtk_css_text_transform_value_get (style->font_variant->text_transform);
|
||||
|
||||
if (transform != GTK_CSS_TEXT_TRANSFORM_NONE)
|
||||
attrs = add_pango_attr (attrs, pango_attr_text_transform_new (get_pango_text_transform_from_style (transform)));
|
||||
|
||||
return attrs;
|
||||
}
|
||||
|
||||
|
@ -159,6 +159,7 @@ struct _GtkCssFontVariantValues {
|
||||
GtkCssValue *text_decoration_line;
|
||||
GtkCssValue *text_decoration_color; // NULL if currentColor
|
||||
GtkCssValue *text_decoration_style;
|
||||
GtkCssValue *text_transform;
|
||||
GtkCssValue *font_kerning;
|
||||
GtkCssValue *font_variant_ligatures;
|
||||
GtkCssValue *font_variant_position;
|
||||
|
@ -366,6 +366,18 @@ parse_text_decoration_style (GtkCssStyleProperty *property,
|
||||
return value;
|
||||
}
|
||||
|
||||
static GtkCssValue *
|
||||
parse_text_transform (GtkCssStyleProperty *property,
|
||||
GtkCssParser *parser)
|
||||
{
|
||||
GtkCssValue *value = _gtk_css_text_transform_value_try_parse (parser);
|
||||
|
||||
if (value == NULL)
|
||||
gtk_css_parser_error_syntax (parser, "unknown text transform value");
|
||||
|
||||
return value;
|
||||
}
|
||||
|
||||
static GtkCssValue *
|
||||
parse_font_kerning (GtkCssStyleProperty *property,
|
||||
GtkCssParser *parser)
|
||||
@ -917,6 +929,12 @@ _gtk_css_style_property_init_properties (void)
|
||||
GTK_CSS_AFFECTS_TEXT_ATTRS,
|
||||
parse_text_decoration_style,
|
||||
_gtk_css_text_decoration_style_value_new (GTK_CSS_TEXT_DECORATION_STYLE_SOLID));
|
||||
gtk_css_style_property_register ("text-transform",
|
||||
GTK_CSS_PROPERTY_TEXT_TRANSFORM,
|
||||
0,
|
||||
GTK_CSS_AFFECTS_TEXT_ATTRS | GTK_CSS_AFFECTS_TEXT_SIZE,
|
||||
parse_text_transform,
|
||||
_gtk_css_text_transform_value_new (GTK_CSS_TEXT_TRANSFORM_NONE));
|
||||
gtk_css_style_property_register ("font-kerning",
|
||||
GTK_CSS_PROPERTY_FONT_KERNING,
|
||||
0,
|
||||
|
@ -198,6 +198,7 @@ enum { /*< skip >*/
|
||||
GTK_CSS_PROPERTY_TEXT_DECORATION_LINE,
|
||||
GTK_CSS_PROPERTY_TEXT_DECORATION_COLOR,
|
||||
GTK_CSS_PROPERTY_TEXT_DECORATION_STYLE,
|
||||
GTK_CSS_PROPERTY_TEXT_TRANSFORM,
|
||||
GTK_CSS_PROPERTY_FONT_KERNING,
|
||||
GTK_CSS_PROPERTY_FONT_VARIANT_LIGATURES,
|
||||
GTK_CSS_PROPERTY_FONT_VARIANT_POSITION,
|
||||
@ -338,6 +339,13 @@ typedef enum /*< skip >*/ {
|
||||
GTK_CSS_TEXT_DECORATION_STYLE_WAVY
|
||||
} GtkTextDecorationStyle;
|
||||
|
||||
typedef enum /*< skip >*/ {
|
||||
GTK_CSS_TEXT_TRANSFORM_NONE,
|
||||
GTK_CSS_TEXT_TRANSFORM_LOWERCASE,
|
||||
GTK_CSS_TEXT_TRANSFORM_UPPERCASE,
|
||||
GTK_CSS_TEXT_TRANSFORM_CAPITALIZE,
|
||||
} GtkTextTransform;
|
||||
|
||||
/* for the order in arrays */
|
||||
typedef enum /*< skip >*/ {
|
||||
GTK_CSS_TOP,
|
||||
|
@ -438,6 +438,9 @@ _gtk_text_attributes_fill_from_tags (GtkTextAttributes *dest,
|
||||
|
||||
if (tag->priv->insert_hyphens_set)
|
||||
dest->no_hyphens = vals->no_hyphens;
|
||||
|
||||
if (tag->priv->text_transform_set)
|
||||
dest->text_transform = vals->text_transform;
|
||||
}
|
||||
|
||||
dest->left_margin += left_margin_accumulative;
|
||||
@ -467,7 +470,8 @@ _gtk_text_tag_affects_size (GtkTextTag *tag)
|
||||
priv->wrap_mode_set ||
|
||||
priv->invisible_set ||
|
||||
priv->font_features_set ||
|
||||
priv->letter_spacing_set;
|
||||
priv->letter_spacing_set ||
|
||||
priv->text_transform_set;
|
||||
}
|
||||
|
||||
gboolean
|
||||
|
@ -159,6 +159,7 @@ struct _GtkTextAttributes
|
||||
guint show_spaces : 3; /* PangoShowFlags */
|
||||
guint no_hyphens : 1;
|
||||
guint line_height_is_absolute : 1;
|
||||
guint text_transform : 3; /* PangoTextTransform */
|
||||
};
|
||||
|
||||
GtkTextAttributes* gtk_text_attributes_new (void);
|
||||
|
@ -4713,6 +4713,7 @@ insert_tags_for_attributes (GtkTextBuffer *buffer,
|
||||
break;
|
||||
|
||||
case PANGO_ATTR_TEXT_TRANSFORM:
|
||||
INT_ATTR (text_transform);
|
||||
break;
|
||||
|
||||
case PANGO_ATTR_SHAPE:
|
||||
|
@ -1683,6 +1683,15 @@ add_text_attrs (GtkTextLayout *layout,
|
||||
attr->start_index = start;
|
||||
attr->end_index = start + byte_count;
|
||||
|
||||
pango_attr_list_insert (attrs, attr);
|
||||
}
|
||||
|
||||
if (style->text_transform != PANGO_TEXT_TRANSFORM_NONE)
|
||||
{
|
||||
attr = pango_attr_text_transform_new (style->text_transform);
|
||||
attr->start_index = start;
|
||||
attr->end_index = start + byte_count;
|
||||
|
||||
pango_attr_list_insert (attrs, attr);
|
||||
}
|
||||
}
|
||||
|
@ -134,6 +134,7 @@ enum {
|
||||
PROP_ALLOW_BREAKS,
|
||||
PROP_SHOW_SPACES,
|
||||
PROP_INSERT_HYPHENS,
|
||||
PROP_TEXT_TRANSFORM,
|
||||
|
||||
/* Behavior args */
|
||||
PROP_ACCUMULATIVE_MARGIN,
|
||||
@ -176,6 +177,7 @@ enum {
|
||||
PROP_ALLOW_BREAKS_SET,
|
||||
PROP_SHOW_SPACES_SET,
|
||||
PROP_INSERT_HYPHENS_SET,
|
||||
PROP_TEXT_TRANSFORM_SET,
|
||||
|
||||
LAST_ARG
|
||||
};
|
||||
@ -856,6 +858,22 @@ gtk_text_tag_class_init (GtkTextTagClass *klass)
|
||||
TRUE,
|
||||
GTK_PARAM_READWRITE));
|
||||
|
||||
/**
|
||||
* GtkTextTag:text-transform:
|
||||
*
|
||||
* How to transform the text for display.
|
||||
*
|
||||
* Since: 4.6
|
||||
*/
|
||||
g_object_class_install_property (object_class,
|
||||
PROP_TEXT_TRANSFORM,
|
||||
g_param_spec_enum ("text-transform",
|
||||
P_("Text Transform"),
|
||||
P_("Whether to transform text for display."),
|
||||
PANGO_TYPE_TEXT_TRANSFORM,
|
||||
PANGO_TEXT_TRANSFORM_NONE,
|
||||
GTK_PARAM_READWRITE));
|
||||
|
||||
/**
|
||||
* GtkTextTag:accumulative-margin:
|
||||
*
|
||||
@ -1034,6 +1052,10 @@ gtk_text_tag_class_init (GtkTextTagClass *klass)
|
||||
ADD_SET_PROP ("insert-hyphens-set", PROP_INSERT_HYPHENS_SET,
|
||||
P_("Insert hyphens set"),
|
||||
P_("Whether this tag affects insertion of hyphens"));
|
||||
|
||||
ADD_SET_PROP ("text-transform-set", PROP_TEXT_TRANSFORM_SET,
|
||||
P_("Text transform set"),
|
||||
P_("Whether this tag affects text transformation"));
|
||||
}
|
||||
|
||||
static void
|
||||
@ -1783,6 +1805,12 @@ gtk_text_tag_set_property (GObject *object,
|
||||
g_object_notify (object, "insert-hyphens-set");
|
||||
break;
|
||||
|
||||
case PROP_TEXT_TRANSFORM:
|
||||
priv->text_transform_set = TRUE;
|
||||
priv->values->text_transform = g_value_get_enum (value);
|
||||
g_object_notify (object, "text-transform-set");
|
||||
break;
|
||||
|
||||
case PROP_ACCUMULATIVE_MARGIN:
|
||||
priv->accumulative_margin = g_value_get_boolean (value);
|
||||
g_object_notify (object, "accumulative-margin");
|
||||
@ -1947,6 +1975,10 @@ gtk_text_tag_set_property (GObject *object,
|
||||
priv->insert_hyphens_set = g_value_get_boolean (value);
|
||||
break;
|
||||
|
||||
case PROP_TEXT_TRANSFORM_SET:
|
||||
priv->text_transform_set = g_value_get_boolean (value);
|
||||
break;
|
||||
|
||||
default:
|
||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||
break;
|
||||
@ -2159,6 +2191,10 @@ gtk_text_tag_get_property (GObject *object,
|
||||
g_value_set_boolean (value, !priv->values->no_hyphens);
|
||||
break;
|
||||
|
||||
case PROP_TEXT_TRANSFORM:
|
||||
g_value_set_enum (value, priv->values->text_transform);
|
||||
break;
|
||||
|
||||
case PROP_ACCUMULATIVE_MARGIN:
|
||||
g_value_set_boolean (value, priv->accumulative_margin);
|
||||
break;
|
||||
@ -2301,6 +2337,10 @@ gtk_text_tag_get_property (GObject *object,
|
||||
g_value_set_boolean (value, priv->insert_hyphens_set);
|
||||
break;
|
||||
|
||||
case PROP_TEXT_TRANSFORM_SET:
|
||||
g_value_set_boolean (value, priv->text_transform_set);
|
||||
break;
|
||||
|
||||
case PROP_BACKGROUND:
|
||||
case PROP_FOREGROUND:
|
||||
case PROP_PARAGRAPH_BACKGROUND:
|
||||
|
@ -87,6 +87,7 @@ struct _GtkTextTagPrivate
|
||||
guint allow_breaks_set : 1;
|
||||
guint show_spaces_set : 1;
|
||||
guint insert_hyphens_set : 1;
|
||||
guint text_transform_set : 1;
|
||||
|
||||
/* Whether these margins accumulate or override */
|
||||
guint accumulative_margin : 1;
|
||||
|
Loading…
Reference in New Issue
Block a user