aboutsummaryrefslogtreecommitdiffstats
path: root/get-contact-gender.c
diff options
context:
space:
mode:
authorMattias Andrée <maandree@kth.se>2021-04-03 02:28:44 +0200
committerMattias Andrée <maandree@kth.se>2021-04-03 02:28:44 +0200
commit49e4bd18d29d5ef9c85d106026b09d86de6ff19c (patch)
treeacaad00d8d6df3a9dd6f0780fb837933b6ccddfd /get-contact-gender.c
downloadcontacts-49e4bd18d29d5ef9c85d106026b09d86de6ff19c.tar.gz
contacts-49e4bd18d29d5ef9c85d106026b09d86de6ff19c.tar.bz2
contacts-49e4bd18d29d5ef9c85d106026b09d86de6ff19c.tar.xz
First commmit
Signed-off-by: Mattias Andrée <maandree@kth.se>
Diffstat (limited to 'get-contact-gender.c')
-rw-r--r--get-contact-gender.c57
1 files changed, 57 insertions, 0 deletions
diff --git a/get-contact-gender.c b/get-contact-gender.c
new file mode 100644
index 0000000..32fef81
--- /dev/null
+++ b/get-contact-gender.c
@@ -0,0 +1,57 @@
+/* See LICENSE file for copyright and license details. */
+#include "common.h"
+
+USAGE("[-f] contact-id ...");
+
+
+int
+main(int argc, char *argv[])
+{
+ struct passwd *user;
+ struct libcontacts_contact contact;
+ int output_flag = 0, ret = 0;
+ size_t i;
+
+ ARGBEGIN {
+ case 'f':
+ output_flag = 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;
+ } else {
+ if (argc > 1)
+ printf("%s: ", *argv);
+ if (contact.gender == LIBCONTACTS_NOT_A_PERSON)
+ printf("%s\n", output_flag ? "-o" : "none");
+ else if (contact.gender == LIBCONTACTS_MALE)
+ printf("%s\n", output_flag ? "-m" : "male");
+ else if (contact.gender == LIBCONTACTS_FEMALE)
+ printf("%s\n", output_flag ? "-f" : "female");
+ else
+ printf("%s\n", output_flag ? "-u" : "unset");
+ libcontacts_contact_destroy(&contact);
+ }
+ }
+
+ if (fflush(stdout) || ferror(stdout) || fclose(stdout))
+ eprintf("printf:");
+ return ret;
+}