From: Behdad Esfahbod Date: Tue, 10 Feb 2009 11:22:55 +0000 (-0500) Subject: [fcformat] Start adding builtins X-Git-Tag: 2.7.0~89 X-Git-Url: https://git.wh0rd.org/?a=commitdiff_plain;h=d4f7a4c6af5420afbbcf2217f9fe396623671294;p=fontconfig.git [fcformat] Start adding builtins --- diff --git a/src/fcformat.c b/src/fcformat.c index 971ee08..1d67a9d 100644 --- a/src/fcformat.c +++ b/src/fcformat.c @@ -33,7 +33,7 @@ * * - allow indexing subexprs using '%{[idx]elt1,elt2{subexpr}}' * - allow indexing simple tags using '%{elt[idx]}' - * - conditional/filtering/deletion on binding (using '(w)'/'(s)' notation) + * - conditional/filtering/deletion on binding (using '(w)'/'(s)'/'(=)' notation) */ static void @@ -203,6 +203,30 @@ read_chars (FcFormatContext *c, return FcTrue; } +static FcBool +interpret_builtin (FcFormatContext *c, + FcPattern *pat, + FcStrBuf *buf) +{ + if (!expect_char (c, '=')) + return FcFalse; + + if (!read_word (c)) + return FcFalse; +#define BUILTIN(name, func) \ + else if (0 == strcmp ((const char *) c->word, name))\ + return func (c, pat, buf) + BUILTIN ("unparse", FcNameUnparse); + BUILTIN ("verbose", FcPatternPrint); + BUILTIN2 ("fcmatch", FcStrDirname); + BUILTIN2 ("fclist", FcStrDirname); + BUILTIN2 ("pkgkit", FcStrDirname); + + message ("unknown builtin \"%s\"", + c->word); + return FcFalse; +} + static FcBool interpret_expr (FcFormatContext *c, FcPattern *pat, @@ -805,6 +829,7 @@ interpret_percent (FcFormatContext *c, start = buf->len; switch (*c->format) { + case '=': ret = interpret_builtin (c, pat, buf); break; case '{': ret = interpret_subexpr (c, pat, buf); break; case '+': ret = interpret_filter (c, pat, buf); break; case '-': ret = interpret_delete (c, pat, buf); break;