write_file(): drop "fatal" parameter
All callers except three passed 1 for the "fatal" parameter to ask this function to die upon error, but to a casual reader of the code, it was not all obvious what that 1 meant. Instead, split the function into two based on a common write_file_v() that takes the flag, introduce write_file_gently() as a new way to attempt creating a file without dying on error, and make three callers to call it. Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
57c867efe4
commit
12d6ce1dba
@ -205,13 +205,13 @@ static int write_state_text(const struct am_state *state,
|
|||||||
fmt = "%s\n";
|
fmt = "%s\n";
|
||||||
else
|
else
|
||||||
fmt = "%s";
|
fmt = "%s";
|
||||||
return write_file(am_path(state, name), 1, fmt, string);
|
return write_file(am_path(state, name), fmt, string);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int write_state_count(const struct am_state *state,
|
static int write_state_count(const struct am_state *state,
|
||||||
const char *name, int value)
|
const char *name, int value)
|
||||||
{
|
{
|
||||||
return write_file(am_path(state, name), 1, "%d\n", value);
|
return write_file(am_path(state, name), "%d\n", value);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int write_state_bool(const struct am_state *state,
|
static int write_state_bool(const struct am_state *state,
|
||||||
|
@ -776,7 +776,7 @@ static int edit_branch_description(const char *branch_name)
|
|||||||
" %s\n"
|
" %s\n"
|
||||||
"Lines starting with '%c' will be stripped.\n",
|
"Lines starting with '%c' will be stripped.\n",
|
||||||
branch_name, comment_line_char);
|
branch_name, comment_line_char);
|
||||||
if (write_file(git_path(edit_description), 0, "%s", buf.buf)) {
|
if (write_file_gently(git_path(edit_description), "%s", buf.buf)) {
|
||||||
strbuf_release(&buf);
|
strbuf_release(&buf);
|
||||||
return error(_("could not write branch description template: %s"),
|
return error(_("could not write branch description template: %s"),
|
||||||
strerror(errno));
|
strerror(errno));
|
||||||
|
@ -378,7 +378,7 @@ static void separate_git_dir(const char *git_dir)
|
|||||||
die_errno(_("unable to move %s to %s"), src, git_dir);
|
die_errno(_("unable to move %s to %s"), src, git_dir);
|
||||||
}
|
}
|
||||||
|
|
||||||
write_file(git_link, 1, "gitdir: %s\n", git_dir);
|
write_file(git_link, "gitdir: %s\n", git_dir);
|
||||||
}
|
}
|
||||||
|
|
||||||
int init_db(const char *template_dir, unsigned int flags)
|
int init_db(const char *template_dir, unsigned int flags)
|
||||||
|
@ -213,7 +213,7 @@ static int add_worktree(const char *path, const char **child_argv)
|
|||||||
* after the preparation is over.
|
* after the preparation is over.
|
||||||
*/
|
*/
|
||||||
strbuf_addf(&sb, "%s/locked", sb_repo.buf);
|
strbuf_addf(&sb, "%s/locked", sb_repo.buf);
|
||||||
write_file(sb.buf, 1, "initializing\n");
|
write_file(sb.buf, "initializing\n");
|
||||||
|
|
||||||
strbuf_addf(&sb_git, "%s/.git", path);
|
strbuf_addf(&sb_git, "%s/.git", path);
|
||||||
if (safe_create_leading_directories_const(sb_git.buf))
|
if (safe_create_leading_directories_const(sb_git.buf))
|
||||||
@ -223,8 +223,8 @@ static int add_worktree(const char *path, const char **child_argv)
|
|||||||
|
|
||||||
strbuf_reset(&sb);
|
strbuf_reset(&sb);
|
||||||
strbuf_addf(&sb, "%s/gitdir", sb_repo.buf);
|
strbuf_addf(&sb, "%s/gitdir", sb_repo.buf);
|
||||||
write_file(sb.buf, 1, "%s\n", real_path(sb_git.buf));
|
write_file(sb.buf, "%s\n", real_path(sb_git.buf));
|
||||||
write_file(sb_git.buf, 1, "gitdir: %s/worktrees/%s\n",
|
write_file(sb_git.buf, "gitdir: %s/worktrees/%s\n",
|
||||||
real_path(get_git_common_dir()), name);
|
real_path(get_git_common_dir()), name);
|
||||||
/*
|
/*
|
||||||
* This is to keep resolve_ref() happy. We need a valid HEAD
|
* This is to keep resolve_ref() happy. We need a valid HEAD
|
||||||
@ -241,10 +241,10 @@ static int add_worktree(const char *path, const char **child_argv)
|
|||||||
die(_("unable to resolve HEAD"));
|
die(_("unable to resolve HEAD"));
|
||||||
strbuf_reset(&sb);
|
strbuf_reset(&sb);
|
||||||
strbuf_addf(&sb, "%s/HEAD", sb_repo.buf);
|
strbuf_addf(&sb, "%s/HEAD", sb_repo.buf);
|
||||||
write_file(sb.buf, 1, "%s\n", sha1_to_hex(rev));
|
write_file(sb.buf, "%s\n", sha1_to_hex(rev));
|
||||||
strbuf_reset(&sb);
|
strbuf_reset(&sb);
|
||||||
strbuf_addf(&sb, "%s/commondir", sb_repo.buf);
|
strbuf_addf(&sb, "%s/commondir", sb_repo.buf);
|
||||||
write_file(sb.buf, 1, "../..\n");
|
write_file(sb.buf, "../..\n");
|
||||||
|
|
||||||
fprintf_ln(stderr, _("Enter %s (identifier %s)"), path, name);
|
fprintf_ln(stderr, _("Enter %s (identifier %s)"), path, name);
|
||||||
|
|
||||||
|
5
cache.h
5
cache.h
@ -1539,8 +1539,9 @@ static inline ssize_t write_str_in_full(int fd, const char *str)
|
|||||||
{
|
{
|
||||||
return write_in_full(fd, str, strlen(str));
|
return write_in_full(fd, str, strlen(str));
|
||||||
}
|
}
|
||||||
__attribute__((format (printf, 3, 4)))
|
|
||||||
extern int write_file(const char *path, int fatal, const char *fmt, ...);
|
extern int write_file(const char *path, const char *fmt, ...);
|
||||||
|
extern int write_file_gently(const char *path, const char *fmt, ...);
|
||||||
|
|
||||||
/* pager.c */
|
/* pager.c */
|
||||||
extern void setup_pager(void);
|
extern void setup_pager(void);
|
||||||
|
2
daemon.c
2
daemon.c
@ -1376,7 +1376,7 @@ int main(int argc, char **argv)
|
|||||||
sanitize_stdfds();
|
sanitize_stdfds();
|
||||||
|
|
||||||
if (pid_file)
|
if (pid_file)
|
||||||
write_file(pid_file, 1, "%"PRIuMAX"\n", (uintmax_t) getpid());
|
write_file(pid_file, "%"PRIuMAX"\n", (uintmax_t) getpid());
|
||||||
|
|
||||||
/* prepare argv for serving-processes */
|
/* prepare argv for serving-processes */
|
||||||
cld_argv = xmalloc(sizeof (char *) * (argc + 2));
|
cld_argv = xmalloc(sizeof (char *) * (argc + 2));
|
||||||
|
2
setup.c
2
setup.c
@ -404,7 +404,7 @@ static void update_linked_gitdir(const char *gitfile, const char *gitdir)
|
|||||||
|
|
||||||
strbuf_addf(&path, "%s/gitfile", gitdir);
|
strbuf_addf(&path, "%s/gitfile", gitdir);
|
||||||
if (stat(path.buf, &st) || st.st_mtime + 24 * 3600 < time(NULL))
|
if (stat(path.buf, &st) || st.st_mtime + 24 * 3600 < time(NULL))
|
||||||
write_file(path.buf, 0, "%s\n", gitfile);
|
write_file_gently(path.buf, "%s\n", gitfile);
|
||||||
strbuf_release(&path);
|
strbuf_release(&path);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1103,7 +1103,7 @@ void connect_work_tree_and_git_dir(const char *work_tree, const char *git_dir)
|
|||||||
|
|
||||||
/* Update gitfile */
|
/* Update gitfile */
|
||||||
strbuf_addf(&file_name, "%s/.git", work_tree);
|
strbuf_addf(&file_name, "%s/.git", work_tree);
|
||||||
write_file(file_name.buf, 1, "gitdir: %s\n",
|
write_file(file_name.buf, "gitdir: %s\n",
|
||||||
relative_path(git_dir, real_work_tree, &rel_path));
|
relative_path(git_dir, real_work_tree, &rel_path));
|
||||||
|
|
||||||
/* Update core.worktree setting */
|
/* Update core.worktree setting */
|
||||||
|
@ -291,7 +291,7 @@ static int write_one_ref(const char *name, const struct object_id *oid,
|
|||||||
|
|
||||||
strbuf_addstr(buf, name);
|
strbuf_addstr(buf, name);
|
||||||
if (safe_create_leading_directories(buf->buf) ||
|
if (safe_create_leading_directories(buf->buf) ||
|
||||||
write_file(buf->buf, 0, "%s\n", oid_to_hex(oid)))
|
write_file_gently(buf->buf, "%s\n", oid_to_hex(oid)))
|
||||||
return error("problems writing temporary file %s: %s",
|
return error("problems writing temporary file %s: %s",
|
||||||
buf->buf, strerror(errno));
|
buf->buf, strerror(errno));
|
||||||
strbuf_setlen(buf, len);
|
strbuf_setlen(buf, len);
|
||||||
|
28
wrapper.c
28
wrapper.c
@ -621,19 +621,17 @@ char *xgetcwd(void)
|
|||||||
return strbuf_detach(&sb, NULL);
|
return strbuf_detach(&sb, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
int write_file(const char *path, int fatal, const char *fmt, ...)
|
static int write_file_v(const char *path, int fatal,
|
||||||
|
const char *fmt, va_list params)
|
||||||
{
|
{
|
||||||
struct strbuf sb = STRBUF_INIT;
|
struct strbuf sb = STRBUF_INIT;
|
||||||
va_list params;
|
|
||||||
int fd = open(path, O_RDWR | O_CREAT | O_TRUNC, 0666);
|
int fd = open(path, O_RDWR | O_CREAT | O_TRUNC, 0666);
|
||||||
if (fd < 0) {
|
if (fd < 0) {
|
||||||
if (fatal)
|
if (fatal)
|
||||||
die_errno(_("could not open %s for writing"), path);
|
die_errno(_("could not open %s for writing"), path);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
va_start(params, fmt);
|
|
||||||
strbuf_vaddf(&sb, fmt, params);
|
strbuf_vaddf(&sb, fmt, params);
|
||||||
va_end(params);
|
|
||||||
if (write_in_full(fd, sb.buf, sb.len) != sb.len) {
|
if (write_in_full(fd, sb.buf, sb.len) != sb.len) {
|
||||||
int err = errno;
|
int err = errno;
|
||||||
close(fd);
|
close(fd);
|
||||||
@ -652,6 +650,28 @@ int write_file(const char *path, int fatal, const char *fmt, ...)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int write_file(const char *path, const char *fmt, ...)
|
||||||
|
{
|
||||||
|
int status;
|
||||||
|
va_list params;
|
||||||
|
|
||||||
|
va_start(params, fmt);
|
||||||
|
status = write_file_v(path, 1, fmt, params);
|
||||||
|
va_end(params);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
int write_file_gently(const char *path, const char *fmt, ...)
|
||||||
|
{
|
||||||
|
int status;
|
||||||
|
va_list params;
|
||||||
|
|
||||||
|
va_start(params, fmt);
|
||||||
|
status = write_file_v(path, 0, fmt, params);
|
||||||
|
va_end(params);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
void sleep_millisec(int millisec)
|
void sleep_millisec(int millisec)
|
||||||
{
|
{
|
||||||
poll(NULL, 0, millisec);
|
poll(NULL, 0, millisec);
|
||||||
|
Loading…
Reference in New Issue
Block a user