[util] Add --unicodes-before/after
Parallel to --unicodes for --text-before/after. To be used in tests.
This commit is contained in:
parent
65c622c689
commit
6ca0ffd42e
|
@ -119,31 +119,14 @@ parse_text (const char *name G_GNUC_UNUSED,
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static bool
|
||||||
parse_unicodes (const char *name G_GNUC_UNUSED,
|
encode_unicodes (const char *unicodes,
|
||||||
const char *arg,
|
GString *gs,
|
||||||
gpointer data,
|
GError **error)
|
||||||
GError **error G_GNUC_UNUSED)
|
|
||||||
{
|
|
||||||
text_options_t *text_opts = (text_options_t *) data;
|
|
||||||
|
|
||||||
if (text_opts->text)
|
|
||||||
{
|
|
||||||
g_set_error (error, G_OPTION_ERROR, G_OPTION_ERROR_BAD_VALUE,
|
|
||||||
"Either --text or --unicodes can be provided but not both");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
GString *gs = g_string_new (nullptr);
|
|
||||||
if (0 == strcmp (arg, "*"))
|
|
||||||
{
|
|
||||||
g_string_append_c (gs, '*');
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
#define DELIMITERS "<+->{},;&#\\xXuUnNiI\n\t\v\f\r "
|
#define DELIMITERS "<+->{},;&#\\xXuUnNiI\n\t\v\f\r "
|
||||||
|
|
||||||
char *s = (char *) arg;
|
char *s = (char *) unicodes;
|
||||||
char *p;
|
char *p;
|
||||||
|
|
||||||
while (s && *s)
|
while (s && *s)
|
||||||
|
@ -167,13 +150,124 @@ parse_unicodes (const char *name G_GNUC_UNUSED,
|
||||||
|
|
||||||
s = p;
|
s = p;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#undef DELIMITERS
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
parse_unicodes (const char *name G_GNUC_UNUSED,
|
||||||
|
const char *arg,
|
||||||
|
gpointer data,
|
||||||
|
GError **error G_GNUC_UNUSED)
|
||||||
|
{
|
||||||
|
text_options_t *text_opts = (text_options_t *) data;
|
||||||
|
|
||||||
|
if (text_opts->text)
|
||||||
|
{
|
||||||
|
g_set_error (error, G_OPTION_ERROR, G_OPTION_ERROR_BAD_VALUE,
|
||||||
|
"Either --text or --unicodes can be provided but not both");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
GString *gs = g_string_new (nullptr);
|
||||||
|
if (0 == strcmp (arg, "*"))
|
||||||
|
g_string_append_c (gs, '*');
|
||||||
|
else
|
||||||
|
if (!encode_unicodes (arg, gs, error))
|
||||||
|
return false;
|
||||||
|
|
||||||
text_opts->text_len = gs->len;
|
text_opts->text_len = gs->len;
|
||||||
text_opts->text = g_string_free (gs, FALSE);
|
text_opts->text = g_string_free (gs, FALSE);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
parse_text_before (const char *name G_GNUC_UNUSED,
|
||||||
|
const char *arg,
|
||||||
|
gpointer data,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
auto *opts = (shape_text_options_t *) data;
|
||||||
|
|
||||||
|
if (opts->text_before)
|
||||||
|
{
|
||||||
|
g_set_error (error, G_OPTION_ERROR, G_OPTION_ERROR_BAD_VALUE,
|
||||||
|
"Either --text-before or --unicodes-before can be provided but not both");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
opts->text_before = g_strdup (arg);
|
||||||
|
fprintf(stderr, "%s\n", opts->text_before);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
parse_unicodes_before (const char *name G_GNUC_UNUSED,
|
||||||
|
const char *arg,
|
||||||
|
gpointer data,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
auto *opts = (shape_text_options_t *) data;
|
||||||
|
|
||||||
|
if (opts->text_before)
|
||||||
|
{
|
||||||
|
g_set_error (error, G_OPTION_ERROR, G_OPTION_ERROR_BAD_VALUE,
|
||||||
|
"Either --text-before or --unicodes-before can be provided but not both");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
GString *gs = g_string_new (nullptr);
|
||||||
|
if (!encode_unicodes (arg, gs, error))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
opts->text_before = g_string_free (gs, FALSE);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
parse_text_after (const char *name G_GNUC_UNUSED,
|
||||||
|
const char *arg,
|
||||||
|
gpointer data,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
auto *opts = (shape_text_options_t *) data;
|
||||||
|
|
||||||
|
if (opts->text_after)
|
||||||
|
{
|
||||||
|
g_set_error (error, G_OPTION_ERROR, G_OPTION_ERROR_BAD_VALUE,
|
||||||
|
"Either --text-after or --unicodes-after can be provided but not both");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
opts->text_after = g_strdup (arg);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
parse_unicodes_after (const char *name G_GNUC_UNUSED,
|
||||||
|
const char *arg,
|
||||||
|
gpointer data,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
auto *opts = (shape_text_options_t *) data;
|
||||||
|
|
||||||
|
if (opts->text_after)
|
||||||
|
{
|
||||||
|
g_set_error (error, G_OPTION_ERROR, G_OPTION_ERROR_BAD_VALUE,
|
||||||
|
"Either --text-after or --unicodes-after can be provided but not both");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
GString *gs = g_string_new (nullptr);
|
||||||
|
if (!encode_unicodes (arg, gs, error))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
opts->text_after = g_string_free (gs, FALSE);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
const char *
|
const char *
|
||||||
text_options_t::get_line (unsigned int *len)
|
text_options_t::get_line (unsigned int *len)
|
||||||
{
|
{
|
||||||
|
@ -236,8 +330,10 @@ shape_text_options_t::add_options (option_parser_t *parser)
|
||||||
|
|
||||||
GOptionEntry entries[] =
|
GOptionEntry entries[] =
|
||||||
{
|
{
|
||||||
{"text-before", 0, 0, G_OPTION_ARG_STRING, &this->text_before, "Set text context before each line", "string"},
|
{"text-before", 0, 0, G_OPTION_ARG_CALLBACK, (gpointer) &parse_text_before, "Set text context before each line", "string"},
|
||||||
{"text-after", 0, 0, G_OPTION_ARG_STRING, &this->text_after, "Set text context after each line", "string"},
|
{"text-after", 0, 0, G_OPTION_ARG_CALLBACK, (gpointer) &parse_text_after, "Set text context after each line", "string"},
|
||||||
|
{"unicodes-before", 0, 0, G_OPTION_ARG_CALLBACK, (gpointer) &parse_unicodes_before, "Set Unicode codepoints context before each line", "list of hex numbers"},
|
||||||
|
{"unicodes-after", 0, 0, G_OPTION_ARG_CALLBACK, (gpointer) &parse_unicodes_after, "Set Unicode codepoints context after each line", "list of hex numbers"},
|
||||||
{nullptr}
|
{nullptr}
|
||||||
};
|
};
|
||||||
parser->add_group (entries,
|
parser->add_group (entries,
|
||||||
|
|
Loading…
Reference in New Issue