X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;ds=sidebyside;f=name.h;h=59f3b16f17eab61442e97cdbef1b51307541d4b0;hb=9152c765065184d0c1267ed2499e3fe4cac53755;hp=8c526baed6b525e4a091e324ae8f2aaf1738249e;hpb=476fe607ecbabc5beffafc8efb0778e3d9e1030a;p=elogind.git diff --git a/name.h b/name.h index 8c526baed..59f3b16f1 100644 --- a/name.h +++ b/name.h @@ -140,9 +140,16 @@ struct NameVTable { * a simpler one that the engine can understand */ NameActiveState (*active_state)(Name *n); + void (*fd_event)(Name *n, int fd, uint32_t events); + void (*sigchld_event)(Name *n, pid_t pid, int code, int status); + void (*free_hook)(Name *n); }; +extern const NameVTable * const name_vtable[_NAME_TYPE_MAX]; + +#define NAME_VTABLE(n) name_vtable[(n)->meta.type] + /* For casting a name into the various name types */ #define DEFINE_CAST(UPPERCASE, MixedCase) \ static inline MixedCase* UPPERCASE(Name *name) { \ @@ -191,4 +198,10 @@ int name_reload(Name *n); void name_notify(Name *n, NameActiveState os, NameActiveState ns); +int name_watch_fd(Name *n, int fd, uint32_t events); +void name_unwatch_fd(Name *n, int fd); + +int name_watch_pid(Name *n, pid_t pid); +void name_unwatch_pid(Name *n, pid_t pid); + #endif