chiark
/
gitweb
/
~ianmdlvl
/
elogind.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
log: rework logging logic so that we don't keep /dev/console open
[elogind.git]
/
util.h
diff --git
a/util.h
b/util.h
index 6d1af6eefd34a2c90d4bc18ce035068eff4f3c16..ba27c759e805fd34d09e2463a48b5f6ee97d02e4 100644
(file)
--- a/
util.h
+++ b/
util.h
@@
-38,6
+38,11
@@
typedef uint64_t usec_t;
#define NSEC_PER_MSEC 1000000ULL
#define NSEC_PER_USEC 1000ULL
#define NSEC_PER_MSEC 1000000ULL
#define NSEC_PER_USEC 1000ULL
+#define USEC_PER_MINUTE (60ULL*USEC_PER_SEC)
+#define USEC_PER_HOUR (60ULL*USEC_PER_MINUTE)
+#define USEC_PER_DAY (24ULL*USEC_PER_HOUR)
+#define USEC_PER_WEEK (7ULL*USEC_PER_DAY)
+
/* What is interpreted as whitespace? */
#define WHITESPACE " \t\n\r"
#define NEWLINE "\n\r"
/* What is interpreted as whitespace? */
#define WHITESPACE " \t\n\r"
#define NEWLINE "\n\r"
@@
-84,6
+89,7
@@
static inline bool is_path_absolute(const char *p) {
bool endswith(const char *s, const char *postfix);
bool startswith(const char *s, const char *prefix);
bool endswith(const char *s, const char *postfix);
bool startswith(const char *s, const char *prefix);
+bool startswith_no_case(const char *s, const char *prefix);
bool first_word(const char *s, const char *word);
bool first_word(const char *s, const char *word);
@@
-91,6
+97,7
@@
int close_nointr(int fd);
void close_nointr_nofail(int fd);
int parse_boolean(const char *v);
void close_nointr_nofail(int fd);
int parse_boolean(const char *v);
+int parse_usec(const char *t, usec_t *usec);
int safe_atou(const char *s, unsigned *ret_u);
int safe_atoi(const char *s, int *ret_i);
int safe_atou(const char *s, unsigned *ret_u);
int safe_atoi(const char *s, int *ret_i);
@@
-157,6
+164,7
@@
char *cunescape(const char *s);
char *path_kill_slashes(char *path);
bool path_startswith(const char *path, const char *prefix);
char *path_kill_slashes(char *path);
bool path_startswith(const char *path, const char *prefix);
+bool path_equal(const char *a, const char *b);
char *ascii_strlower(char *path);
char *ascii_strlower(char *path);
@@
-171,6
+179,8
@@
bool chars_intersect(const char *a, const char *b);
char *format_timestamp(char *buf, size_t l, usec_t t);
char *format_timestamp(char *buf, size_t l, usec_t t);
+int make_stdio(int fd);
+
#define DEFINE_STRING_TABLE_LOOKUP(name,type) \
const char *name##_to_string(type i) { \
if (i < 0 || i >= (type) ELEMENTSOF(name##_table)) \
#define DEFINE_STRING_TABLE_LOOKUP(name,type) \
const char *name##_to_string(type i) { \
if (i < 0 || i >= (type) ELEMENTSOF(name##_table)) \
@@
-211,6
+221,14
@@
int release_terminal(void);
int flush_fd(int fd);
int flush_fd(int fd);
+int ignore_signal(int sig);
+
+int close_pipe(int p[]);
+
+ssize_t loop_read(int fd, void *buf, size_t nbytes);
+
+int path_is_mount_point(const char *path);
+
extern char * __progname;
const char *ioprio_class_to_string(int i);
extern char * __progname;
const char *ioprio_class_to_string(int i);