tag: don't warn if target is missing but promised
deref_tag() prints a warning if the object that a tag refers to does not exist. However, when a partial clone has an annotated tag from its promisor remote, but not the object that it refers to, printing a warning on such a tag is incorrect. This occurs, for example, when the checkout that happens after a partial clone causes some objects to be fetched - and as part of the fetch, all local refs are read. The test included in this patch demonstrates this situation. Therefore, do not print a warning in this case. Signed-off-by: Jonathan Tan <jonathantanmy@google.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
committed by
Junio C Hamano
parent
dc0a13f681
commit
8c4cc32689
13
tag.c
13
tag.c
@@ -4,6 +4,7 @@
|
||||
#include "tree.h"
|
||||
#include "blob.h"
|
||||
#include "gpg-interface.h"
|
||||
#include "packfile.h"
|
||||
|
||||
const char *tag_type = "tag";
|
||||
|
||||
@@ -64,12 +65,18 @@ int gpg_verify_tag(const struct object_id *oid, const char *name_to_report,
|
||||
|
||||
struct object *deref_tag(struct object *o, const char *warn, int warnlen)
|
||||
{
|
||||
struct object_id *last_oid = NULL;
|
||||
while (o && o->type == OBJ_TAG)
|
||||
if (((struct tag *)o)->tagged)
|
||||
o = parse_object(&((struct tag *)o)->tagged->oid);
|
||||
else
|
||||
if (((struct tag *)o)->tagged) {
|
||||
last_oid = &((struct tag *)o)->tagged->oid;
|
||||
o = parse_object(last_oid);
|
||||
} else {
|
||||
last_oid = NULL;
|
||||
o = NULL;
|
||||
}
|
||||
if (!o && warn) {
|
||||
if (last_oid && is_promisor_object(last_oid))
|
||||
return NULL;
|
||||
if (!warnlen)
|
||||
warnlen = strlen(warn);
|
||||
error("missing object referenced by '%.*s'", warnlen, warn);
|
||||
|
||||
Reference in New Issue
Block a user