summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@ppc970.osdl.org>2005-06-28 18:10:06 (GMT)
committerLinus Torvalds <torvalds@ppc970.osdl.org>2005-06-28 18:10:06 (GMT)
commit4397f0148ad0967cf3a2d794fb3d6b2c7f8738d7 (patch)
treeceb1717d793364c2d2d1bc96f6f949e5de5216e7
parent5571be75ebb6c8a1f88b3897d9631279106d8e0f (diff)
downloadgit-4397f0148ad0967cf3a2d794fb3d6b2c7f8738d7.zip
git-4397f0148ad0967cf3a2d794fb3d6b2c7f8738d7.tar.gz
git-4397f0148ad0967cf3a2d794fb3d6b2c7f8738d7.tar.bz2
csum-file: add "sha1fd()" to create a SHA1 csum file from an existing file descriptor
We'll use this soon to write pack-files to stdout.
-rw-r--r--csum-file.c20
-rw-r--r--csum-file.h1
2 files changed, 21 insertions, 0 deletions
diff --git a/csum-file.c b/csum-file.c
index 3ab65b7..c8c7369 100644
--- a/csum-file.c
+++ b/csum-file.c
@@ -96,6 +96,26 @@ struct sha1file *sha1create(const char *fmt, ...)
return f;
}
+struct sha1file *sha1fd(int fd, const char *name)
+{
+ struct sha1file *f;
+ unsigned len;
+
+ f = xmalloc(sizeof(*f));
+
+ len = strlen(name);
+ if (len >= PATH_MAX)
+ die("you wascally wabbit, you");
+ f->namelen = len;
+ memcpy(f->name, name, len+1);
+
+ f->fd = fd;
+ f->error = 0;
+ f->offset = 0;
+ SHA1_Init(&f->ctx);
+ return f;
+}
+
int sha1write_compressed(struct sha1file *f, void *in, unsigned int size)
{
z_stream stream;
diff --git a/csum-file.h b/csum-file.h
index 2b6c8dc..776cfb1 100644
--- a/csum-file.h
+++ b/csum-file.h
@@ -10,6 +10,7 @@ struct sha1file {
unsigned char buffer[8192];
};
+extern struct sha1file *sha1fd(int fd, const char *name);
extern struct sha1file *sha1create(const char *fmt, ...);
extern int sha1close(struct sha1file *, unsigned char *, int);
extern int sha1write(struct sha1file *, void *, unsigned int);