X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fshared%2Futil.h;h=f0dfe19ad46252e7b0b65148b2c1eb8fc30e3463;hb=961e4526925b7b1e1d3582f2fc9fb38035e2b5fb;hp=27b21f97cc4109da6e1e6bb0b3a7be8845f44103;hpb=076a24adf4bfbb9c5aa8167e102c253c7e1c651e;p=elogind.git diff --git a/src/shared/util.h b/src/shared/util.h index 27b21f97c..f0dfe19ad 100644 --- a/src/shared/util.h +++ b/src/shared/util.h @@ -519,12 +519,17 @@ void warn_melody(void); int get_shell(char **ret); int get_home_dir(char **ret); -void freep(void *p); +static inline void freep(void *p) { + free(*(void**) p); +} + void fclosep(FILE **f); void pclosep(FILE **f); void closep(int *fd); void closedirp(DIR **d); -void umaskp(mode_t *u); +static inline void umaskp(mode_t *u) { + umask(*u); +} _malloc_ static inline void *malloc_multiply(size_t a, size_t b) { if (_unlikely_(b == 0 || a > ((size_t) -1) / b)) @@ -589,3 +594,8 @@ int search_and_fopen_nulstr(const char *path, const char *mode, const char *sear } else if (ignore_file((de)->d_name)) \ continue; \ else + +static inline void *mempset(void *s, int c, size_t n) { + memset(s, c, n); + return (char*)s + n; +}