Skip to content

Commit

Permalink
strbuf: retire strbuf_commented_lines()
Browse files Browse the repository at this point in the history
The API allows the caller to pass any string as the comment prefix,
but in reality, everybody passes the comment_line_str from the
environment.

Replace this overly flexible API with strbuf_comment_lines() that
does not allow customization of the comment_line_str (usually '#'
but can be configured via the core.commentChar).

Signed-off-by: Junio C Hamano <[email protected]>
  • Loading branch information
gitster committed Sep 12, 2024
1 parent f3582c0 commit 19e27e2
Show file tree
Hide file tree
Showing 8 changed files with 28 additions and 37 deletions.
10 changes: 5 additions & 5 deletions builtin/notes.c
Original file line number Diff line number Diff line change
Expand Up @@ -178,7 +178,7 @@ static void write_commented_object(int fd, const struct object_id *object)

if (strbuf_read(&buf, show.out, 0) < 0)
die_errno(_("could not read 'show' output"));
strbuf_add_commented_lines(&cbuf, buf.buf, buf.len, comment_line_str);
strbuf_add_comment_lines(&cbuf, buf.buf, buf.len);
write_or_die(fd, cbuf.buf, cbuf.len);

strbuf_release(&cbuf);
Expand Down Expand Up @@ -206,10 +206,10 @@ static void prepare_note_data(const struct object_id *object, struct note_data *
copy_obj_to_fd(fd, old_note);

strbuf_addch(&buf, '\n');
strbuf_add_commented_lines(&buf, "\n", strlen("\n"), comment_line_str);
strbuf_add_commented_lines(&buf, _(note_template), strlen(_(note_template)),
comment_line_str);
strbuf_add_commented_lines(&buf, "\n", strlen("\n"), comment_line_str);
strbuf_add_comment_lines(&buf, "\n", strlen("\n"));
strbuf_add_comment_lines(&buf, _(note_template),
strlen(_(note_template)));
strbuf_add_comment_lines(&buf, "\n", strlen("\n"));
write_or_die(fd, buf.buf, buf.len);

write_commented_object(fd, object);
Expand Down
2 changes: 1 addition & 1 deletion builtin/stripspace.c
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ static void comment_lines(struct strbuf *buf)
size_t len;

msg = strbuf_detach(buf, &len);
strbuf_add_commented_lines(buf, msg, len, comment_line_str);
strbuf_add_comment_lines(buf, msg, len);
free(msg);
}

Expand Down
17 changes: 7 additions & 10 deletions fmt-merge-msg.c
Original file line number Diff line number Diff line change
Expand Up @@ -511,8 +511,7 @@ static void fmt_tag_signature(struct strbuf *tagbuf,
strbuf_complete_line(tagbuf);
if (sig->len) {
strbuf_addch(tagbuf, '\n');
strbuf_add_commented_lines(tagbuf, sig->buf, sig->len,
comment_line_str);
strbuf_add_comment_lines(tagbuf, sig->buf, sig->len);
}
}

Expand Down Expand Up @@ -556,19 +555,17 @@ static void fmt_merge_msg_sigs(struct strbuf *out)
if (tag_number == 2) {
struct strbuf tagline = STRBUF_INIT;
strbuf_addch(&tagline, '\n');
strbuf_add_commented_lines(&tagline,
origins.items[first_tag].string,
strlen(origins.items[first_tag].string),
comment_line_str);
strbuf_add_comment_lines(&tagline,
origins.items[first_tag].string,
strlen(origins.items[first_tag].string));
strbuf_insert(&tagbuf, 0, tagline.buf,
tagline.len);
strbuf_release(&tagline);
}
strbuf_addch(&tagbuf, '\n');
strbuf_add_commented_lines(&tagbuf,
origins.items[i].string,
strlen(origins.items[i].string),
comment_line_str);
strbuf_add_comment_lines(&tagbuf,
origins.items[i].string,
strlen(origins.items[i].string));
fmt_tag_signature(&tagbuf, &sig, buf, len);
}
strbuf_release(&payload);
Expand Down
6 changes: 3 additions & 3 deletions rebase-interactive.c
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,7 @@ void append_todo_help(int command_count,
shortrevisions, shortonto, command_count);
}

strbuf_add_commented_lines(buf, msg, strlen(msg), comment_line_str);
strbuf_add_comment_lines(buf, msg, strlen(msg));

