From efa7ac2eef94614ed6e8481b57b00cf25239581b Mon Sep 17 00:00:00 2001 From: Mattias Andrée Date: Sun, 4 Apr 2021 03:31:26 +0200 Subject: misc MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Mattias Andrée --- get-contact-numbers.c | 91 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 91 insertions(+) create mode 100644 get-contact-numbers.c (limited to 'get-contact-numbers.c') diff --git a/get-contact-numbers.c b/get-contact-numbers.c new file mode 100644 index 0000000..0d9c02b --- /dev/null +++ b/get-contact-numbers.c @@ -0,0 +1,91 @@ +/* See LICENSE file for copyright and license details. */ +#include "common.h" + +USAGE("[-c context] [-F | -f] [-M | -m] contact-id ..."); + + +int +main(int argc, char *argv[]) +{ + int require_mobile = -1, require_fax = -1; + struct passwd *user; + struct libcontacts_contact contact; + struct libcontacts_number **numbers, *number; + const char *lookup_ctx = NULL; + int ret = 0; + size_t i; + + ARGBEGIN { + case 'c': + if (lookup_ctx) + usage(); + lookup_ctx = ARG(); + break; + case 'F': + if (require_fax >= 0) + usage(); + require_fax = 0; + break; + case 'f': + if (require_fax >= 0) + usage(); + require_fax = 1; + break; + case 'M': + if (require_mobile >= 0) + usage(); + require_mobile = 0; + break; + case 'm': + if (require_mobile >= 0) + usage(); + require_mobile = 1; + break; + default: + usage(); + } ARGEND; + + if (!argc) + usage(); + + for (i = 0; argv[i]; i++) + if (!*argv[i] || strchr(argv[i], '/')) + usage(); + + errno = 0; + user = getpwuid(getuid()); + if (!user) + eprintf("getpwuid: %s\n", errno ? strerror(errno) : "user does not exist"); + + for (; *argv; argv++) { + if (libcontacts_load_contact(*argv, &contact, user)) { + weprintf("libcontacts_load_contact %s: %s\n", *argv, errno ? strerror(errno) : "contact file is malformatted"); + ret = 1; + continue; + } + if ((numbers = contact.numbers)) { + for (; (number = *numbers); numbers++) { + if (!number->number) + continue; + if (require_mobile >= 0 && number->is_mobile != require_mobile) + continue; + if (require_fax >= 0 && number->is_facsimile != require_fax) + continue; + if (lookup_ctx && strcmpnul(number->context, lookup_ctx)) + continue; + if (argc > 1) + printf("%s: ", *argv); + printf("%c%c", "-m"[number->is_mobile], "-f"[number->is_facsimile]); + if (!lookup_ctx) + printf(" %s (%s)\n", number->number, number->context); + else + printf(" %s\n", number->number); + } + } + libcontacts_contact_destroy(&contact); + } + + if (fflush(stdout) || ferror(stdout) || fclose(stdout)) + eprintf("printf:"); + return ret; +} -- cgit v1.2.3-70-g09d2