X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fbasic%2Ffileio.h;h=fa223fdf52d021ace998f9be72c16e43ae45a244;hb=9742b1e43855b1599bd52ff95af995d9a9d35eac;hp=0635147b756d38c9fe96c6fe48d7ab82a3118714;hpb=e0a51e4dd37f53af54ab05fa41ce3c4a535a76d4;p=elogind.git diff --git a/src/basic/fileio.h b/src/basic/fileio.h index 0635147b7..fa223fdf5 100644 --- a/src/basic/fileio.h +++ b/src/basic/fileio.h @@ -35,8 +35,14 @@ typedef enum { WRITE_STRING_FILE_VERIFY_ON_FAILURE = 8, } WriteStringFileFlags; -int write_string_stream(FILE *f, const char *line, bool enforce_newline); -int write_string_file(const char *fn, const char *line, WriteStringFileFlags flags); +int write_string_stream_ts(FILE *f, const char *line, bool enforce_newline, struct timespec *ts); +static inline int write_string_stream(FILE *f, const char *line, bool enforce_newline) { + return write_string_stream_ts(f, line, enforce_newline, NULL); +} +int write_string_file_ts(const char *fn, const char *line, WriteStringFileFlags flags, struct timespec *ts); +static inline int write_string_file(const char *fn, const char *line, WriteStringFileFlags flags) { + return write_string_file_ts(fn, line, flags, NULL); +} int read_one_line_file(const char *fn, char **line); int read_full_file(const char *fn, char **contents, size_t *size); @@ -47,8 +53,12 @@ int verify_file(const char *fn, const char *blob, bool accept_extra_nl); int parse_env_file(const char *fname, const char *separator, ...) _sentinel_; #if 0 /// UNNEEDED by elogind int load_env_file(FILE *f, const char *fname, const char *separator, char ***l); +#endif // 0 int load_env_file_pairs(FILE *f, const char *fname, const char *separator, char ***l); +#if 0 /// UNNEEDED by elogind +int merge_env_file(char ***env, FILE *f, const char *fname); + int write_env_file(const char *fname, char **l); int executable_is_script(const char *path, char **interpreter); @@ -62,6 +72,7 @@ DIR *xopendirat(int dirfd, const char *name, int flags); int search_and_fopen(const char *path, const char *mode, const char *root, const char **search, FILE **_f); int search_and_fopen_nulstr(const char *path, const char *mode, const char *root, const char *search, FILE **_f); #endif // 0 + #define FOREACH_LINE(line, f, on_error) \ for (;;) \ if (!fgets(line, sizeof(line), f)) { \ @@ -74,14 +85,11 @@ int search_and_fopen_nulstr(const char *path, const char *mode, const char *root int fflush_and_check(FILE *f); int fopen_temporary(const char *path, FILE **_f, char **_temp_path); -int mkostemp_safe(char *pattern, int flags); -#if 0 /// UNNEEDED by elogind -int open_tmpfile(const char *path, int flags); -#endif // 0 +int mkostemp_safe(char *pattern); int tempfn_xxxxxx(const char *p, const char *extra, char **ret); -#if 0 /// UNNEEDED by elogind int tempfn_random(const char *p, const char *extra, char **ret); +#if 0 /// UNNEEDED by elogind int tempfn_random_child(const char *p, const char *extra, char **ret); int write_timestamp_file_atomic(const char *fn, usec_t n); @@ -89,3 +97,17 @@ int read_timestamp_file(const char *fn, usec_t *ret); int fputs_with_space(FILE *f, const char *s, const char *separator, bool *space); #endif // 0 + +int open_tmpfile_unlinkable(const char *directory, int flags); +#if 0 /// UNNEEDED by elogind +int open_tmpfile_linkable(const char *target, int flags, char **ret_path); +#endif // 0 +int open_serialization_fd(const char *ident); + +#if 0 /// UNNEEDED by elogind +int link_tmpfile(int fd, const char *path, const char *target); + +int read_nul_string(FILE *f, char **ret); + +int mkdtemp_malloc(const char *template, char **ret); +#endif // 0