Lines Matching refs:fda
12 void fdarray__init(struct fdarray *fda, int nr_autogrow) in fdarray__init() argument
14 fda->entries = NULL; in fdarray__init()
15 fda->priv = NULL; in fdarray__init()
16 fda->nr = fda->nr_alloc = 0; in fdarray__init()
17 fda->nr_autogrow = nr_autogrow; in fdarray__init()
20 int fdarray__grow(struct fdarray *fda, int nr) in fdarray__grow() argument
23 int nr_alloc = fda->nr_alloc + nr; in fdarray__grow()
24 size_t psize = sizeof(fda->priv[0]) * nr_alloc; in fdarray__grow()
26 struct pollfd *entries = realloc(fda->entries, size); in fdarray__grow()
31 priv = realloc(fda->priv, psize); in fdarray__grow()
37 fda->nr_alloc = nr_alloc; in fdarray__grow()
38 fda->entries = entries; in fdarray__grow()
39 fda->priv = priv; in fdarray__grow()
45 struct fdarray *fda = calloc(1, sizeof(*fda)); in fdarray__new() local
47 if (fda != NULL) { in fdarray__new()
48 if (fdarray__grow(fda, nr_alloc)) { in fdarray__new()
49 free(fda); in fdarray__new()
50 fda = NULL; in fdarray__new()
52 fda->nr_autogrow = nr_autogrow; in fdarray__new()
56 return fda; in fdarray__new()
59 void fdarray__exit(struct fdarray *fda) in fdarray__exit() argument
61 free(fda->entries); in fdarray__exit()
62 free(fda->priv); in fdarray__exit()
63 fdarray__init(fda, 0); in fdarray__exit()
66 void fdarray__delete(struct fdarray *fda) in fdarray__delete() argument
68 fdarray__exit(fda); in fdarray__delete()
69 free(fda); in fdarray__delete()
72 int fdarray__add(struct fdarray *fda, int fd, short revents) in fdarray__add() argument
74 int pos = fda->nr; in fdarray__add()
76 if (fda->nr == fda->nr_alloc && in fdarray__add()
77 fdarray__grow(fda, fda->nr_autogrow) < 0) in fdarray__add()
80 fda->entries[fda->nr].fd = fd; in fdarray__add()
81 fda->entries[fda->nr].events = revents; in fdarray__add()
82 fda->nr++; in fdarray__add()
86 int fdarray__filter(struct fdarray *fda, short revents, in fdarray__filter() argument
87 void (*entry_destructor)(struct fdarray *fda, int fd, void *arg), in fdarray__filter() argument
92 if (fda->nr == 0) in fdarray__filter()
95 for (fd = 0; fd < fda->nr; ++fd) { in fdarray__filter()
96 if (fda->entries[fd].revents & revents) { in fdarray__filter()
98 entry_destructor(fda, fd, arg); in fdarray__filter()
104 fda->entries[nr] = fda->entries[fd]; in fdarray__filter()
105 fda->priv[nr] = fda->priv[fd]; in fdarray__filter()
111 return fda->nr = nr; in fdarray__filter()
114 int fdarray__poll(struct fdarray *fda, int timeout) in fdarray__poll() argument
116 return poll(fda->entries, fda->nr, timeout); in fdarray__poll()
119 int fdarray__fprintf(struct fdarray *fda, FILE *fp) in fdarray__fprintf() argument
121 int fd, printed = fprintf(fp, "%d [ ", fda->nr); in fdarray__fprintf()
123 for (fd = 0; fd < fda->nr; ++fd) in fdarray__fprintf()
124 printed += fprintf(fp, "%s%d", fd ? ", " : "", fda->entries[fd].fd); in fdarray__fprintf()