Simplify strbuf uses in archive-tar.c using strbuf API
This is just cleaner way to deal with strbufs, using its API rather than reinventing it in the module (e.g. strbuf_append_string is just the plain strbuf_addstr function, and it was used to perform what strbuf_addch does anyways). Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
b449f4cfc9
commit
7a604f16b7
@ -78,19 +78,6 @@ static void write_trailer(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void strbuf_append_string(struct strbuf *sb, const char *s)
|
|
||||||
{
|
|
||||||
int slen = strlen(s);
|
|
||||||
int total = sb->len + slen;
|
|
||||||
if (total + 1 > sb->alloc) {
|
|
||||||
sb->buf = xrealloc(sb->buf, total + 1);
|
|
||||||
sb->alloc = total + 1;
|
|
||||||
}
|
|
||||||
memcpy(sb->buf + sb->len, s, slen);
|
|
||||||
sb->len = total;
|
|
||||||
sb->buf[total] = '\0';
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* pax extended header records have the format "%u %s=%s\n". %u contains
|
* pax extended header records have the format "%u %s=%s\n". %u contains
|
||||||
* the size of the whole string (including the %u), the first %s is the
|
* the size of the whole string (including the %u), the first %s is the
|
||||||
@ -100,26 +87,17 @@ static void strbuf_append_string(struct strbuf *sb, const char *s)
|
|||||||
static void strbuf_append_ext_header(struct strbuf *sb, const char *keyword,
|
static void strbuf_append_ext_header(struct strbuf *sb, const char *keyword,
|
||||||
const char *value, unsigned int valuelen)
|
const char *value, unsigned int valuelen)
|
||||||
{
|
{
|
||||||
char *p;
|
int len, tmp;
|
||||||
int len, total, tmp;
|
|
||||||
|
|
||||||
/* "%u %s=%s\n" */
|
/* "%u %s=%s\n" */
|
||||||
len = 1 + 1 + strlen(keyword) + 1 + valuelen + 1;
|
len = 1 + 1 + strlen(keyword) + 1 + valuelen + 1;
|
||||||
for (tmp = len; tmp > 9; tmp /= 10)
|
for (tmp = len; tmp > 9; tmp /= 10)
|
||||||
len++;
|
len++;
|
||||||
|
|
||||||
total = sb->len + len;
|
strbuf_grow(sb, len);
|
||||||
if (total > sb->alloc) {
|
strbuf_addf(sb, "%u %s=", len, keyword);
|
||||||
sb->buf = xrealloc(sb->buf, total);
|
strbuf_add(sb, value, valuelen);
|
||||||
sb->alloc = total;
|
strbuf_addch(sb, '\n');
|
||||||
}
|
|
||||||
|
|
||||||
p = sb->buf;
|
|
||||||
p += sprintf(p, "%u %s=", len, keyword);
|
|
||||||
memcpy(p, value, valuelen);
|
|
||||||
p += valuelen;
|
|
||||||
*p = '\n';
|
|
||||||
sb->len = total;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static unsigned int ustar_header_chksum(const struct ustar_header *header)
|
static unsigned int ustar_header_chksum(const struct ustar_header *header)
|
||||||
@ -153,8 +131,7 @@ static void write_entry(const unsigned char *sha1, struct strbuf *path,
|
|||||||
struct strbuf ext_header;
|
struct strbuf ext_header;
|
||||||
|
|
||||||
memset(&header, 0, sizeof(header));
|
memset(&header, 0, sizeof(header));
|
||||||
ext_header.buf = NULL;
|
strbuf_init(&ext_header);
|
||||||
ext_header.len = ext_header.alloc = 0;
|
|
||||||
|
|
||||||
if (!sha1) {
|
if (!sha1) {
|
||||||
*header.typeflag = TYPEFLAG_GLOBAL_HEADER;
|
*header.typeflag = TYPEFLAG_GLOBAL_HEADER;
|
||||||
@ -225,8 +202,8 @@ static void write_entry(const unsigned char *sha1, struct strbuf *path,
|
|||||||
|
|
||||||
if (ext_header.len > 0) {
|
if (ext_header.len > 0) {
|
||||||
write_entry(sha1, NULL, 0, ext_header.buf, ext_header.len);
|
write_entry(sha1, NULL, 0, ext_header.buf, ext_header.len);
|
||||||
free(ext_header.buf);
|
|
||||||
}
|
}
|
||||||
|
strbuf_release(&ext_header);
|
||||||
write_blocked(&header, sizeof(header));
|
write_blocked(&header, sizeof(header));
|
||||||
if (S_ISREG(mode) && buffer && size > 0)
|
if (S_ISREG(mode) && buffer && size > 0)
|
||||||
write_blocked(buffer, size);
|
write_blocked(buffer, size);
|
||||||
@ -235,11 +212,11 @@ static void write_entry(const unsigned char *sha1, struct strbuf *path,
|
|||||||
static void write_global_extended_header(const unsigned char *sha1)
|
static void write_global_extended_header(const unsigned char *sha1)
|
||||||
{
|
{
|
||||||
struct strbuf ext_header;
|
struct strbuf ext_header;
|
||||||
ext_header.buf = NULL;
|
|
||||||
ext_header.len = ext_header.alloc = 0;
|
strbuf_init(&ext_header);
|
||||||
strbuf_append_ext_header(&ext_header, "comment", sha1_to_hex(sha1), 40);
|
strbuf_append_ext_header(&ext_header, "comment", sha1_to_hex(sha1), 40);
|
||||||
write_entry(NULL, NULL, 0, ext_header.buf, ext_header.len);
|
write_entry(NULL, NULL, 0, ext_header.buf, ext_header.len);
|
||||||
free(ext_header.buf);
|
strbuf_release(&ext_header);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int git_tar_config(const char *var, const char *value)
|
static int git_tar_config(const char *var, const char *value)
|
||||||
@ -260,28 +237,18 @@ static int write_tar_entry(const unsigned char *sha1,
|
|||||||
const char *base, int baselen,
|
const char *base, int baselen,
|
||||||
const char *filename, unsigned mode, int stage)
|
const char *filename, unsigned mode, int stage)
|
||||||
{
|
{
|
||||||
static struct strbuf path;
|
static struct strbuf path = STRBUF_INIT;
|
||||||
int filenamelen = strlen(filename);
|
int filenamelen = strlen(filename);
|
||||||
void *buffer;
|
void *buffer;
|
||||||
enum object_type type;
|
enum object_type type;
|
||||||
unsigned long size;
|
unsigned long size;
|
||||||
|
|
||||||
if (!path.alloc) {
|
strbuf_grow(&path, MAX(PATH_MAX, baselen + filenamelen + 1));
|
||||||
path.buf = xmalloc(PATH_MAX);
|
strbuf_reset(&path);
|
||||||
path.alloc = PATH_MAX;
|
strbuf_add(&path, base, baselen);
|
||||||
path.len = path.eof = 0;
|
strbuf_add(&path, filename, filenamelen);
|
||||||
}
|
|
||||||
if (path.alloc < baselen + filenamelen + 1) {
|
|
||||||
free(path.buf);
|
|
||||||
path.buf = xmalloc(baselen + filenamelen + 1);
|
|
||||||
path.alloc = baselen + filenamelen + 1;
|
|
||||||
}
|
|
||||||
memcpy(path.buf, base, baselen);
|
|
||||||
memcpy(path.buf + baselen, filename, filenamelen);
|
|
||||||
path.len = baselen + filenamelen;
|
|
||||||
path.buf[path.len] = '\0';
|
|
||||||
if (S_ISDIR(mode) || S_ISGITLINK(mode)) {
|
if (S_ISDIR(mode) || S_ISGITLINK(mode)) {
|
||||||
strbuf_append_string(&path, "/");
|
strbuf_addch(&path, '/');
|
||||||
buffer = NULL;
|
buffer = NULL;
|
||||||
size = 0;
|
size = 0;
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user