From: Behdad Esfahbod Date: Thu, 12 Feb 2009 04:55:11 +0000 (-0500) Subject: [fcformat] Support 'default value' for simple tags X-Git-Tag: 2.7.0~85 X-Git-Url: https://git.wh0rd.org/?a=commitdiff_plain;h=0673ef3881d24820e627b9a8cd3a4b3e3889c545;p=fontconfig.git [fcformat] Support 'default value' for simple tags The format '%{family:-XXX} prints XٓٓٓٓXX if the element family is not defined. Also works for things like '%{family[1]:-XXX}'. --- diff --git a/src/fcformat.c b/src/fcformat.c index 898ee32..f91b6e0 100644 --- a/src/fcformat.c +++ b/src/fcformat.c @@ -33,14 +33,12 @@ * * - array enumeration using '%{[]family,familylang{expr}|decorator}' * - langset enumeration using same syntax as array enumeration - * - allow indexing simple tags using '%{elt[idx]}' * - allow indexing subexprs using '%{[idx]elt1,elt2{subexpr}}' * - conditional/filtering/deletion on binding (using '(w)'/'(s)'/'(=)' notation) */ -/* fc-match needs '', etc handling. */ -#define FCMATCH_FORMAT "%{file|basename}: \"%{family[0]}\" \"%{style[0]}\"" +#define FCMATCH_FORMAT "%{file:-|basename}: \"%{family[0]:-}\" \"%{style[0]:-}\"" #define FCLIST_FORMAT "%{?file{%{file}: }}%{=unparse}" @@ -247,7 +245,7 @@ interpret_builtin (FcFormatContext *c, else if (0 == strcmp ((const char *) c->word, name))\ do { new_str = func (pat); ret = FcTrue; } while (0) BUILTIN ("unparse", FcNameUnparse); - /* BUILTIN ("verbose", FcPatternPrint); */ + /* BUILTIN ("verbose", FcPatternPrint); XXX */ #undef BUILTIN else ret = FcFalse; @@ -543,6 +541,7 @@ interpret_simple (FcFormatContext *c, FcBool add_colon = FcFalse; FcBool add_elt_name = FcFalse; int idx; + FcChar8 *else_string; if (consume_char (c, ':')) add_colon = FcTrue; @@ -566,6 +565,25 @@ interpret_simple (FcFormatContext *c, if (consume_char (c, '=')) add_elt_name = FcTrue; + /* modifiers */ + else_string = NULL; + if (consume_char (c, ':')) + { + FcChar8 *orig; + /* divert the c->word for now */ + orig = c->word; + c->word = c->word + strlen ((const char *) c->word) + 1; + /* for now we just support 'default value' */ + if (!expect_char (c, '-') || + !read_chars (c, '\0')) + { + c->word = orig; + return FcFalse; + } + else_string = c->word; + c->word = orig; + } + e = FcPatternObjectFindElt (pat, FcObjectFromName ((const char *) c->word)); if (e) @@ -604,6 +622,8 @@ interpret_simple (FcFormatContext *c, else notfound: { + if (else_string) + printf ("%s", else_string); } return FcTrue; @@ -752,7 +772,7 @@ translate_chars (FcFormatContext *c, from_len = strlen (from); to = from + from_len + 1; - /* hack: we temporarily diverge c->word */ + /* hack: we temporarily divert c->word */ c->word = (FcChar8 *) to; if (!read_chars (c, ')')) {