1 /* GTK - The GIMP Toolkit
2 * Copyright (C) 2011 Benjamin Otte <otte@gnome.org>
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the
16 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
17 * Boston, MA 02111-1307, USA.
20 #ifndef __GTK_CSS_PARSER_PRIVATE_H__
21 #define __GTK_CSS_PARSER_PRIVATE_H__
23 #include "gtk/gtkcsstypesprivate.h"
24 #include <gtk/gtksymboliccolor.h>
28 typedef enum /*< skip >*/ {
29 GTK_CSS_POSITIVE_ONLY = (1 << 0),
30 GTK_CSS_PARSE_PERCENT = (1 << 1),
31 GTK_CSS_PARSE_NUMBER = (1 << 2),
32 GTK_CSS_NUMBER_AS_PIXELS = (1 << 3),
33 GTK_CSS_PARSE_LENGTH = (1 << 4),
34 GTK_CSS_PARSE_ANGLE = (1 << 5)
35 } GtkCssNumberParseFlags;
37 typedef struct _GtkCssParser GtkCssParser;
39 typedef void (* GtkCssParserErrorFunc) (GtkCssParser *parser,
43 GtkCssParser * _gtk_css_parser_new (const char *data,
44 GtkCssParserErrorFunc error_func,
46 void _gtk_css_parser_free (GtkCssParser *parser);
48 void _gtk_css_parser_take_error (GtkCssParser *parser,
50 void _gtk_css_parser_error (GtkCssParser *parser,
52 ...) G_GNUC_PRINTF (2, 3);
54 guint _gtk_css_parser_get_line (GtkCssParser *parser);
55 guint _gtk_css_parser_get_position (GtkCssParser *parser);
57 gboolean _gtk_css_parser_is_eof (GtkCssParser *parser);
58 gboolean _gtk_css_parser_begins_with (GtkCssParser *parser,
60 gboolean _gtk_css_parser_has_prefix (GtkCssParser *parser,
62 gboolean _gtk_css_parser_is_string (GtkCssParser *parser);
65 * _try_foo() functions do not modify the data pointer if they fail, nor do they
66 * signal an error. _read_foo() will modify the data pointer and position it at
67 * the first token that is broken and emit an error about the failure.
68 * So only call _read_foo() when you know that you are reading a foo. _try_foo()
69 * however is fine to call if you don't know yet if the token is a foo or a bar,
70 * you can _try_bar() if try_foo() failed.
72 gboolean _gtk_css_parser_try (GtkCssParser *parser,
74 gboolean skip_whitespace);
75 char * _gtk_css_parser_try_ident (GtkCssParser *parser,
76 gboolean skip_whitespace);
77 char * _gtk_css_parser_try_name (GtkCssParser *parser,
78 gboolean skip_whitespace);
79 gboolean _gtk_css_parser_try_int (GtkCssParser *parser,
81 gboolean _gtk_css_parser_try_uint (GtkCssParser *parser,
83 gboolean _gtk_css_parser_try_double (GtkCssParser *parser,
85 gboolean _gtk_css_parser_try_length (GtkCssParser *parser,
87 gboolean _gtk_css_parser_try_enum (GtkCssParser *parser,
91 gboolean _gtk_css_parser_has_number (GtkCssParser *parser);
92 gboolean _gtk_css_parser_read_number (GtkCssParser *parser,
94 GtkCssNumberParseFlags flags);
95 char * _gtk_css_parser_read_string (GtkCssParser *parser);
96 char * _gtk_css_parser_read_value (GtkCssParser *parser);
97 GtkSymbolicColor *_gtk_css_parser_read_symbolic_color
98 (GtkCssParser *parser);
99 GFile * _gtk_css_parser_read_url (GtkCssParser *parser,
102 void _gtk_css_parser_skip_whitespace (GtkCssParser *parser);
103 void _gtk_css_parser_resync (GtkCssParser *parser,
104 gboolean sync_at_semicolon,
109 #endif /* __GTK_CSS_PARSER_PRIVATE_H__ */