diff options
author | Ronnie Sahlberg <sahlberg@google.com> | 2014-07-16 20:20:36 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2014-10-15 19:47:21 +0200 |
commit | 9ccc0c089667e6dccc888590376f138521784e5e (patch) | |
tree | f51130e16fe3945b137f76ac5862a917ec45d6a9 /wrapper.c | |
parent | refs.c: lock_ref_sha1_basic is used for all refs (diff) | |
download | git-9ccc0c089667e6dccc888590376f138521784e5e.tar.xz git-9ccc0c089667e6dccc888590376f138521784e5e.zip |
wrapper.c: add a new function unlink_or_msg
This behaves like unlink_or_warn except that on failure it writes the message
to its 'err' argument, which the caller can display in an appropriate way or
ignore.
Signed-off-by: Ronnie Sahlberg <sahlberg@google.com>
Reviewed-by: Michael Haggerty <mhagger@alum.mit.edu>
Signed-off-by: Jonathan Nieder <jrnieder@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'wrapper.c')
-rw-r--r-- | wrapper.c | 14 |
1 files changed, 14 insertions, 0 deletions
@@ -475,6 +475,20 @@ static int warn_if_unremovable(const char *op, const char *file, int rc) return rc; } +int unlink_or_msg(const char *file, struct strbuf *err) +{ + int rc = unlink(file); + + assert(err); + + if (!rc || errno == ENOENT) + return 0; + + strbuf_addf(err, "unable to unlink %s: %s", + file, strerror(errno)); + return -1; +} + int unlink_or_warn(const char *file) { return warn_if_unremovable("unlink", file, unlink(file)); |