X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Fsystemd%2Fsd-event.h;h=fd32ac85650b9ebae99a39674e2a149e0b921fba;hp=1adb26ee44104acb48944aa16fd6b3d3cd13ce5f;hb=f4c228f18281f3a7b305940329ca9b7a51fc430d;hpb=d2338db3145922b1dfcb3b458e5bce2568a9347a diff --git a/src/systemd/sd-event.h b/src/systemd/sd-event.h index 1adb26ee4..fd32ac856 100644 --- a/src/systemd/sd-event.h +++ b/src/systemd/sd-event.h @@ -1,5 +1,3 @@ -/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/ - #ifndef foosdeventhfoo #define foosdeventhfoo @@ -22,11 +20,11 @@ along with systemd; If not, see . ***/ -#include -#include -#include #include #include +#include +#include +#include #include "_sd-common.h" @@ -56,7 +54,8 @@ enum { SD_EVENT_PENDING, SD_EVENT_RUNNING, SD_EVENT_EXITING, - SD_EVENT_FINISHED + SD_EVENT_FINISHED, + SD_EVENT_PREPARING, }; enum { @@ -81,54 +80,84 @@ sd_event* sd_event_unref(sd_event *e); int sd_event_add_io(sd_event *e, sd_event_source **s, int fd, uint32_t events, sd_event_io_handler_t callback, void *userdata); int sd_event_add_time(sd_event *e, sd_event_source **s, clockid_t clock, uint64_t usec, uint64_t accuracy, sd_event_time_handler_t callback, void *userdata); int sd_event_add_signal(sd_event *e, sd_event_source **s, int sig, sd_event_signal_handler_t callback, void *userdata); -// UNNEEDED int sd_event_add_child(sd_event *e, sd_event_source **s, pid_t pid, int options, sd_event_child_handler_t callback, void *userdata); -// UNNEEDED int sd_event_add_defer(sd_event *e, sd_event_source **s, sd_event_handler_t callback, void *userdata); +#if 0 /// UNNEEDED by elogind +int sd_event_add_child(sd_event *e, sd_event_source **s, pid_t pid, int options, sd_event_child_handler_t callback, void *userdata); +int sd_event_add_defer(sd_event *e, sd_event_source **s, sd_event_handler_t callback, void *userdata); +#endif // 0 int sd_event_add_post(sd_event *e, sd_event_source **s, sd_event_handler_t callback, void *userdata); int sd_event_add_exit(sd_event *e, sd_event_source **s, sd_event_handler_t callback, void *userdata); int sd_event_prepare(sd_event *e); -int sd_event_wait(sd_event *e, uint64_t timeout); +int sd_event_wait(sd_event *e, uint64_t usec); int sd_event_dispatch(sd_event *e); -int sd_event_run(sd_event *e, uint64_t timeout); -// UNNEEDED int sd_event_loop(sd_event *e); +int sd_event_run(sd_event *e, uint64_t usec); +#if 0 /// UNNEEDED by elogind +int sd_event_loop(sd_event *e); +#endif // 0 int sd_event_exit(sd_event *e, int code); -// UNNEEDED int sd_event_now(sd_event *e, clockid_t clock, uint64_t *usec); +#if 0 /// UNNEEDED by elogind +int sd_event_now(sd_event *e, clockid_t clock, uint64_t *usec); -// UNNEEDED int sd_event_get_fd(sd_event *e); +int sd_event_get_fd(sd_event *e); +#endif // 0 int sd_event_get_state(sd_event *e); -// UNNEEDED int sd_event_get_tid(sd_event *e, pid_t *tid); -// UNNEEDED int sd_event_get_exit_code(sd_event *e, int *code); +#if 0 /// UNNEEDED by elogind +int sd_event_get_tid(sd_event *e, pid_t *tid); +int sd_event_get_exit_code(sd_event *e, int *code); +#endif // 0 int sd_event_set_watchdog(sd_event *e, int b); -// UNNEEDED int sd_event_get_watchdog(sd_event *e); +#if 0 /// UNNEEDED by elogind +int sd_event_get_watchdog(sd_event *e); -// UNNEEDED sd_event_source* sd_event_source_ref(sd_event_source *s); +sd_event_source* sd_event_source_ref(sd_event_source *s); +#endif // 0 sd_event_source* sd_event_source_unref(sd_event_source *s); sd_event *sd_event_source_get_event(sd_event_source *s); -// UNNEEDED void* sd_event_source_get_userdata(sd_event_source *s); -// UNNEEDED void* sd_event_source_set_userdata(sd_event_source *s, void *userdata); +#if 0 /// UNNEEDED by elogind +void* sd_event_source_get_userdata(sd_event_source *s); +void* sd_event_source_set_userdata(sd_event_source *s, void *userdata); +#endif // 0 int sd_event_source_set_description(sd_event_source *s, const char *description); -// UNNEEDED int sd_event_source_get_description(sd_event_source *s, const char **description); +#if 0 /// UNNEEDED by elogind +int sd_event_source_get_description(sd_event_source *s, const char **description); +#endif // 0 int sd_event_source_set_prepare(sd_event_source *s, sd_event_handler_t callback); -// UNNEEDED int sd_event_source_get_pending(sd_event_source *s); -// UNNEEDED int sd_event_source_get_priority(sd_event_source *s, int64_t *priority); +#if 0 /// UNNEEDED by elogind +int sd_event_source_get_pending(sd_event_source *s); +int sd_event_source_get_priority(sd_event_source *s, int64_t *priority); +#endif // 0 int sd_event_source_set_priority(sd_event_source *s, int64_t priority); -// UNNEEDED int sd_event_source_get_enabled(sd_event_source *s, int *enabled); +#if 0 /// UNNEEDED by elogind +int sd_event_source_get_enabled(sd_event_source *s, int *enabled); +#endif // 0 int sd_event_source_set_enabled(sd_event_source *s, int enabled); -// UNNEEDED int sd_event_source_get_io_fd(sd_event_source *s); +#if 0 /// UNNEEDED by elogind +int sd_event_source_get_io_fd(sd_event_source *s); +#endif // 0 int sd_event_source_set_io_fd(sd_event_source *s, int fd); -// UNNEEDED int sd_event_source_get_io_events(sd_event_source *s, uint32_t* events); +#if 0 /// UNNEEDED by elogind +int sd_event_source_get_io_events(sd_event_source *s, uint32_t* events); +#endif // 0 int sd_event_source_set_io_events(sd_event_source *s, uint32_t events); -// UNNEEDED int sd_event_source_get_io_revents(sd_event_source *s, uint32_t* revents); +#if 0 /// UNNEEDED by elogind +int sd_event_source_get_io_revents(sd_event_source *s, uint32_t* revents); +#endif // 0 int sd_event_source_get_time(sd_event_source *s, uint64_t *usec); int sd_event_source_set_time(sd_event_source *s, uint64_t usec); -// UNNEEDED int sd_event_source_get_time_accuracy(sd_event_source *s, uint64_t *usec); -// UNNEEDED int sd_event_source_set_time_accuracy(sd_event_source *s, uint64_t usec); -// UNNEEDED int sd_event_source_get_time_clock(sd_event_source *s, clockid_t *clock); -// UNNEEDED int sd_event_source_get_signal(sd_event_source *s); -// UNNEEDED int sd_event_source_get_child_pid(sd_event_source *s, pid_t *pid); +#if 0 /// UNNEEDED by elogind +int sd_event_source_get_time_accuracy(sd_event_source *s, uint64_t *usec); +int sd_event_source_set_time_accuracy(sd_event_source *s, uint64_t usec); +int sd_event_source_get_time_clock(sd_event_source *s, clockid_t *clock); +int sd_event_source_get_signal(sd_event_source *s); +int sd_event_source_get_child_pid(sd_event_source *s, pid_t *pid); +#endif // 0 + +/* Define helpers so that __attribute__((cleanup(sd_event_unrefp))) and similar may be used. */ +_SD_DEFINE_POINTER_CLEANUP_FUNC(sd_event, sd_event_unref); +_SD_DEFINE_POINTER_CLEANUP_FUNC(sd_event_source, sd_event_source_unref); _SD_END_DECLARATIONS;