diff options
author | Mattias Andrée <maandree@kth.se> | 2021-04-03 19:26:35 +0200 |
---|---|---|
committer | Mattias Andrée <maandree@kth.se> | 2021-04-03 19:26:35 +0200 |
commit | 2c6143d373c86f6b5c31e07d97447063766cd4eb (patch) | |
tree | 3f92f07cb737dad6f0f6f02bd191741fdd57edad /list-chat-contacts.c | |
parent | Add photo utils (diff) | |
download | contacts-2c6143d373c86f6b5c31e07d97447063766cd4eb.tar.gz contacts-2c6143d373c86f6b5c31e07d97447063766cd4eb.tar.bz2 contacts-2c6143d373c86f6b5c31e07d97447063766cd4eb.tar.xz |
m + add chat utils
Signed-off-by: Mattias Andrée <maandree@kth.se>
Diffstat (limited to 'list-chat-contacts.c')
-rw-r--r-- | list-chat-contacts.c | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/list-chat-contacts.c b/list-chat-contacts.c new file mode 100644 index 0000000..eb262a9 --- /dev/null +++ b/list-chat-contacts.c @@ -0,0 +1,71 @@ +/* See LICENSE file for copyright and license details. */ +#include "common.h" + +USAGE("[-c context] [-a] service"); + + +int +main(int argc, char *argv[]) +{ + int display_address = 0; + struct passwd *user; + struct libcontacts_contact **contacts; + struct libcontacts_chat **chats, *chat; + char *context = NULL; + size_t i; + + ARGBEGIN { + case 'a': + display_address = 1; + break; + case 'c': + if (context) + usage(); + context = ARG(); + break; + default: + usage(); + } ARGEND; + + if (argc != 1) + usage(); + + errno = 0; + user = getpwuid(getuid()); + if (!user) + eprintf("getpwuid: %s\n", errno ? strerror(errno) : "user does not exist"); + + if (libcontacts_load_contacts(&contacts, user)) + eprintf("libcontacts_load_contacts:"); + for (i = 0; contacts[i]; i++) { + if ((chats = contacts[i]->chats)) { + for (; (chat = *chats); chats++) { + if (display_address && !chat->address) + continue; + if (strcmpnul(chat->service, argv[0])) + continue; + if (context && strcmpnul(chat->context, context)) + continue; + if (context || !chat->context) { + if (display_address) + printf("%s (%s)\n", contacts[i]->id, chat->address); + else + printf("%s\n", contacts[i]->id); + } else if (chat->context) { + if (display_address) + printf("%s (%s: %s)\n", contacts[i]->id, chat->context, chat->address); + else + printf("%s (%s)\n", contacts[i]->id, chat->context); + } + } + } + libcontacts_contact_destroy(contacts[i]); + free(contacts[i]); + } + free(contacts); + + if (fflush(stdout) || ferror(stdout) || fclose(stdout)) + eprintf("printf:"); + + return 0; +} |