diff options
author | Michael Zucci <zucchi@src.gnome.org> | 2000-02-14 10:00:22 +0800 |
---|---|---|
committer | Michael Zucci <zucchi@src.gnome.org> | 2000-02-14 10:00:22 +0800 |
commit | add8821e99b4ea1b574ed469018ae224a542e6ae (patch) | |
tree | 3e9e02c153fb7300707a26a132ee66c9177d2369 /libibex/lookup.c | |
parent | e4bbdf696cc2f23e9b1fc288d37a44eb27d9426d (diff) | |
download | gsoc2013-evolution-add8821e99b4ea1b574ed469018ae224a542e6ae.tar gsoc2013-evolution-add8821e99b4ea1b574ed469018ae224a542e6ae.tar.gz gsoc2013-evolution-add8821e99b4ea1b574ed469018ae224a542e6ae.tar.bz2 gsoc2013-evolution-add8821e99b4ea1b574ed469018ae224a542e6ae.tar.lz gsoc2013-evolution-add8821e99b4ea1b574ed469018ae224a542e6ae.tar.xz gsoc2013-evolution-add8821e99b4ea1b574ed469018ae224a542e6ae.tar.zst gsoc2013-evolution-add8821e99b4ea1b574ed469018ae224a542e6ae.zip |
Initial revision
svn path=/trunk/; revision=1768
Diffstat (limited to 'libibex/lookup.c')
-rw-r--r-- | libibex/lookup.c | 74 |
1 files changed, 74 insertions, 0 deletions
diff --git a/libibex/lookup.c b/libibex/lookup.c new file mode 100644 index 0000000000..d6bdec06a5 --- /dev/null +++ b/libibex/lookup.c @@ -0,0 +1,74 @@ +/* + Copyright 2000 Helix Code Inc. +*/ + +/* lookup.c: a simple client, part 2 */ + +#include <errno.h> +#include <stdio.h> +#include <string.h> +#include <unistd.h> + +#include "ibex.h" + +extern int optind; +extern char *optarg; + +static void +usage(void) +{ + fprintf(stderr, "Usage: lookup [-f indexfile] word ...\n"); + exit(1); +} + +int +main(int argc, char **argv) +{ + ibex *ib; + GPtrArray *ans, *words; + int opt, i; + char *file = "INDEX"; + + while ((opt = getopt(argc, argv, "f:")) != -1) + { + switch (opt) + { + case 'f': + file = optarg; + break; + + default: + usage(); + break; + } + } + argc -= optind; + argv += optind; + + if (argc == 0) + usage(); + + ib = ibex_open(file, FALSE); + if (!ib) + { + printf("Couldn't open %s: %s\n", file, strerror(errno)); + exit(1); + } + + words = g_ptr_array_new(); + while (argc--) + g_ptr_array_add(words, argv[argc]); + + ans = ibex_find_all(ib, words); + if (ans) + { + for (i = 0; i < ans->len; i++) + printf("%s\n", (char *)g_ptr_array_index(ans, i)); + exit(0); + } + else + { + printf("Nope.\n"); + exit(1); + } +} |