4 char *xstrdup(const char *str
);
5 void *xmalloc(size_t size
);
6 void *xmallocz(size_t size
);
7 void *xmallocz_gently(size_t size
);
8 void *xmemdupz(const void *data
, size_t len
);
9 char *xstrndup(const char *str
, size_t len
);
10 void *xrealloc(void *ptr
, size_t size
);
11 void *xcalloc(size_t nmemb
, size_t size
);
12 void xsetenv(const char *name
, const char *value
, int overwrite
);
13 void *xmmap(void *start
, size_t length
, int prot
, int flags
, int fd
, off_t offset
);
14 const char *mmap_os_err(void);
15 void *xmmap_gently(void *start
, size_t length
, int prot
, int flags
, int fd
, off_t offset
);
16 int xopen(const char *path
, int flags
, ...);
17 ssize_t
xread(int fd
, void *buf
, size_t len
);
18 ssize_t
xwrite(int fd
, const void *buf
, size_t len
);
19 ssize_t
xpread(int fd
, void *buf
, size_t len
, off_t offset
);
21 FILE *xfopen(const char *path
, const char *mode
);
22 FILE *xfdopen(int fd
, const char *mode
);
23 int xmkstemp(char *temp_filename
);
24 int xmkstemp_mode(char *temp_filename
, int mode
);
26 FILE *fopen_for_writing(const char *path
);
27 FILE *fopen_or_warn(const char *path
, const char *mode
);
30 * Like strncmp, but only return zero if s is NUL-terminated and exactly len
31 * characters long. If it is not, consider it greater than t.
33 int xstrncmpz(const char *s
, const char *t
, size_t len
);
35 __attribute__((format (printf
, 3, 4)))
36 int xsnprintf(char *dst
, size_t max
, const char *fmt
, ...);
38 int xgethostname(char *buf
, size_t len
);
40 /* set default permissions by passing mode arguments to open(2) */
41 int git_mkstemps_mode(char *pattern
, int suffix_len
, int mode
);
42 int git_mkstemp_mode(char *pattern
, int mode
);
44 ssize_t
read_in_full(int fd
, void *buf
, size_t count
);
45 ssize_t
write_in_full(int fd
, const void *buf
, size_t count
);
46 ssize_t
pread_in_full(int fd
, void *buf
, size_t count
, off_t offset
);
48 static inline ssize_t
write_str_in_full(int fd
, const char *str
)
50 return write_in_full(fd
, str
, strlen(str
));
54 * Open (and truncate) the file at path, write the contents of buf to it,
55 * and close it. Dies if any errors are encountered.
57 void write_file_buf(const char *path
, const char *buf
, size_t len
);
60 * Like write_file_buf(), but format the contents into a buffer first.
61 * Additionally, write_file() will append a newline if one is not already
62 * present, making it convenient to write text files:
64 * write_file(path, "counter: %d", ctr);
66 __attribute__((format (printf
, 2, 3)))
67 void write_file(const char *path
, const char *fmt
, ...);
69 /* Return 1 if the file is empty or does not exists, 0 otherwise. */
70 int is_empty_or_missing_file(const char *filename
);
78 * Issues an fsync against the specified file according to the specified mode.
80 * FSYNC_WRITEOUT_ONLY attempts to use interfaces available on some operating
81 * systems to flush the OS cache without issuing a flush command to the storage
82 * controller. If those interfaces are unavailable, the function fails with
85 * FSYNC_HARDWARE_FLUSH does an OS writeout and hardware flush to ensure that
86 * changes are durable. It is not expected to fail.
88 int git_fsync(int fd
, enum fsync_action action
);
91 * Writes out trace statistics for fsync using the trace2 API.
93 void trace_git_fsync_stats(void);
96 * Preserves errno, prints a message, but gives no warning for ENOENT.
97 * Returns 0 on success, which includes trying to unlink an object that does
100 int unlink_or_warn(const char *path
);
102 * Tries to unlink file. Returns 0 if unlink succeeded
103 * or the file already didn't exist. Returns -1 and
104 * appends a message to err suitable for
105 * 'error("%s", err->buf)' on error.
107 int unlink_or_msg(const char *file
, struct strbuf
*err
);
109 * Preserves errno, prints a message, but gives no warning for ENOENT.
110 * Returns 0 on success, which includes trying to remove a directory that does
113 int rmdir_or_warn(const char *path
);
115 * Calls the correct function out of {unlink,rmdir}_or_warn based on
116 * the supplied file mode.
118 int remove_or_warn(unsigned int mode
, const char *path
);
121 * Call access(2), but warn for any error except "missing file"
122 * (ENOENT or ENOTDIR).
124 #define ACCESS_EACCES_OK (1U << 0)
125 int access_or_warn(const char *path
, int mode
, unsigned flag
);
126 int access_or_die(const char *path
, int mode
, unsigned flag
);
128 /* Warn on an inaccessible file if errno indicates this is an error */
129 int warn_on_fopen_errors(const char *path
);
132 * Open with O_NOFOLLOW, or equivalent. Note that the fallback equivalent
133 * may be racy. Do not use this as protection against an attacker who can
134 * simultaneously create paths.
136 int open_nofollow(const char *path
, int flags
);
138 void sleep_millisec(int millisec
);
141 * Generate len bytes from the system cryptographically secure PRNG.
142 * Returns 0 on success and -1 on error, setting errno. The inability to
143 * satisfy the full request is an error.
145 int csprng_bytes(void *buf
, size_t len
);
147 #endif /* WRAPPER_H */