Compare commits
6 Commits
css-style-
...
wip/baeder
Author | SHA1 | Date | |
---|---|---|---|
|
0694b9b204 | ||
|
4047fa34bb | ||
|
880006bb46 | ||
|
cd4712380b | ||
|
5b3e0e11a2 | ||
|
51a0f98900 |
@@ -186,14 +186,13 @@ transition_info_add (TransitionInfo infos[GTK_CSS_PROPERTY_N_PROPERTIES],
|
||||
GtkStyleProperty *property,
|
||||
guint index)
|
||||
{
|
||||
gtk_internal_return_if_fail (GTK_IS_STYLE_PROPERTY (property));
|
||||
|
||||
if (GTK_IS_CSS_SHORTHAND_PROPERTY (property))
|
||||
{
|
||||
GtkCssShorthandProperty *shorthand = GTK_CSS_SHORTHAND_PROPERTY (property);
|
||||
GtkCssShorthandProperty *shorthand = (GtkCssShorthandProperty *) property;
|
||||
guint len = _gtk_css_shorthand_property_get_n_subproperties (shorthand);
|
||||
guint i;
|
||||
|
||||
for (i = 0; i < _gtk_css_shorthand_property_get_n_subproperties (shorthand); i++)
|
||||
for (i = 0; i < len; i++)
|
||||
{
|
||||
GtkCssStyleProperty *prop = _gtk_css_shorthand_property_get_subproperty (shorthand, i);
|
||||
|
||||
@@ -228,9 +227,10 @@ transition_infos_set (TransitionInfo infos[GTK_CSS_PROPERTY_N_PROPERTIES],
|
||||
prop_value = _gtk_css_array_value_get_nth (transitions, i);
|
||||
if (g_ascii_strcasecmp (_gtk_css_ident_value_get (prop_value), "all") == 0)
|
||||
{
|
||||
const guint len = _gtk_css_style_property_get_n_properties ();
|
||||
guint j;
|
||||
|
||||
for (j = 0; j < _gtk_css_style_property_get_n_properties (); j++)
|
||||
for (j = 0; j < len; j++)
|
||||
{
|
||||
property = GTK_STYLE_PROPERTY (_gtk_css_style_property_lookup_by_id (j));
|
||||
transition_info_add (infos, property, i);
|
||||
|
@@ -151,7 +151,6 @@ _gtk_css_color_value_resolve (GtkCssValue *color,
|
||||
GtkCssValue *value;
|
||||
|
||||
gtk_internal_return_val_if_fail (color != NULL, NULL);
|
||||
gtk_internal_return_val_if_fail (provider == NULL || GTK_IS_STYLE_PROVIDER (provider), NULL);
|
||||
|
||||
switch (color->type)
|
||||
{
|
||||
|
@@ -298,17 +298,18 @@ _gtk_css_parser_skip_whitespace (GtkCssParser *parser)
|
||||
}
|
||||
|
||||
gboolean
|
||||
_gtk_css_parser_try (GtkCssParser *parser,
|
||||
const char *string,
|
||||
gboolean skip_whitespace)
|
||||
gtk_css_parser_try_len (GtkCssParser *parser,
|
||||
const char *string,
|
||||
gsize string_len,
|
||||
gboolean skip_whitespace)
|
||||
{
|
||||
g_return_val_if_fail (GTK_IS_CSS_PARSER (parser), FALSE);
|
||||
g_return_val_if_fail (string != NULL, FALSE);
|
||||
|
||||
if (g_ascii_strncasecmp (parser->data, string, strlen (string)) != 0)
|
||||
if (g_ascii_strncasecmp (parser->data, string, string_len) != 0)
|
||||
return FALSE;
|
||||
|
||||
parser->data += strlen (string);
|
||||
parser->data += string_len;
|
||||
|
||||
if (skip_whitespace)
|
||||
_gtk_css_parser_skip_whitespace (parser);
|
||||
|
@@ -66,8 +66,10 @@ gboolean _gtk_css_parser_is_string (GtkCssParser *parser
|
||||
* however is fine to call if you don’t know yet if the token is a foo or a bar,
|
||||
* you can _try_bar() if try_foo() failed.
|
||||
*/
|
||||
gboolean _gtk_css_parser_try (GtkCssParser *parser,
|
||||
#define _gtk_css_parser_try(p, s, skip) (gtk_css_parser_try_len (p, s, strlen(s), skip))
|
||||
gboolean gtk_css_parser_try_len (GtkCssParser *parser,
|
||||
const char *string,
|
||||
gsize string_len,
|
||||
gboolean skip_whitespace);
|
||||
char * _gtk_css_parser_try_ident (GtkCssParser *parser,
|
||||
gboolean skip_whitespace);
|
||||
|
@@ -207,9 +207,6 @@ gtk_css_static_style_compute_value (GtkCssStaticStyle *style,
|
||||
{
|
||||
GtkCssValue *value;
|
||||
|
||||
gtk_internal_return_if_fail (GTK_IS_CSS_STATIC_STYLE (style));
|
||||
gtk_internal_return_if_fail (GTK_IS_STYLE_PROVIDER (provider));
|
||||
gtk_internal_return_if_fail (parent_style == NULL || GTK_IS_CSS_STYLE (parent_style));
|
||||
gtk_internal_return_if_fail (id < GTK_CSS_PROPERTY_N_PROPERTIES);
|
||||
|
||||
/* http://www.w3.org/TR/css3-cascade/#cascade
|
||||
|
@@ -200,14 +200,14 @@ gtk_css_transform_apply (const GtkCssTransform *transform,
|
||||
break;
|
||||
case GTK_CSS_TRANSFORM_SKEW:
|
||||
graphene_matrix_init_skew (&skew,
|
||||
_gtk_css_number_value_get (transform->skew.x, 100),
|
||||
_gtk_css_number_value_get (transform->skew.y, 100));
|
||||
_gtk_css_number_value_get (transform->skew.x, 100) / 180.0f * G_PI,
|
||||
_gtk_css_number_value_get (transform->skew.y, 100) /180.0f * G_PI);
|
||||
graphene_matrix_multiply (matrix, &skew, &tmp);
|
||||
graphene_matrix_init_from_matrix (matrix, &tmp);
|
||||
break;
|
||||
case GTK_CSS_TRANSFORM_SKEW_X:
|
||||
graphene_matrix_init_skew (&skew,
|
||||
_gtk_css_number_value_get (transform->skew_x.skew, 100),
|
||||
_gtk_css_number_value_get (transform->skew_x.skew, 100) / 180.0f * G_PI,
|
||||
0);
|
||||
graphene_matrix_multiply (matrix, &skew, &tmp);
|
||||
graphene_matrix_init_from_matrix (matrix, &tmp);
|
||||
@@ -215,7 +215,7 @@ gtk_css_transform_apply (const GtkCssTransform *transform,
|
||||
case GTK_CSS_TRANSFORM_SKEW_Y:
|
||||
graphene_matrix_init_skew (&skew,
|
||||
0,
|
||||
_gtk_css_number_value_get (transform->skew_y.skew, 100));
|
||||
_gtk_css_number_value_get (transform->skew_y.skew, 100) / 180.0f * G_PI);
|
||||
graphene_matrix_multiply (matrix, &skew, &tmp);
|
||||
graphene_matrix_init_from_matrix (matrix, &tmp);
|
||||
break;
|
||||
|
@@ -5638,15 +5638,15 @@ gtk_label_move_logically (GtkLabel *label,
|
||||
|
||||
if (priv->text)
|
||||
{
|
||||
PangoLogAttr *log_attrs;
|
||||
const PangoLogAttr *log_attrs;
|
||||
gint n_attrs;
|
||||
gint length;
|
||||
|
||||
gtk_label_ensure_layout (label);
|
||||
|
||||
|
||||
length = g_utf8_strlen (priv->text, -1);
|
||||
|
||||
pango_layout_get_log_attrs (priv->layout, &log_attrs, &n_attrs);
|
||||
log_attrs = pango_layout_get_log_attrs_readonly (priv->layout, &n_attrs);
|
||||
|
||||
while (count > 0 && offset < length)
|
||||
{
|
||||
@@ -5664,8 +5664,6 @@ gtk_label_move_logically (GtkLabel *label,
|
||||
|
||||
count++;
|
||||
}
|
||||
|
||||
g_free (log_attrs);
|
||||
}
|
||||
|
||||
return g_utf8_offset_to_pointer (priv->text, offset) - priv->text;
|
||||
@@ -5738,19 +5736,17 @@ gtk_label_move_forward_word (GtkLabel *label,
|
||||
length = g_utf8_strlen (priv->text, -1);
|
||||
if (new_pos < length)
|
||||
{
|
||||
PangoLogAttr *log_attrs;
|
||||
const PangoLogAttr *log_attrs;
|
||||
gint n_attrs;
|
||||
|
||||
gtk_label_ensure_layout (label);
|
||||
|
||||
pango_layout_get_log_attrs (priv->layout, &log_attrs, &n_attrs);
|
||||
log_attrs = pango_layout_get_log_attrs_readonly (priv->layout, &n_attrs);
|
||||
|
||||
/* Find the next word end */
|
||||
new_pos++;
|
||||
while (new_pos < n_attrs && !log_attrs[new_pos].is_word_end)
|
||||
new_pos++;
|
||||
|
||||
g_free (log_attrs);
|
||||
new_pos++;
|
||||
}
|
||||
|
||||
return g_utf8_offset_to_pointer (priv->text, new_pos) - priv->text;
|
||||
@@ -5767,20 +5763,18 @@ gtk_label_move_backward_word (GtkLabel *label,
|
||||
|
||||
if (new_pos > 0)
|
||||
{
|
||||
PangoLogAttr *log_attrs;
|
||||
const PangoLogAttr *log_attrs;
|
||||
gint n_attrs;
|
||||
|
||||
gtk_label_ensure_layout (label);
|
||||
|
||||
pango_layout_get_log_attrs (priv->layout, &log_attrs, &n_attrs);
|
||||
log_attrs = pango_layout_get_log_attrs_readonly (priv->layout, &n_attrs);
|
||||
|
||||
new_pos -= 1;
|
||||
|
||||
/* Find the previous word beginning */
|
||||
while (new_pos > 0 && !log_attrs[new_pos].is_word_start)
|
||||
new_pos--;
|
||||
|
||||
g_free (log_attrs);
|
||||
new_pos--;
|
||||
}
|
||||
|
||||
return g_utf8_offset_to_pointer (priv->text, new_pos) - priv->text;
|
||||
|
@@ -3606,7 +3606,6 @@ indicator_reset (Indicator *indicator)
|
||||
indicator->tick_id = 0;
|
||||
}
|
||||
|
||||
indicator->scrollbar = NULL;
|
||||
indicator->over = FALSE;
|
||||
gtk_progress_tracker_finish (&indicator->tracker);
|
||||
indicator->current_pos = indicator->source_pos = indicator->target_pos = 0;
|
||||
|
@@ -48,6 +48,7 @@
|
||||
#include "visual.h"
|
||||
#include "window.h"
|
||||
#include "gtkstackcombo.h"
|
||||
#include "widgetview.h"
|
||||
|
||||
#include "gtkmagnifierprivate.h"
|
||||
|
||||
@@ -85,6 +86,7 @@ gtk_inspector_init (void)
|
||||
g_type_ensure (GTK_TYPE_INSPECTOR_VISUAL);
|
||||
g_type_ensure (GTK_TYPE_INSPECTOR_WINDOW);
|
||||
g_type_ensure (GTK_TYPE_STACK_COMBO);
|
||||
g_type_ensure (GTK_TYPE_WIDGET_VIEW);
|
||||
|
||||
if (extension_point == NULL)
|
||||
{
|
||||
|
@@ -37,5 +37,6 @@ inspector_sources = files(
|
||||
'treewalk.c',
|
||||
'updatesoverlay.c',
|
||||
'visual.c',
|
||||
'widgetview.c',
|
||||
'window.c',
|
||||
)
|
||||
|
@@ -29,6 +29,7 @@
|
||||
#include "gtkframe.h"
|
||||
#include "gtkbutton.h"
|
||||
#include "gtkwidgetprivate.h"
|
||||
#include "widgetview.h"
|
||||
|
||||
|
||||
struct _GtkInspectorMiscInfoPrivate {
|
||||
@@ -223,19 +224,10 @@ update_focus_widget (GtkInspectorMiscInfo *sl)
|
||||
GtkWidget *widget;
|
||||
|
||||
widget = gtk_window_get_focus (GTK_WINDOW (sl->priv->object));
|
||||
if (widget)
|
||||
{
|
||||
gchar *tmp;
|
||||
tmp = g_strdup_printf ("%p", widget);
|
||||
gtk_label_set_label (GTK_LABEL (sl->priv->focus_widget), tmp);
|
||||
g_free (tmp);
|
||||
gtk_widget_set_sensitive (sl->priv->focus_widget_button, TRUE);
|
||||
}
|
||||
else
|
||||
{
|
||||
gtk_label_set_label (GTK_LABEL (sl->priv->focus_widget), "NULL");
|
||||
gtk_widget_set_sensitive (sl->priv->focus_widget_button, FALSE);
|
||||
}
|
||||
|
||||
gtk_widget_view_set_inspected_widget (GTK_WIDGET_VIEW (sl->priv->focus_widget),
|
||||
widget);
|
||||
gtk_widget_set_sensitive (sl->priv->focus_widget_button, widget != NULL);
|
||||
}
|
||||
|
||||
static void
|
||||
|
@@ -176,11 +176,9 @@
|
||||
</object>
|
||||
</child>
|
||||
<child>
|
||||
<object class="GtkLabel" id="focus_widget">
|
||||
<property name="selectable">1</property>
|
||||
<object class="GtkWidgetView" id="focus_widget">
|
||||
<property name="halign">end</property>
|
||||
<property name="valign">baseline</property>
|
||||
<property name="ellipsize">end</property>
|
||||
</object>
|
||||
</child>
|
||||
<child>
|
||||
|
93
gtk/inspector/widgetview.c
Normal file
93
gtk/inspector/widgetview.c
Normal file
@@ -0,0 +1,93 @@
|
||||
|
||||
#include "widgetview.h"
|
||||
#include "gtklabel.h"
|
||||
#include "gtkpicture.h"
|
||||
#include "gtkbox.h"
|
||||
|
||||
G_DEFINE_TYPE (GtkWidgetView, gtk_widget_view, GTK_TYPE_WIDGET);
|
||||
|
||||
static void
|
||||
gtk_widget_view_measure (GtkWidget *widget,
|
||||
GtkOrientation orientation,
|
||||
int for_size,
|
||||
int *minimum,
|
||||
int *natural,
|
||||
int *minimum_baseline,
|
||||
int *natural_baseline)
|
||||
{
|
||||
GtkWidgetView *self = GTK_WIDGET_VIEW (widget);
|
||||
|
||||
gtk_widget_measure (self->box, orientation, for_size,
|
||||
minimum, natural, minimum_baseline, natural_baseline);
|
||||
}
|
||||
|
||||
static void
|
||||
gtk_widget_view_size_allocate (GtkWidget *widget,
|
||||
int width,
|
||||
int height,
|
||||
int baseline)
|
||||
{
|
||||
GtkWidgetView *self = GTK_WIDGET_VIEW (widget);
|
||||
|
||||
gtk_widget_size_allocate (self->box,
|
||||
&(GtkAllocation) {
|
||||
0, 0,
|
||||
width, height
|
||||
}, -1);
|
||||
}
|
||||
|
||||
static void
|
||||
gtk_widget_view_class_init (GtkWidgetViewClass *klass)
|
||||
{
|
||||
GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass);
|
||||
|
||||
widget_class->measure = gtk_widget_view_measure;
|
||||
widget_class->size_allocate = gtk_widget_view_size_allocate;
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
gtk_widget_view_init (GtkWidgetView *self)
|
||||
{
|
||||
gtk_widget_set_has_surface (GTK_WIDGET (self), FALSE);
|
||||
|
||||
self->typename_label = gtk_label_new ("");
|
||||
self->paintable_picture = gtk_picture_new ();
|
||||
self->box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 12);
|
||||
|
||||
gtk_container_add (GTK_CONTAINER (self->box), self->typename_label);
|
||||
gtk_container_add (GTK_CONTAINER (self->box), self->paintable_picture);
|
||||
|
||||
gtk_widget_set_parent (self->box, GTK_WIDGET (self));
|
||||
}
|
||||
|
||||
|
||||
GtkWidget *
|
||||
gtk_widget_view_new (void)
|
||||
{
|
||||
return (GtkWidget *) g_object_new (GTK_TYPE_WIDGET_VIEW, NULL);
|
||||
}
|
||||
|
||||
void
|
||||
gtk_widget_view_set_inspected_widget (GtkWidgetView *self,
|
||||
GtkWidget *inspected)
|
||||
{
|
||||
char typename_buffer[512];
|
||||
GdkPaintable *paintable;
|
||||
|
||||
g_set_object (&self->inspected, inspected);
|
||||
|
||||
if (!self->inspected)
|
||||
{
|
||||
gtk_label_set_label (GTK_LABEL (self->typename_label), "NULL");
|
||||
return;
|
||||
}
|
||||
|
||||
g_snprintf (typename_buffer, sizeof (typename_buffer),
|
||||
"%s", G_OBJECT_TYPE_NAME (inspected));
|
||||
gtk_label_set_label (GTK_LABEL (self->typename_label), typename_buffer);
|
||||
|
||||
paintable = gtk_widget_paintable_new (inspected);
|
||||
gtk_picture_set_paintable (GTK_PICTURE (self->paintable_picture), paintable);
|
||||
g_object_unref (paintable);
|
||||
}
|
39
gtk/inspector/widgetview.h
Normal file
39
gtk/inspector/widgetview.h
Normal file
@@ -0,0 +1,39 @@
|
||||
|
||||
#ifndef __GTK_WIDGET_VIEW_H__
|
||||
#define __GTK_WIDGET_VIEW_H__
|
||||
|
||||
#include "gtkwidget.h"
|
||||
#include "gtkwidgetpaintable.h"
|
||||
|
||||
#define GTK_TYPE_WIDGET_VIEW (gtk_widget_view_get_type ())
|
||||
#define GTK_WIDGET_VIEW(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_WIDGET_VIEW, GtkWidgetView))
|
||||
#define GTK_WIDGET_VIEW_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_WIDGET_VIEW, GtkWidgetViewClass))
|
||||
#define GTK_IS_WIDGET_VIEW(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_WIDGET_VIEW))
|
||||
#define GTK_IS_WIDGET_VIEW_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_WIDGET_VIEW))
|
||||
#define GTK_WIDGET_VIEW_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_WIDGET_VIEW, GtkWidgetViewClass))
|
||||
|
||||
typedef struct _GtkWidgetView GtkWidgetView;
|
||||
typedef struct _GtkWidgetViewClass GtkWidgetViewClass;
|
||||
|
||||
struct _GtkWidgetView
|
||||
{
|
||||
GtkWidget parent_instance;
|
||||
|
||||
GtkWidget *box;
|
||||
GtkWidget *typename_label;
|
||||
GtkWidget *paintable_picture;
|
||||
|
||||
GtkWidget *inspected;
|
||||
};
|
||||
|
||||
struct _GtkWidgetViewClass
|
||||
{
|
||||
GtkWidgetClass parent_class;
|
||||
};
|
||||
|
||||
GType gtk_widget_view_get_type (void) G_GNUC_CONST;
|
||||
GtkWidget * gtk_widget_view_new (void);
|
||||
void gtk_widget_view_set_inspected_widget (GtkWidgetView *self,
|
||||
GtkWidget *inspected);
|
||||
|
||||
#endif
|
Reference in New Issue
Block a user