X-Git-Url: http://git.tuebingen.mpg.de/?p=adu.git;a=blobdiff_plain;f=adu.h;h=85ab63a6e04db918f14f37e3e5f40d9294cb555a;hp=f8ef9c2ddf53af4a6c44ff9b3193487cbf8c9838;hb=38117be0e4d8d0a62f01cfe1a5702bdf358a1fea;hpb=b01ff57775258c8df4c486b0962fc67cfdfef439 diff --git a/adu.h b/adu.h index f8ef9c2..85ab63a 100644 --- a/adu.h +++ b/adu.h @@ -21,6 +21,7 @@ #include #include #include "gcc-compat.h" +#include "select.cmdline.h" /** debug loglevel, gets really noisy */ #define DEBUG 1 @@ -173,9 +174,12 @@ enum search_uid_flags { CREATE_USER_TABLE = 2, }; +#define FOR_EACH_UID_RANGE(ur, urs) for (ur = urs; ur->low <= ur->high; ur++) + extern uint32_t num_uids; extern struct osl_table *dir_table; extern struct gengetopt_args_info conf; +extern struct select_args_info select_conf; /* adu.c */ __printf_2_3 void __log(int, const char*, ...); @@ -184,15 +188,15 @@ void check_signals(void); void close_all_tables(void); char *get_uid_list_name(void); void create_hash_table(unsigned bits); -int search_uid(uint32_t uid, enum search_uid_flags flags, - struct user_info **ui_ptr); +int search_uid(uint32_t uid, struct uid_range *urs, + enum search_uid_flags flags, struct user_info **ui_ptr); int for_each_admissible_user(int (*func)(struct user_info *, void *), void *data); void sort_hash_table(int (*comp)(const void *, const void *)); -/* select.c */ -int com_select(void); - -/* create.h */ +/* create.c */ int com_create(void); + +/* interactive.c */ +void print_interactive_help(void); int com_interactive(void);