X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fshared%2Futil.h;h=38851237ab15957762723d7023fb2bf12e6359bf;hb=4b73a0c0612d26d49791f389e92f85d6444c36af;hp=7a38421007f7929a7ad2762a9c53dcc32fc226b1;hpb=4468addca6d01a0d2d154371dd72f54307a9c786;p=elogind.git diff --git a/src/shared/util.h b/src/shared/util.h index 7a3842100..38851237a 100644 --- a/src/shared/util.h +++ b/src/shared/util.h @@ -36,8 +36,9 @@ #include #include #include -#include +#include +#include #include "macro.h" #include "time-util.h" @@ -329,6 +330,7 @@ ssize_t loop_write(int fd, const void *buf, size_t nbytes, bool do_poll); bool is_device_path(const char *path); int dir_is_empty(const char *path); +char* dirname_malloc(const char *path); void rename_process(const char name[8]); @@ -519,7 +521,6 @@ bool in_initrd(void); void warn_melody(void); -int get_shell(char **ret); int get_home_dir(char **ret); static inline void freep(void *p) { @@ -538,6 +539,8 @@ static inline void journal_closep(sd_journal **j) { sd_journal_close(*j); } +#define _cleanup_globfree_ __attribute__((cleanup(globfree))) + _malloc_ static inline void *malloc_multiply(size_t a, size_t b) { if (_unlikely_(b == 0 || a > ((size_t) -1) / b)) return NULL; @@ -595,7 +598,7 @@ int create_tmp_dir(char template[], char** dir_name); #define FOREACH_DIRENT(de, d, on_error) \ for (errno = 0, de = readdir(d);; errno = 0, de = readdir(d)) \ if (!de) { \ - if (errno != 0) { \ + if (errno > 0) { \ on_error; \ } \ break; \ @@ -609,5 +612,39 @@ static inline void *mempset(void *s, int c, size_t n) { } char *hexmem(const void *p, size_t l); +void *unhexmem(const char *p, size_t l); + char *strextend(char **x, ...); char *strrep(const char *s, unsigned n); + +void* greedy_realloc(void **p, size_t *allocated, size_t need); + +static inline void _reset_errno_(int *saved_errno) { + errno = *saved_errno; +} + +#define PROTECT_ERRNO __attribute__((cleanup(_reset_errno_))) int _saved_errno_ = errno + +struct umask_struct { + mode_t mask; + bool quit; +}; + +static inline void _reset_umask_(struct umask_struct *s) { + umask(s->mask); +}; + +#define RUN_WITH_UMASK(mask) \ + for (__attribute__((cleanup(_reset_umask_))) struct umask_struct _saved_umask_ = { umask(mask), false }; \ + !_saved_umask_.quit ; \ + _saved_umask_.quit = true) + +static inline unsigned u64log2(uint64_t n) { + return (n > 1) ? __builtin_clzll(n) ^ 63U : 0; +} + +static inline bool logind_running(void) { + return access("/run/systemd/seats/", F_OK) >= 0; +} + +int unlink_noerrno(const char *path);