blob: 8d44a9a0515cc7b050874b8a0c5a4bdf865a7fb8 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
/* See LICENSE file for copyright and license details. */
#include "common.h"
int
libcontacts_load_contacts(struct libcontacts_contact ***contactsp, const struct passwd *user, int with_me)
{
int saved_errno = errno;
char **ids;
void *temp;
size_t i, j, n;
struct libcontacts_contact contact;
*contactsp = NULL;
if (libcontacts_list_contacts(&ids, user, with_me))
return -1;
for (n = 0; ids[n]; n++);
*contactsp = calloc(n + 1, sizeof(**contactsp));
if (!*contactsp)
goto fail;
for (i = j = 0; i < n; i++) {
memset(&contact, 0, sizeof(contact));
if (libcontacts_load_contact(ids[i], &contact, user)) {
switch (errno) {
case ENOENT:
case EACCES:
continue;
default:
goto fail;
}
}
(*contactsp)[j] = calloc(1, sizeof(***contactsp));
if (!(*contactsp)[j])
goto fail;
*(*contactsp)[j++] = contact;
}
for (i = 0; i < n; i++)
free(ids[i]);
free(ids);
errno = saved_errno;
return 0;
fail:
for (i = 0; i < n; i++)
free(ids[i]);
free(ids);
if ((temp = *contactsp)) {
for (; **contactsp; ++*contactsp) {
libcontacts_contact_destroy(**contactsp);
free(**contactsp);
}
}
free(temp);
*contactsp = NULL;
return -1;
}
|