if (get_missing_commit_check_level() == MISSING_COMMIT_CHECK_ERROR)
msg = _("\nDo not remove any line. Use 'drop' "
Expand All @@ -89,7 +89,7 @@ void append_todo_help(int command_count,
msg = _("\nIf you remove a line here "
"THAT COMMIT WILL BE LOST.\n");

strbuf_add_commented_lines(buf, msg, strlen(msg), comment_line_str);
strbuf_add_comment_lines(buf, msg, strlen(msg));

if (edit_todo)
msg = _("\nYou are editing the todo file "
Expand All @@ -100,7 +100,7 @@ void append_todo_help(int command_count,
msg = _("\nHowever, if you remove everything, "
"the rebase will be aborted.\n\n");

strbuf_add_commented_lines(buf, msg, strlen(msg), comment_line_str);
strbuf_add_comment_lines(buf, msg, strlen(msg));
}

int edit_todo_list(struct repository *r, struct replay_opts *opts,
Expand Down
12 changes: 5 additions & 7 deletions sequencer.c
Original file line number Diff line number Diff line change
Expand Up @@ -1911,7 +1911,7 @@ static int is_fixup_flag(enum todo_command command, unsigned flag)
}

/*
* Wrapper around strbuf_add_commented_lines() which avoids double
* Wrapper around strbuf_add_comment_lines() which avoids double
* commenting commit subjects.
*/
static void add_commented_lines(struct strbuf *buf, const void *str, size_t len)
Expand All @@ -1928,7 +1928,7 @@ static void add_commented_lines(struct strbuf *buf, const void *str, size_t len)
s += count;
len -= count;
}
strbuf_add_commented_lines(buf, s, len, comment_line_str);
strbuf_add_comment_lines(buf, s, len);
}

/* Does the current fixup chain contain a squash command? */
Expand Down Expand Up @@ -2028,7 +2028,7 @@ static int append_squash_message(struct strbuf *buf, const char *body,
strbuf_addf(buf, _(nth_commit_msg_fmt),
++ctx->current_fixup_count + 1);
strbuf_addstr(buf, "\n\n");
strbuf_add_commented_lines(buf, body, commented_len, comment_line_str);
strbuf_add_comment_lines(buf, body, commented_len);
/* buf->buf may be reallocated so store an offset into the buffer */
fixup_off = buf->len;
strbuf_addstr(buf, body + commented_len);
Expand Down Expand Up @@ -2119,8 +2119,7 @@ static int update_squash_messages(struct repository *r,
_(first_commit_msg_str));
strbuf_addstr(&buf, "\n\n");
if (is_fixup_flag(command, flag))
strbuf_add_commented_lines(&buf, body, strlen(body),
comment_line_str);
strbuf_add_comment_lines(&buf, body, strlen(body));
else
strbuf_addstr(&buf, body);

Expand All @@ -2139,8 +2138,7 @@ static int update_squash_messages(struct repository *r,
strbuf_addf(&buf, _(skip_nth_commit_msg_fmt),
++ctx->current_fixup_count + 1);
strbuf_addstr(&buf, "\n\n");
strbuf_add_commented_lines(&buf, body, strlen(body),
comment_line_str);
strbuf_add_comment_lines(&buf, body, strlen(body));
} else
return error(_("unknown command: %d"), command);
repo_unuse_commit_buffer(r, commit, message);
Expand Down
7 changes: 3 additions & 4 deletions strbuf.c
Original file line number Diff line number Diff line change
Expand Up @@ -379,10 +379,9 @@ static void add_lines(struct strbuf *out,
strbuf_complete_line(out);
}

void strbuf_add_commented_lines(struct strbuf *out, const char *buf,
size_t size, const char *comment_prefix)
void strbuf_add_comment_lines(struct strbuf *out, const char *buf, size_t size)
{
add_lines(out, comment_prefix, buf, size, 1);
add_lines(out, comment_line_str, buf, size, 1);
}

void strbuf_comment_addf(struct strbuf *sb, const char *fmt, ...)
Expand All @@ -395,7 +394,7 @@ void strbuf_comment_addf(struct strbuf *sb, const char *fmt, ...)
strbuf_vaddf(&buf, fmt, params);
va_end(params);

strbuf_add_commented_lines(sb, buf.buf, buf.len, comment_line_str);
strbuf_add_comment_lines(sb, buf.buf, buf.len);
if (incomplete_line)
sb->buf[--sb->len] = '\0';

Expand Down
7 changes: 2 additions & 5 deletions strbuf.h
Original file line number Diff line number Diff line change
Expand Up @@ -284,12 +284,9 @@ void strbuf_splice(struct strbuf *sb, size_t pos, size_t len,

/**
* Add a NUL-terminated string to the buffer. Each line will be prepended
* by a comment character and a blank.
* by the comment character and a blank.
*/
void strbuf_add_commented_lines(struct strbuf *out,
const char *buf, size_t size,
const char *comment_prefix);

void strbuf_add_comment_lines(struct strbuf *out, const char *buf, size_t size);

/**
* Add data of given length to the buffer.
Expand Down
4 changes: 2 additions & 2 deletions wt-status.c
Original file line number Diff line number Diff line change
Expand Up @@ -1033,7 +1033,7 @@ static void wt_longstatus_print_submodule_summary(struct wt_status *s, int uncom
if (s->display_comment_prefix) {
size_t len;
summary_content = strbuf_detach(&summary, &len);
strbuf_add_commented_lines(&summary, summary_content, len, comment_line_str);
strbuf_add_comment_lines(&summary, summary_content, len);
free(summary_content);
}

Expand Down Expand Up @@ -1112,7 +1112,7 @@ void wt_status_append_cut_line(struct strbuf *buf)
const char *explanation = _("Do not modify or remove the line above.\nEverything below it will be ignored.");

strbuf_comment_addf(buf, "%s", cut_line);
strbuf_add_commented_lines(buf, explanation, strlen(explanation), comment_line_str);
strbuf_add_comment_lines(buf, explanation, strlen(explanation));
}

void wt_status_add_cut_line(struct wt_status *s)
Expand Down

0 comments on commit 19e27e2

Please sign in to comment.