From 6853c2b8806443ad80bdb99200502d9975398780 Mon Sep 17 00:00:00 2001 From: Matthias Clasen Date: Tue, 7 May 2002 21:45:21 +0000 Subject: [PATCH] Report unfinished entity references as errors rather than running into an * glib/gmarkup.c (unescape_text): Report unfinished entity references as errors rather than running into an assert. (#80441) --- ChangeLog | 5 +++++ ChangeLog.pre-2-10 | 5 +++++ ChangeLog.pre-2-12 | 5 +++++ ChangeLog.pre-2-2 | 5 +++++ ChangeLog.pre-2-4 | 5 +++++ ChangeLog.pre-2-6 | 5 +++++ ChangeLog.pre-2-8 | 5 +++++ glib/gmarkup.c | 24 +++++++++++++++++++++--- 8 files changed, 56 insertions(+), 3 deletions(-) diff --git a/ChangeLog b/ChangeLog index e5008355a..b8afb0c0c 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +2002-05-07 Matthias Clasen + + * glib/gmarkup.c (unescape_text): Report unfinished entity + references as errors rather than running into an assert. (#80441) + 2002-05-07 Michael Natterer * configure.in: added a new conditional CROSS_COMPILING which diff --git a/ChangeLog.pre-2-10 b/ChangeLog.pre-2-10 index e5008355a..b8afb0c0c 100644 --- a/ChangeLog.pre-2-10 +++ b/ChangeLog.pre-2-10 @@ -1,3 +1,8 @@ +2002-05-07 Matthias Clasen + + * glib/gmarkup.c (unescape_text): Report unfinished entity + references as errors rather than running into an assert. (#80441) + 2002-05-07 Michael Natterer * configure.in: added a new conditional CROSS_COMPILING which diff --git a/ChangeLog.pre-2-12 b/ChangeLog.pre-2-12 index e5008355a..b8afb0c0c 100644 --- a/ChangeLog.pre-2-12 +++ b/ChangeLog.pre-2-12 @@ -1,3 +1,8 @@ +2002-05-07 Matthias Clasen + + * glib/gmarkup.c (unescape_text): Report unfinished entity + references as errors rather than running into an assert. (#80441) + 2002-05-07 Michael Natterer * configure.in: added a new conditional CROSS_COMPILING which diff --git a/ChangeLog.pre-2-2 b/ChangeLog.pre-2-2 index e5008355a..b8afb0c0c 100644 --- a/ChangeLog.pre-2-2 +++ b/ChangeLog.pre-2-2 @@ -1,3 +1,8 @@ +2002-05-07 Matthias Clasen + + * glib/gmarkup.c (unescape_text): Report unfinished entity + references as errors rather than running into an assert. (#80441) + 2002-05-07 Michael Natterer * configure.in: added a new conditional CROSS_COMPILING which diff --git a/ChangeLog.pre-2-4 b/ChangeLog.pre-2-4 index e5008355a..b8afb0c0c 100644 --- a/ChangeLog.pre-2-4 +++ b/ChangeLog.pre-2-4 @@ -1,3 +1,8 @@ +2002-05-07 Matthias Clasen + + * glib/gmarkup.c (unescape_text): Report unfinished entity + references as errors rather than running into an assert. (#80441) + 2002-05-07 Michael Natterer * configure.in: added a new conditional CROSS_COMPILING which diff --git a/ChangeLog.pre-2-6 b/ChangeLog.pre-2-6 index e5008355a..b8afb0c0c 100644 --- a/ChangeLog.pre-2-6 +++ b/ChangeLog.pre-2-6 @@ -1,3 +1,8 @@ +2002-05-07 Matthias Clasen + + * glib/gmarkup.c (unescape_text): Report unfinished entity + references as errors rather than running into an assert. (#80441) + 2002-05-07 Michael Natterer * configure.in: added a new conditional CROSS_COMPILING which diff --git a/ChangeLog.pre-2-8 b/ChangeLog.pre-2-8 index e5008355a..b8afb0c0c 100644 --- a/ChangeLog.pre-2-8 +++ b/ChangeLog.pre-2-8 @@ -1,3 +1,8 @@ +2002-05-07 Matthias Clasen + + * glib/gmarkup.c (unescape_text): Report unfinished entity + references as errors rather than running into an assert. (#80441) + 2002-05-07 Michael Natterer * configure.in: added a new conditional CROSS_COMPILING which diff --git a/glib/gmarkup.c b/glib/gmarkup.c index 39ff57bee..8f5c6b861 100644 --- a/glib/gmarkup.c +++ b/glib/gmarkup.c @@ -592,9 +592,27 @@ unescape_text (GMarkupParseContext *context, } } - /* If no errors, we should have returned to USTATE_INSIDE_TEXT */ - g_assert (context->state == STATE_ERROR || - state == USTATE_INSIDE_TEXT); + if (context->state != STATE_ERROR) + { + switch (state) + { + case USTATE_INSIDE_TEXT: + break; + case USTATE_AFTER_AMPERSAND: + case USTATE_INSIDE_ENTITY_NAME: + set_unescape_error (context, error, + NULL, NULL, + G_MARKUP_ERROR_PARSE, + _("Unfinished entity reference")); + break; + case USTATE_AFTER_CHARREF_HASH: + set_unescape_error (context, error, + NULL, NULL, + G_MARKUP_ERROR_PARSE, + _("Unfinished character reference")); + break; + } + } if (context->state == STATE_ERROR) {