rev-list: extend print-info to print missing object type
Additional information about missing objects found in git-rev-list(1) can be printed by specifying the `print-info` missing action for the `--missing` option. Extend this action to also print missing object type information inferred from its containing object. This token follows the form `type=<type>` and specifies the expected object type of the missing object. Signed-off-by: Justin Tobler <jltobler@gmail.com> Acked-by: Christian Couder <christian.couder@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>maint
parent
c6d896bcfd
commit
3295c35398
|
@ -1038,6 +1038,9 @@ one of the following:
|
||||||
* The `path=<path>` shows the path of the missing object inferred from a
|
* The `path=<path>` shows the path of the missing object inferred from a
|
||||||
containing object. A path containing SP or special characters is enclosed in
|
containing object. A path containing SP or special characters is enclosed in
|
||||||
double-quotes in the C style as needed.
|
double-quotes in the C style as needed.
|
||||||
|
+
|
||||||
|
* The `type=<type>` shows the type of the missing object inferred from a
|
||||||
|
containing object.
|
||||||
--
|
--
|
||||||
+
|
+
|
||||||
If some tips passed to the traversal are missing, they will be
|
If some tips passed to the traversal are missing, they will be
|
||||||
|
|
|
@ -79,6 +79,7 @@ static int arg_print_omitted; /* print objects omitted by filter */
|
||||||
struct missing_objects_map_entry {
|
struct missing_objects_map_entry {
|
||||||
struct oidmap_entry entry;
|
struct oidmap_entry entry;
|
||||||
const char *path;
|
const char *path;
|
||||||
|
unsigned type;
|
||||||
};
|
};
|
||||||
static struct oidmap missing_objects;
|
static struct oidmap missing_objects;
|
||||||
enum missing_action {
|
enum missing_action {
|
||||||
|
@ -109,7 +110,8 @@ static off_t get_object_disk_usage(struct object *obj)
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void add_missing_object_entry(struct object_id *oid, const char *path)
|
static void add_missing_object_entry(struct object_id *oid, const char *path,
|
||||||
|
unsigned type)
|
||||||
{
|
{
|
||||||
struct missing_objects_map_entry *entry;
|
struct missing_objects_map_entry *entry;
|
||||||
|
|
||||||
|
@ -118,6 +120,7 @@ static void add_missing_object_entry(struct object_id *oid, const char *path)
|
||||||
|
|
||||||
CALLOC_ARRAY(entry, 1);
|
CALLOC_ARRAY(entry, 1);
|
||||||
entry->entry.oid = *oid;
|
entry->entry.oid = *oid;
|
||||||
|
entry->type = type;
|
||||||
if (path)
|
if (path)
|
||||||
entry->path = xstrdup(path);
|
entry->path = xstrdup(path);
|
||||||
oidmap_put(&missing_objects, entry);
|
oidmap_put(&missing_objects, entry);
|
||||||
|
@ -142,6 +145,8 @@ static void print_missing_object(struct missing_objects_map_entry *entry,
|
||||||
|
|
||||||
strbuf_release(&path);
|
strbuf_release(&path);
|
||||||
}
|
}
|
||||||
|
if (entry->type)
|
||||||
|
strbuf_addf(&sb, " type=%s", type_name(entry->type));
|
||||||
|
|
||||||
printf("?%s%s\n", oid_to_hex(&entry->entry.oid), sb.buf);
|
printf("?%s%s\n", oid_to_hex(&entry->entry.oid), sb.buf);
|
||||||
strbuf_release(&sb);
|
strbuf_release(&sb);
|
||||||
|
@ -166,7 +171,7 @@ static inline void finish_object__ma(struct object *obj, const char *name)
|
||||||
|
|
||||||
case MA_PRINT:
|
case MA_PRINT:
|
||||||
case MA_PRINT_INFO:
|
case MA_PRINT_INFO:
|
||||||
add_missing_object_entry(&obj->oid, name);
|
add_missing_object_entry(&obj->oid, name, obj->type);
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case MA_ALLOW_PROMISOR:
|
case MA_ALLOW_PROMISOR:
|
||||||
|
@ -843,7 +848,7 @@ int cmd_rev_list(int argc,
|
||||||
|
|
||||||
/* Add missing tips */
|
/* Add missing tips */
|
||||||
while ((oid = oidset_iter_next(&iter)))
|
while ((oid = oidset_iter_next(&iter)))
|
||||||
add_missing_object_entry(oid, NULL);
|
add_missing_object_entry(oid, NULL, 0);
|
||||||
|
|
||||||
oidset_clear(&revs.missing_commits);
|
oidset_clear(&revs.missing_commits);
|
||||||
}
|
}
|
||||||
|
|
|
@ -164,6 +164,7 @@ do
|
||||||
|
|
||||||
oid="$(git rev-parse "$obj")" &&
|
oid="$(git rev-parse "$obj")" &&
|
||||||
path=".git/objects/$(test_oid_to_path $oid)" &&
|
path=".git/objects/$(test_oid_to_path $oid)" &&
|
||||||
|
type_info=" type=$(git cat-file -t $oid)" &&
|
||||||
|
|
||||||
case $obj in
|
case $obj in
|
||||||
HEAD:foo)
|
HEAD:foo)
|
||||||
|
@ -184,7 +185,7 @@ do
|
||||||
# get the expected oids.
|
# get the expected oids.
|
||||||
git rev-list --objects --no-object-names \
|
git rev-list --objects --no-object-names \
|
||||||
HEAD ^"$obj" >expect.raw &&
|
HEAD ^"$obj" >expect.raw &&
|
||||||
echo "?$oid$path_info" >>expect.raw &&
|
echo "?$oid$path_info$type_info" >>expect.raw &&
|
||||||
|
|
||||||
mv "$path" "$path.hidden" &&
|
mv "$path" "$path.hidden" &&
|
||||||
git rev-list --objects --no-object-names \
|
git rev-list --objects --no-object-names \
|
||||||
|
|
Loading…
Reference in New Issue