Fix regression in g_shell_parse_argv()

The commit in 6e4acf44b3 broke
the fallthrough case for '\\' when it changed the '#' case.

This caused issues like this:
  https://bugzilla.gnome.org/show_bug.cgi?id=683821

https://bugzilla.gnome.org/show_bug.cgi?id=562907
This commit is contained in:
Alexander Larsson 2012-09-13 10:13:04 +02:00
parent d6b9df6949
commit c99acf51d0
2 changed files with 6 additions and 5 deletions

View File

@ -518,7 +518,10 @@ tokenize_command_line (const gchar *command_line,
g_string_append_c (current_token, *p);
/* FALL THRU */
case '\\':
current_quote = *p;
break;
case '#':
if (p == command_line)
{ /* '#' was the first char */
@ -538,9 +541,6 @@ tokenize_command_line (const gchar *command_line,
break;
}
break;
case '\\':
current_quote = *p;
break;
default:
/* Combines rules 4) and 6) - if we have a token, append to it,

View File

@ -66,7 +66,8 @@ static CmdlineTest cmdline_tests[] =
{ "foo '\"bar\" baz", 0, { NULL }, G_SHELL_ERROR_BAD_QUOTING },
{ "", 0, { NULL }, G_SHELL_ERROR_EMPTY_STRING },
{ " ", 0, { NULL }, G_SHELL_ERROR_EMPTY_STRING },
{ "# foo bar", 0, { NULL }, G_SHELL_ERROR_EMPTY_STRING }
{ "# foo bar", 0, { NULL }, G_SHELL_ERROR_EMPTY_STRING },
{"foo '/bar/summer'\\''09 tours.pdf'", 2, {"foo", "/bar/summer'09 tours.pdf", NULL}, -1}
};
static gboolean