diff options
| -rw-r--r-- | src/tabfile.c | 19 | 
1 files changed, 15 insertions, 4 deletions
| diff --git a/src/tabfile.c b/src/tabfile.c index b2ceefa..053748c 100644 --- a/src/tabfile.c +++ b/src/tabfile.c @@ -24,6 +24,7 @@  #include <glib.h>  #include <gio/gio.h> +#include <pango/pango.h>  #include <unicode/ucol.h> @@ -93,6 +94,11 @@ import_line (Generator *generator, gchar *line, gsize len, GError **error)  	 || !inplace_unescape (separator, error))  		return FALSE; +	if (generator->info->same_type_sequence +	 && *generator->info->same_type_sequence == STARDICT_FIELD_PANGO +	 && !pango_parse_markup (separator, -1, 0, NULL, NULL, NULL, error)) +		return FALSE; +  	generator_begin_entry (generator);  	return generator_write_string (generator, separator, TRUE, error)  		&& generator_finish_entry (generator, line, error); @@ -145,12 +151,13 @@ main (int argc, char *argv[])  	g_option_context_set_summary (ctx,  		"Create a StarDict dictionary from plaintext."); -	StardictInfo template = -	{ -		.same_type_sequence = "m", -	}; +	gboolean pango_markup = FALSE; +	StardictInfo template = {};  	GOptionEntry entries[] =  	{ +		{ "pango",       'p', 0, G_OPTION_ARG_NONE,   &pango_markup, +		  "Entries use Pango markup", NULL }, +  		{ "book-name",   'b', 0, G_OPTION_ARG_STRING, &template.book_name,  		  "Set the book name field", "TEXT" },  		{ "author",      'a', 0, G_OPTION_ARG_STRING, &template.author, @@ -175,6 +182,10 @@ main (int argc, char *argv[])  		fatal ("%s", g_option_context_get_help (ctx, TRUE, FALSE));  	g_option_context_free (ctx); +	template.same_type_sequence = pango_markup +		? (char[]) { STARDICT_FIELD_PANGO, 0 } +		: (char[]) { STARDICT_FIELD_MEANING, 0 }; +  	if (!template.book_name)  		template.book_name = argv[1];  	if (template.description) | 
