Function stripspace now gets a buffer instead file descriptors.
An implementation easier to call from builtins. It is designed to be used from the upcoming builtin-tag.c and builtin-commit.c, because both need to remove unwanted spaces from messages. Signed-off-by: Carlos Rica <jasampler@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>maint
parent
73f8936050
commit
975e0daf5e
|
@ -2,12 +2,11 @@
|
||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Remove trailing spaces from a line.
|
* Returns the length of a line, without trailing spaces.
|
||||||
*
|
*
|
||||||
* If the line ends with newline, it will be removed too.
|
* If the line ends with newline, it will be removed too.
|
||||||
* Returns the new length of the string.
|
|
||||||
*/
|
*/
|
||||||
static int cleanup(char *line, int len)
|
static size_t cleanup(char *line, size_t len)
|
||||||
{
|
{
|
||||||
if (len) {
|
if (len) {
|
||||||
if (line[len - 1] == '\n')
|
if (line[len - 1] == '\n')
|
||||||
|
@ -19,7 +18,6 @@ static int cleanup(char *line, int len)
|
||||||
break;
|
break;
|
||||||
len--;
|
len--;
|
||||||
}
|
}
|
||||||
line[len] = 0;
|
|
||||||
}
|
}
|
||||||
return len;
|
return len;
|
||||||
}
|
}
|
||||||
|
@ -28,52 +26,67 @@ static int cleanup(char *line, int len)
|
||||||
* Remove empty lines from the beginning and end
|
* Remove empty lines from the beginning and end
|
||||||
* and also trailing spaces from every line.
|
* and also trailing spaces from every line.
|
||||||
*
|
*
|
||||||
|
* Note that the buffer will not be NUL-terminated.
|
||||||
|
*
|
||||||
* Turn multiple consecutive empty lines between paragraphs
|
* Turn multiple consecutive empty lines between paragraphs
|
||||||
* into just one empty line.
|
* into just one empty line.
|
||||||
*
|
*
|
||||||
* If the input has only empty lines and spaces,
|
* If the input has only empty lines and spaces,
|
||||||
* no output will be produced.
|
* no output will be produced.
|
||||||
*
|
*
|
||||||
|
* If last line has a newline at the end, it will be removed.
|
||||||
|
*
|
||||||
* Enable skip_comments to skip every line starting with "#".
|
* Enable skip_comments to skip every line starting with "#".
|
||||||
*/
|
*/
|
||||||
void stripspace(FILE *in, FILE *out, int skip_comments)
|
size_t stripspace(char *buffer, size_t length, int skip_comments)
|
||||||
{
|
{
|
||||||
int empties = -1;
|
int empties = -1;
|
||||||
int alloc = 1024;
|
size_t i, j, len, newlen;
|
||||||
char *line = xmalloc(alloc);
|
char *eol;
|
||||||
|
|
||||||
while (fgets(line, alloc, in)) {
|
for (i = j = 0; i < length; i += len, j += newlen) {
|
||||||
int len = strlen(line);
|
eol = memchr(buffer + i, '\n', length - i);
|
||||||
|
len = eol ? eol - (buffer + i) + 1 : length - i;
|
||||||
|
|
||||||
while (len == alloc - 1 && line[len - 1] != '\n') {
|
if (skip_comments && len && buffer[i] == '#') {
|
||||||
alloc = alloc_nr(alloc);
|
newlen = 0;
|
||||||
line = xrealloc(line, alloc);
|
|
||||||
fgets(line + len, alloc - len, in);
|
|
||||||
len += strlen(line + len);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (skip_comments && line[0] == '#')
|
|
||||||
continue;
|
continue;
|
||||||
len = cleanup(line, len);
|
}
|
||||||
|
newlen = cleanup(buffer + i, len);
|
||||||
|
|
||||||
/* Not just an empty line? */
|
/* Not just an empty line? */
|
||||||
if (len) {
|
if (newlen) {
|
||||||
|
if (empties != -1)
|
||||||
|
buffer[j++] = '\n';
|
||||||
if (empties > 0)
|
if (empties > 0)
|
||||||
fputc('\n', out);
|
buffer[j++] = '\n';
|
||||||
empties = 0;
|
empties = 0;
|
||||||
fputs(line, out);
|
memmove(buffer + j, buffer + i, newlen);
|
||||||
fputc('\n', out);
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (empties < 0)
|
if (empties < 0)
|
||||||
continue;
|
continue;
|
||||||
empties++;
|
empties++;
|
||||||
}
|
}
|
||||||
free(line);
|
|
||||||
|
return j;
|
||||||
}
|
}
|
||||||
|
|
||||||
int cmd_stripspace(int argc, const char **argv, const char *prefix)
|
int cmd_stripspace(int argc, const char **argv, const char *prefix)
|
||||||
{
|
{
|
||||||
stripspace(stdin, stdout, 0);
|
char *buffer;
|
||||||
|
unsigned long size;
|
||||||
|
|
||||||
|
size = 1024;
|
||||||
|
buffer = xmalloc(size);
|
||||||
|
if (read_pipe(0, &buffer, &size))
|
||||||
|
die("could not read the input");
|
||||||
|
|
||||||
|
size = stripspace(buffer, size, 0);
|
||||||
|
write_or_die(1, buffer, size);
|
||||||
|
if (size)
|
||||||
|
putc('\n', stdout);
|
||||||
|
|
||||||
|
free(buffer);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,7 +7,7 @@ extern const char git_version_string[];
|
||||||
extern const char git_usage_string[];
|
extern const char git_usage_string[];
|
||||||
|
|
||||||
extern void help_unknown_cmd(const char *cmd);
|
extern void help_unknown_cmd(const char *cmd);
|
||||||
extern void stripspace(FILE *in, FILE *out, int skip_comments);
|
extern size_t stripspace(char *buffer, size_t length, int skip_comments);
|
||||||
extern int write_tree(unsigned char *sha1, int missing_ok, const char *prefix);
|
extern int write_tree(unsigned char *sha1, int missing_ok, const char *prefix);
|
||||||
extern void prune_packed_objects(int);
|
extern void prune_packed_objects(int);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue