diff options
author | Behdad Esfahbod <behdad@behdad.org> | 2008-12-29 20:00:26 -0500 |
---|---|---|
committer | Behdad Esfahbod <behdad@behdad.org> | 2009-02-13 16:54:04 -0800 |
commit | 0c93b91db0cdf7c5e901477c266b45c8baeadd00 (patch) | |
tree | fd3df21df4f20d88a9af8426533fcb0ed542541a /fc-list | |
parent | 5cf04b201fb5e9dc989d30cf5c30f7575dda56bc (diff) |
Implement FcPatternFormat and use it in cmdline tools (bug #17107)
Still need to add more features, but the API is there, and used
by cmdline tools with -f or --format.
Diffstat (limited to 'fc-list')
-rw-r--r-- | fc-list/fc-list.c | 38 | ||||
-rw-r--r-- | fc-list/fc-list.sgml | 22 |
2 files changed, 47 insertions, 13 deletions
diff --git a/fc-list/fc-list.c b/fc-list/fc-list.c index 89f4167b..f7a66b59 100644 --- a/fc-list/fc-list.c +++ b/fc-list/fc-list.c @@ -26,6 +26,7 @@ #include <stdio.h> #include <unistd.h> #include <stdlib.h> +#include <string.h> #ifdef HAVE_CONFIG_H #include <config.h> #else @@ -47,9 +48,10 @@ #define _GNU_SOURCE #include <getopt.h> const struct option longopts[] = { - {"version", 0, 0, 'V'}, {"verbose", 0, 0, 'v'}, + {"format", 1, 0, 'f'}, {"quiet", 0, 0, 'q'}, + {"version", 0, 0, 'V'}, {"help", 0, 0, 'h'}, {NULL,0,0,0}, }; @@ -65,21 +67,23 @@ usage (char *program, int error) { FILE *file = error ? stderr : stdout; #if HAVE_GETOPT_LONG - fprintf (file, "usage: %s [-vqVh] [--verbose] [--quiet] [--version] [--help] [pattern] {element ...} \n", + fprintf (file, "usage: %s [-vqVh] [-f FORMAT] [--verbose] [--format=FORMAT] [--quiet] [--version] [--help] [pattern] {element ...} \n", program); #else - fprintf (file, "usage: %s [-vqVh] [pattern] {element ...} \n", + fprintf (file, "usage: %s [-vqVh] [-f FORMAT] [pattern] {element ...} \n", program); #endif fprintf (file, "List fonts matching [pattern]\n"); fprintf (file, "\n"); #if HAVE_GETOPT_LONG fprintf (file, " -v, --verbose display entire font pattern\n"); + fprintf (file, " -f, --format=FORMAT use the given output format\n"); fprintf (file, " -q, --quiet suppress all normal output, exit 1 if no fonts matched\n"); fprintf (file, " -V, --version display font config version and exit\n"); fprintf (file, " -h, --help display this help and exit\n"); #else fprintf (file, " -v (verbose) display entire font pattern\n"); + fprintf (file, " -f FORMAT (format) use the given output format\n"); fprintf (file, " -q, (quiet) suppress all normal output, exit 1 if no fonts matched\n"); fprintf (file, " -V (version) display font config version and exit\n"); fprintf (file, " -h (help) display this help and exit\n"); @@ -92,6 +96,7 @@ main (int argc, char **argv) { int verbose = 0; int quiet = 0; + FcChar8 *format = NULL; int nfont = 0; int i; FcObjectSet *os = 0; @@ -101,22 +106,25 @@ main (int argc, char **argv) int c; #if HAVE_GETOPT_LONG - while ((c = getopt_long (argc, argv, "Vqvh", longopts, NULL)) != -1) + while ((c = getopt_long (argc, argv, "vf:qVh", longopts, NULL)) != -1) #else - while ((c = getopt (argc, argv, "Vqvh")) != -1) + while ((c = getopt (argc, argv, "vf:qVh")) != -1) #endif { switch (c) { - case 'V': - fprintf (stderr, "fontconfig version %d.%d.%d\n", - FC_MAJOR, FC_MINOR, FC_REVISION); - exit (0); case 'v': verbose = 1; break; + case 'f': + format = (FcChar8 *) strdup (optarg); + break; case 'q': quiet = 1; break; + case 'V': + fprintf (stderr, "fontconfig version %d.%d.%d\n", + FC_MAJOR, FC_MINOR, FC_REVISION); + exit (0); case 'h': usage (argv[0], 0); default: @@ -148,7 +156,7 @@ main (int argc, char **argv) pat = FcPatternCreate (); if (quiet && !os) os = FcObjectSetCreate (); - if (!verbose && !os) + if (!verbose && !format && !os) os = FcObjectSetBuild (FC_FAMILY, FC_STYLE, (char *) 0); fs = FcFontList (0, pat, os); if (os) @@ -166,7 +174,17 @@ main (int argc, char **argv) FcChar8 *file; if (verbose) + { FcPatternPrint (fs->fonts[j]); + } + else if (format) + { + FcChar8 *s; + + s = FcPatternFormat (fs->fonts[j], format); + printf ("%s", s); + free (s); + } else { font = FcNameUnparse (fs->fonts[j]); diff --git a/fc-list/fc-list.sgml b/fc-list/fc-list.sgml index 35bf899d..5807ed1a 100644 --- a/fc-list/fc-list.sgml +++ b/fc-list/fc-list.sgml @@ -65,6 +65,10 @@ manpage.1: manpage.sgml <arg><option>-vVh</option></arg> <arg><option>--verbose</option></arg> + <group> + <arg><option>-f</option> <option><replaceable>format</replaceable></option></arg> + <arg><option>--format</option> <option><replaceable>format</replaceable></option></arg> + </group> <arg><option>--version</option></arg> <arg><option>--help</option></arg> <sbr> @@ -100,11 +104,13 @@ manpage.1: manpage.sgml </listitem> </varlistentry> <varlistentry> - <term><option>-h</option> - <option>--help</option> + <term><option>-f</option> + <option>--format</option> + <option><replaceable>format</replaceable></option> </term> <listitem> - <para>Show summary of options.</para> + <para>Format output according to the format specifier + <replaceable>format</replaceable>.</para> </listitem> </varlistentry> <varlistentry> @@ -116,6 +122,14 @@ manpage.1: manpage.sgml </listitem> </varlistentry> <varlistentry> + <term><option>-h</option> + <option>--help</option> + </term> + <listitem> + <para>Show summary of options.</para> + </listitem> + </varlistentry> + <varlistentry> <term><option><replaceable>pattern</replaceable></option> </term> <listitem> @@ -164,6 +178,8 @@ manpage.1: manpage.sgml <command>fc-cache</command>(1) <command>fc-match</command>(1) <command>fc-query</command>(1) + <function>FcFontList</function>(3) + <function>FcPatternFormat</function>(3) </para> <para>The fontconfig user's guide, in HTML format: |