aboutsummaryrefslogtreecommitdiffstats
path: root/get-contact-organisations.c
diff options
context:
space:
mode:
authorMattias Andrée <maandree@kth.se>2021-04-12 13:37:59 +0200
committerMattias Andrée <maandree@kth.se>2021-04-12 13:37:59 +0200
commitfa88a28e46b7ac2d3dcd1938e5e4708157d08b22 (patch)
treec3ca4f98374328f37d71d1079f9e1f7406ed84d8 /get-contact-organisations.c
parentMinor fix to set-contact-photos (diff)
downloadcontacts-fa88a28e46b7ac2d3dcd1938e5e4708157d08b22.tar.gz
contacts-fa88a28e46b7ac2d3dcd1938e5e4708157d08b22.tar.bz2
contacts-fa88a28e46b7ac2d3dcd1938e5e4708157d08b22.tar.xz
Deduplicate code and make some small improvements
Signed-off-by: Mattias Andrée <maandree@kth.se>
Diffstat (limited to '')
-rw-r--r--get-contact-organisations.c91
1 files changed, 6 insertions, 85 deletions
diff --git a/get-contact-organisations.c b/get-contact-organisations.c
index 92be776..dc5228e 100644
--- a/get-contact-organisations.c
+++ b/get-contact-organisations.c
@@ -1,88 +1,9 @@
/* See LICENSE file for copyright and license details. */
-#include "common.h"
-
-USAGE("[-o organisation] [-t title] [-OT] contact-id ...");
-
-
-int
-main(int argc, char *argv[])
-{
- int display_org = 0, display_title = 0;
- const char *lookup_org = NULL, *lookup_title = NULL;
- struct passwd *user;
- struct libcontacts_contact contact;
- struct libcontacts_organisation **orgs, *org;
- int ret = 0;
- size_t i;
-
- ARGBEGIN {
- case 'o':
- if (lookup_org)
- usage();
- lookup_org = ARG();
- break;
- case 't':
- if (lookup_title)
- usage();
- lookup_title = ARG();
- break;
- case 'O':
- display_org = 1;
- break;
- case 'T':
- display_title = 1;
- break;
- default:
- usage();
- } ARGEND;
+#define CATEGORY organisations
- if (!argc)
- usage();
+#define LIST_PARAMS(X)\
+ X('O', "O", 'o', "o", organisation, "organisation")\
+ X('T', "T", 't', "t", title, "title")
- if (lookup_org && !lookup_title && !display_org && !display_title)
- display_title = 1;
- if (lookup_title && !lookup_org && !display_org && !display_title)
- display_org = 1;
-
- 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 ((orgs = contact.organisations)) {
- for (; (org = *orgs); orgs++) {
- if (lookup_org && strcmpnul(org->organisation, lookup_org))
- continue;
- if (lookup_title && strcmpnul(org->title, lookup_title))
- continue;
- if (lookup_org && lookup_title && !display_org && !display_title) {
- printf("%s\n", *argv);
- continue;
- }
- if (argc > 1)
- printf("%s: ", *argv);
- if (!display_org == !display_title)
- printf("%s: %s\n", org->organisation, org->title);
- else if (display_title)
- printf("%s\n", org->title);
- else
- printf("%s\n", org->organisation);
- }
- }
- libcontacts_contact_destroy(&contact);
- }
-
- if (fflush(stdout) || ferror(stdout) || fclose(stdout))
- eprintf("printf:");
- return ret;
-}
+#include "common.h"
+IMPLEMENT_GET_ON_LIST(organisation)