提交 63af4a84 编写于 作者: T Tobias Klauser 提交者: Junio C Hamano

strbuf: make stripspace() part of strbuf

This function is also used in other builtins than stripspace, so it
makes sense to have it in a more generic place.  Since it operates
on an strbuf and the function is declared in strbuf.h, move it to
strbuf.c and add the corresponding prefix to its name, just like
other API functions in the strbuf_* family.

Also switch all current users of stripspace() to the new function
name and keep a temporary wrapper inline function for any topic
branches still using stripspace().
Reviewed-by: NMatthieu Moy <Matthieu.Moy@imag.fr>
Signed-off-by: NTobias Klauser <tklauser@distanz.ch>
Signed-off-by: NJunio C Hamano <gitster@pobox.com>
上级 22f698cb
...@@ -1343,7 +1343,7 @@ static int parse_mail(struct am_state *state, const char *mail) ...@@ -1343,7 +1343,7 @@ static int parse_mail(struct am_state *state, const char *mail)
strbuf_addstr(&msg, "\n\n"); strbuf_addstr(&msg, "\n\n");
if (strbuf_read_file(&msg, am_path(state, "msg"), 0) < 0) if (strbuf_read_file(&msg, am_path(state, "msg"), 0) < 0)
die_errno(_("could not read '%s'"), am_path(state, "msg")); die_errno(_("could not read '%s'"), am_path(state, "msg"));
stripspace(&msg, 0); strbuf_stripspace(&msg, 0);
if (state->signoff) if (state->signoff)
am_signoff(&msg); am_signoff(&msg);
......
...@@ -786,7 +786,7 @@ static int edit_branch_description(const char *branch_name) ...@@ -786,7 +786,7 @@ static int edit_branch_description(const char *branch_name)
strbuf_release(&buf); strbuf_release(&buf);
return -1; return -1;
} }
stripspace(&buf, 1); strbuf_stripspace(&buf, 1);
strbuf_addf(&name, "branch.%s.description", branch_name); strbuf_addf(&name, "branch.%s.description", branch_name);
status = git_config_set(name.buf, buf.len ? buf.buf : NULL); status = git_config_set(name.buf, buf.len ? buf.buf : NULL);
......
...@@ -775,7 +775,7 @@ static int prepare_to_commit(const char *index_file, const char *prefix, ...@@ -775,7 +775,7 @@ static int prepare_to_commit(const char *index_file, const char *prefix,
s->hints = 0; s->hints = 0;
if (clean_message_contents) if (clean_message_contents)
stripspace(&sb, 0); strbuf_stripspace(&sb, 0);
if (signoff) if (signoff)
append_signoff(&sb, ignore_non_trailer(&sb), 0); append_signoff(&sb, ignore_non_trailer(&sb), 0);
...@@ -1014,7 +1014,7 @@ static int template_untouched(struct strbuf *sb) ...@@ -1014,7 +1014,7 @@ static int template_untouched(struct strbuf *sb)
if (!template_file || strbuf_read_file(&tmpl, template_file, 0) <= 0) if (!template_file || strbuf_read_file(&tmpl, template_file, 0) <= 0)
return 0; return 0;
stripspace(&tmpl, cleanup_mode == CLEANUP_ALL); strbuf_stripspace(&tmpl, cleanup_mode == CLEANUP_ALL);
if (!skip_prefix(sb->buf, tmpl.buf, &start)) if (!skip_prefix(sb->buf, tmpl.buf, &start))
start = sb->buf; start = sb->buf;
strbuf_release(&tmpl); strbuf_release(&tmpl);
...@@ -1726,7 +1726,7 @@ int cmd_commit(int argc, const char **argv, const char *prefix) ...@@ -1726,7 +1726,7 @@ int cmd_commit(int argc, const char **argv, const char *prefix)
wt_status_truncate_message_at_cut_line(&sb); wt_status_truncate_message_at_cut_line(&sb);
if (cleanup_mode != CLEANUP_NONE) if (cleanup_mode != CLEANUP_NONE)
stripspace(&sb, cleanup_mode == CLEANUP_ALL); strbuf_stripspace(&sb, cleanup_mode == CLEANUP_ALL);
if (template_untouched(&sb) && !allow_empty_message) { if (template_untouched(&sb) && !allow_empty_message) {
rollback_index_files(); rollback_index_files();
fprintf(stderr, _("Aborting commit; you did not edit the message.\n")); fprintf(stderr, _("Aborting commit; you did not edit the message.\n"));
......
...@@ -806,7 +806,7 @@ static void prepare_to_commit(struct commit_list *remoteheads) ...@@ -806,7 +806,7 @@ static void prepare_to_commit(struct commit_list *remoteheads)
abort_commit(remoteheads, NULL); abort_commit(remoteheads, NULL);
} }
read_merge_msg(&msg); read_merge_msg(&msg);
stripspace(&msg, 0 < option_edit); strbuf_stripspace(&msg, 0 < option_edit);
if (!msg.len) if (!msg.len)
abort_commit(remoteheads, _("Empty commit message.")); abort_commit(remoteheads, _("Empty commit message."));
strbuf_release(&merge_msg); strbuf_release(&merge_msg);
......
...@@ -192,7 +192,7 @@ static void prepare_note_data(const unsigned char *object, struct note_data *d, ...@@ -192,7 +192,7 @@ static void prepare_note_data(const unsigned char *object, struct note_data *d,
if (launch_editor(d->edit_path, &d->buf, NULL)) { if (launch_editor(d->edit_path, &d->buf, NULL)) {
die(_("Please supply the note contents using either -m or -F option")); die(_("Please supply the note contents using either -m or -F option"));
} }
stripspace(&d->buf, 1); strbuf_stripspace(&d->buf, 1);
} }
} }
...@@ -215,7 +215,7 @@ static int parse_msg_arg(const struct option *opt, const char *arg, int unset) ...@@ -215,7 +215,7 @@ static int parse_msg_arg(const struct option *opt, const char *arg, int unset)
if (d->buf.len) if (d->buf.len)
strbuf_addch(&d->buf, '\n'); strbuf_addch(&d->buf, '\n');
strbuf_addstr(&d->buf, arg); strbuf_addstr(&d->buf, arg);
stripspace(&d->buf, 0); strbuf_stripspace(&d->buf, 0);
d->given = 1; d->given = 1;
return 0; return 0;
...@@ -232,7 +232,7 @@ static int parse_file_arg(const struct option *opt, const char *arg, int unset) ...@@ -232,7 +232,7 @@ static int parse_file_arg(const struct option *opt, const char *arg, int unset)
die_errno(_("cannot read '%s'"), arg); die_errno(_("cannot read '%s'"), arg);
} else if (strbuf_read_file(&d->buf, arg, 1024) < 0) } else if (strbuf_read_file(&d->buf, arg, 1024) < 0)
die_errno(_("could not open or read '%s'"), arg); die_errno(_("could not open or read '%s'"), arg);
stripspace(&d->buf, 0); strbuf_stripspace(&d->buf, 0);
d->given = 1; d->given = 1;
return 0; return 0;
......
#include "builtin.h" #include "builtin.h"
#include "cache.h" #include "cache.h"
#include "strbuf.h"
/*
* Returns the length of a line, without trailing spaces.
*
* If the line ends with newline, it will be removed too.
*/
static size_t cleanup(char *line, size_t len)
{
while (len) {
unsigned char c = line[len - 1];
if (!isspace(c))
break;
len--;
}
return len;
}
/*
* Remove empty lines from the beginning and end
* and also trailing spaces from every line.
*
* Turn multiple consecutive empty lines between paragraphs
* into just one empty line.
*
* If the input has only empty lines and spaces,
* no output will be produced.
*
* If last line does not have a newline at the end, one is added.
*
* Enable skip_comments to skip every line starting with comment
* character.
*/
void stripspace(struct strbuf *sb, int skip_comments)
{
int empties = 0;
size_t i, j, len, newlen;
char *eol;
/* We may have to add a newline. */
strbuf_grow(sb, 1);
for (i = j = 0; i < sb->len; i += len, j += newlen) {
eol = memchr(sb->buf + i, '\n', sb->len - i);
len = eol ? eol - (sb->buf + i) + 1 : sb->len - i;
if (skip_comments && len && sb->buf[i] == comment_line_char) {
newlen = 0;
continue;
}
newlen = cleanup(sb->buf + i, len);
/* Not just an empty line? */
if (newlen) {
if (empties > 0 && j > 0)
sb->buf[j++] = '\n';
empties = 0;
memmove(sb->buf + j, sb->buf + i, newlen);
sb->buf[newlen + j++] = '\n';
} else {
empties++;
}
}
strbuf_setlen(sb, j);
}
static void comment_lines(struct strbuf *buf) static void comment_lines(struct strbuf *buf)
{ {
...@@ -111,7 +46,7 @@ int cmd_stripspace(int argc, const char **argv, const char *prefix) ...@@ -111,7 +46,7 @@ int cmd_stripspace(int argc, const char **argv, const char *prefix)
die_errno("could not read the input"); die_errno("could not read the input");
if (mode == STRIP_SPACE) if (mode == STRIP_SPACE)
stripspace(&buf, strip_comments); strbuf_stripspace(&buf, strip_comments);
else else
comment_lines(&buf); comment_lines(&buf);
......
...@@ -498,7 +498,7 @@ static void create_tag(const unsigned char *object, const char *tag, ...@@ -498,7 +498,7 @@ static void create_tag(const unsigned char *object, const char *tag,
} }
if (opt->cleanup_mode != CLEANUP_NONE) if (opt->cleanup_mode != CLEANUP_NONE)
stripspace(buf, opt->cleanup_mode == CLEANUP_ALL); strbuf_stripspace(buf, opt->cleanup_mode == CLEANUP_ALL);
if (!opt->message_given && !buf->len) if (!opt->message_given && !buf->len)
die(_("no tag message?")); die(_("no tag message?"));
......
...@@ -743,3 +743,69 @@ void strbuf_addftime(struct strbuf *sb, const char *fmt, const struct tm *tm) ...@@ -743,3 +743,69 @@ void strbuf_addftime(struct strbuf *sb, const char *fmt, const struct tm *tm)
} }
strbuf_setlen(sb, sb->len + len); strbuf_setlen(sb, sb->len + len);
} }
/*
* Returns the length of a line, without trailing spaces.
*
* If the line ends with newline, it will be removed too.
*/
static size_t cleanup(char *line, size_t len)
{
while (len) {
unsigned char c = line[len - 1];
if (!isspace(c))
break;
len--;
}
return len;
}
/*
* Remove empty lines from the beginning and end
* and also trailing spaces from every line.
*
* Turn multiple consecutive empty lines between paragraphs
* into just one empty line.
*
* If the input has only empty lines and spaces,
* no output will be produced.
*
* If last line does not have a newline at the end, one is added.
*
* Enable skip_comments to skip every line starting with comment
* character.
*/
void strbuf_stripspace(struct strbuf *sb, int skip_comments)
{
int empties = 0;
size_t i, j, len, newlen;
char *eol;
/* We may have to add a newline. */
strbuf_grow(sb, 1);
for (i = j = 0; i < sb->len; i += len, j += newlen) {
eol = memchr(sb->buf + i, '\n', sb->len - i);
len = eol ? eol - (sb->buf + i) + 1 : sb->len - i;
if (skip_comments && len && sb->buf[i] == comment_line_char) {
newlen = 0;
continue;
}
newlen = cleanup(sb->buf + i, len);
/* Not just an empty line? */
if (newlen) {
if (empties > 0 && j > 0)
sb->buf[j++] = '\n';
empties = 0;
memmove(sb->buf + j, sb->buf + i, newlen);
sb->buf[newlen + j++] = '\n';
} else {
empties++;
}
}
strbuf_setlen(sb, j);
}
...@@ -418,7 +418,16 @@ extern void strbuf_add_absolute_path(struct strbuf *sb, const char *path); ...@@ -418,7 +418,16 @@ extern void strbuf_add_absolute_path(struct strbuf *sb, const char *path);
* Strip whitespace from a buffer. The second parameter controls if * Strip whitespace from a buffer. The second parameter controls if
* comments are considered contents to be removed or not. * comments are considered contents to be removed or not.
*/ */
extern void stripspace(struct strbuf *buf, int skip_comments); extern void strbuf_stripspace(struct strbuf *buf, int skip_comments);
/**
* Temporary alias until all topic branches have switched to use
* strbuf_stripspace directly.
*/
static inline void stripspace(struct strbuf *buf, int skip_comments)
{
strbuf_stripspace(buf, skip_comments);
}
static inline int strbuf_strip_suffix(struct strbuf *sb, const char *suffix) static inline int strbuf_strip_suffix(struct strbuf *sb, const char *suffix)
{ {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册