verify-tag: factor out signature detection
into tag.h/c for later reuse and modification. Signed-off-by: Michael J Gruber <git@drmicha.warpmail.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
c8525c302b
commit
ac58c4c795
@ -17,13 +17,11 @@ static const char * const verify_tag_usage[] = {
|
|||||||
NULL
|
NULL
|
||||||
};
|
};
|
||||||
|
|
||||||
#define PGP_SIGNATURE "-----BEGIN PGP SIGNATURE-----"
|
|
||||||
|
|
||||||
static int run_gpg_verify(const char *buf, unsigned long size, int verbose)
|
static int run_gpg_verify(const char *buf, unsigned long size, int verbose)
|
||||||
{
|
{
|
||||||
struct child_process gpg;
|
struct child_process gpg;
|
||||||
const char *args_gpg[] = {"gpg", "--verify", "FILE", "-", NULL};
|
const char *args_gpg[] = {"gpg", "--verify", "FILE", "-", NULL};
|
||||||
char path[PATH_MAX], *eol;
|
char path[PATH_MAX];
|
||||||
size_t len;
|
size_t len;
|
||||||
int fd, ret;
|
int fd, ret;
|
||||||
|
|
||||||
@ -37,11 +35,7 @@ static int run_gpg_verify(const char *buf, unsigned long size, int verbose)
|
|||||||
close(fd);
|
close(fd);
|
||||||
|
|
||||||
/* find the length without signature */
|
/* find the length without signature */
|
||||||
len = 0;
|
len = parse_signature(buf, size);
|
||||||
while (len < size && prefixcmp(buf + len, PGP_SIGNATURE)) {
|
|
||||||
eol = memchr(buf + len, '\n', size - len);
|
|
||||||
len += eol ? eol - (buf + len) + 1 : size - len;
|
|
||||||
}
|
|
||||||
if (verbose)
|
if (verbose)
|
||||||
write_in_full(1, buf, len);
|
write_in_full(1, buf, len);
|
||||||
|
|
||||||
|
13
tag.c
13
tag.c
@ -4,6 +4,8 @@
|
|||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
#include "blob.h"
|
#include "blob.h"
|
||||||
|
|
||||||
|
#define PGP_SIGNATURE "-----BEGIN PGP SIGNATURE-----"
|
||||||
|
|
||||||
const char *tag_type = "tag";
|
const char *tag_type = "tag";
|
||||||
|
|
||||||
struct object *deref_tag(struct object *o, const char *warn, int warnlen)
|
struct object *deref_tag(struct object *o, const char *warn, int warnlen)
|
||||||
@ -133,3 +135,14 @@ int parse_tag(struct tag *item)
|
|||||||
free(data);
|
free(data);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
size_t parse_signature(const char *buf, unsigned long size)
|
||||||
|
{
|
||||||
|
char *eol;
|
||||||
|
size_t len = 0;
|
||||||
|
while (len < size && prefixcmp(buf + len, PGP_SIGNATURE)) {
|
||||||
|
eol = memchr(buf + len, '\n', size - len);
|
||||||
|
len += eol ? eol - (buf + len) + 1 : size - len;
|
||||||
|
}
|
||||||
|
return len;
|
||||||
|
}
|
||||||
|
1
tag.h
1
tag.h
@ -16,5 +16,6 @@ extern struct tag *lookup_tag(const unsigned char *sha1);
|
|||||||
extern int parse_tag_buffer(struct tag *item, void *data, unsigned long size);
|
extern int parse_tag_buffer(struct tag *item, void *data, unsigned long size);
|
||||||
extern int parse_tag(struct tag *item);
|
extern int parse_tag(struct tag *item);
|
||||||
extern struct object *deref_tag(struct object *, const char *, int);
|
extern struct object *deref_tag(struct object *, const char *, int);
|
||||||
|
extern size_t parse_signature(const char *buf, unsigned long size);
|
||||||
|
|
||||||
#endif /* TAG_H */
|
#endif /* TAG_H */
|
||||||
|
Loading…
Reference in New Issue
Block a user