1 #ifndef __API_FD_ARRAY__
2 #define __API_FD_ARRAY__
9 * struct fdarray: Array of file descriptors
11 * @priv: Per array entry priv area, users should access just its contents,
12 * not set it to anything, as it is kept in synch with @entries, being
13 * realloc'ed, * for instance, in fdarray__{grow,filter}.
15 * I.e. using 'fda->priv[N].idx = * value' where N < fda->nr is ok,
16 * but doing 'fda->priv = malloc(M)' is not allowed.
22 struct pollfd
*entries
;
28 void fdarray__init(struct fdarray
*fda
, int nr_autogrow
);
29 void fdarray__exit(struct fdarray
*fda
);
31 struct fdarray
*fdarray__new(int nr_alloc
, int nr_autogrow
);
32 void fdarray__delete(struct fdarray
*fda
);
34 int fdarray__add(struct fdarray
*fda
, int fd
, short revents
);
35 int fdarray__poll(struct fdarray
*fda
, int timeout
);
36 int fdarray__filter(struct fdarray
*fda
, short revents
,
37 void (*entry_destructor
)(struct fdarray
*fda
, int fd
));
38 int fdarray__grow(struct fdarray
*fda
, int extra
);
39 int fdarray__fprintf(struct fdarray
*fda
, FILE *fp
);
41 static inline int fdarray__available_entries(struct fdarray
*fda
)
43 return fda
->nr_alloc
- fda
->nr
;
46 #endif /* __API_FD_ARRAY__ */