summaryrefslogtreecommitdiff
path: root/fc-list
diff options
context:
space:
mode:
authorBehdad Esfahbod <behdad@behdad.org>2008-12-29 20:00:26 -0500
committerBehdad Esfahbod <behdad@behdad.org>2009-02-13 16:54:04 -0800
commit0c93b91db0cdf7c5e901477c266b45c8baeadd00 (patch)
treefd3df21df4f20d88a9af8426533fcb0ed542541a /fc-list
parent5cf04b201fb5e9dc989d30cf5c30f7575dda56bc (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.c38
-rw-r--r--fc-list/fc-list.sgml22
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: