cssparser: Get rid of _gtk_css_parser_try_double()

Use gtk_css_parser_consume_number() everywhere instead.
This commit is contained in:
Benjamin Otte 2019-04-05 02:16:00 +02:00
parent f0d2f99239
commit 23080d47b5
4 changed files with 21 additions and 38 deletions

View File

@ -548,11 +548,9 @@ _gtk_css_color_value_parse_function (GtkCssParser *parser,
return NULL; return NULL;
} }
if (!_gtk_css_parser_try_double (parser, &tmp)) if (!gtk_css_parser_consume_number (parser, &tmp))
{
_gtk_css_parser_error (parser, "Invalid number for color value");
return NULL; return NULL;
}
if (_gtk_css_parser_try (parser, "%", TRUE)) if (_gtk_css_parser_try (parser, "%", TRUE))
tmp /= 100.0; tmp /= 100.0;
else else
@ -575,12 +573,9 @@ _gtk_css_color_value_parse_function (GtkCssParser *parser,
return NULL; return NULL;
} }
if (!_gtk_css_parser_try_double (parser, &rgba.alpha)) if (!gtk_css_parser_consume_number (parser, &rgba.alpha))
{
_gtk_css_parser_error (parser, "Invalid number for alpha value");
return NULL; return NULL;
} }
}
else else
rgba.alpha = 1.0; rgba.alpha = 1.0;
@ -626,9 +621,8 @@ _gtk_css_color_value_parse_function (GtkCssParser *parser,
return NULL; return NULL;
} }
if (!_gtk_css_parser_try_double (parser, &d)) if (!gtk_css_parser_consume_number (parser, &d))
{ {
_gtk_css_parser_error (parser, "Expected number in color definition");
_gtk_css_value_unref (child1); _gtk_css_value_unref (child1);
if (child2) if (child2)
_gtk_css_value_unref (child2); _gtk_css_value_unref (child2);

View File

@ -339,7 +339,7 @@ _gtk_css_keyframes_parse (GtkCssParser *parser)
progress = 0; progress = 0;
else if (gtk_css_parser_try_ident (parser, "to")) else if (gtk_css_parser_try_ident (parser, "to"))
progress = 1; progress = 1;
else if (_gtk_css_parser_try_double (parser, &progress) && else if (gtk_css_parser_consume_number (parser, &progress) &&
_gtk_css_parser_try (parser, "%", TRUE)) _gtk_css_parser_try (parser, "%", TRUE))
{ {
if (progress < 0 || progress > 100) if (progress < 0 || progress > 100)

View File

@ -775,26 +775,28 @@ _gtk_css_parser_try_int (GtkCssParser *parser,
} }
gboolean gboolean
_gtk_css_parser_try_double (GtkCssParser *parser, gtk_css_parser_consume_number (GtkCssParser *self,
gdouble *value) double *number)
{ {
gdouble result; gdouble result;
char *end; char *end;
g_return_val_if_fail (GTK_IS_CSS_PARSER (parser), FALSE); g_return_val_if_fail (GTK_IS_CSS_PARSER (self), FALSE);
g_return_val_if_fail (value != NULL, FALSE); g_return_val_if_fail (number != NULL, FALSE);
errno = 0; errno = 0;
result = g_ascii_strtod (parser->data, &end); result = g_ascii_strtod (self->data, &end);
if (errno) if (errno ||
return FALSE; self->data == end)
if (parser->data == end) {
_gtk_css_parser_error (self, "Expected a number");
return FALSE; return FALSE;
}
parser->data = end; self->data = end;
*value = result; *number = result;
_gtk_css_parser_skip_whitespace (parser); _gtk_css_parser_skip_whitespace (self);
return TRUE; return TRUE;
} }
@ -811,17 +813,6 @@ gtk_css_parser_consume_ident (GtkCssParser *self)
return result; return result;
} }
gboolean
gtk_css_parser_consume_number (GtkCssParser *self,
double *number)
{
if (_gtk_css_parser_try_double (self, number))
return TRUE;
_gtk_css_parser_error (self, "Expected a number");
return FALSE;
}
gboolean gboolean
_gtk_css_parser_has_number (GtkCssParser *parser) _gtk_css_parser_has_number (GtkCssParser *parser)
{ {

View File

@ -92,8 +92,6 @@ char * _gtk_css_parser_try_name (GtkCssParser *parser
gboolean skip_whitespace); gboolean skip_whitespace);
gboolean _gtk_css_parser_try_int (GtkCssParser *parser, gboolean _gtk_css_parser_try_int (GtkCssParser *parser,
int *value); int *value);
gboolean _gtk_css_parser_try_double (GtkCssParser *parser,
gdouble *value);
gboolean _gtk_css_parser_try_hash_color (GtkCssParser *parser, gboolean _gtk_css_parser_try_hash_color (GtkCssParser *parser,
GdkRGBA *rgba); GdkRGBA *rgba);