aboutsummaryrefslogtreecommitdiffstats
path: root/get-contact-chats.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-chats.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-chats.c109
1 files changed, 7 insertions, 102 deletions
diff --git a/get-contact-chats.c b/get-contact-chats.c
index 5e790d7..fecb152 100644
--- a/get-contact-chats.c
+++ b/get-contact-chats.c
@@ -1,105 +1,10 @@
/* See LICENSE file for copyright and license details. */
-#include "common.h"
-
-USAGE("[-a address] [-c context] [-s service] [-ACS] contact-id ...");
-
-
-int
-main(int argc, char *argv[])
-{
- int display_ctx = 0, display_addr = 0, display_srv = 0;
- const char *lookup_ctx = NULL, *lookup_addr = NULL, *lookup_srv = NULL;
- struct passwd *user;
- struct libcontacts_contact contact;
- struct libcontacts_chat **chats, *chat;
- int ret = 0;
- size_t i;
-
- ARGBEGIN {
- case 'a':
- if (lookup_addr)
- usage();
- lookup_addr = ARG();
- break;
- case 'c':
- if (lookup_ctx)
- usage();
- lookup_ctx = ARG();
- break;
- case 's':
- if (lookup_srv)
- usage();
- lookup_srv = ARG();
- break;
- case 'A':
- display_addr = 1;
- break;
- case 'C':
- display_ctx = 1;
- break;
- case 'S':
- display_srv = 1;
- break;
- default:
- usage();
- } ARGEND;
+#define CATEGORY chats
- if (!argc)
- usage();
+#define LIST_PARAMS(X)\
+ X('C', "C", 'c', "c", context, "context")\
+ X('S', "S", 's', "s", service, "service")\
+ X('A', "A", 'a', "a", address, "address")
- if (!display_ctx && !display_addr && !display_srv) {
- display_ctx = !lookup_ctx;
- display_addr = !lookup_addr;
- display_srv = !lookup_srv;
- }
-
- 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 ((chats = contact.chats)) {
- for (; (chat = *chats); chats++) {
- if (lookup_ctx && strcmpnul(chat->context, lookup_ctx))
- continue;
- if (lookup_addr && strcmpnul(chat->address, lookup_addr))
- continue;
- if (lookup_srv && strcmpnul(chat->service, lookup_srv))
- continue;
- if (!display_ctx && !display_addr && !display_srv) {
- printf("%s\n", *argv);
- continue;
- }
- if (display_ctx && !chat->context)
- continue;
- if (display_srv && !chat->service)
- continue;
- if (display_addr && !chat->address)
- continue;
- if (argc > 1)
- printf("%s: ", *argv);
- if (display_ctx)
- printf("%s%s", chat->context, (display_srv || display_addr) ? ": " : "\n");
- if (display_srv)
- printf("%s%s", chat->service, display_addr ? ": " : "\n");
- if (display_addr)
- printf("%s\n", chat->address);
- }
- }
- libcontacts_contact_destroy(&contact);
- }
-
- if (fflush(stdout) || ferror(stdout) || fclose(stdout))
- eprintf("printf:");
- return ret;
-}
+#include "common.h"
+IMPLEMENT_GET_ON_LIST(chat)