diff options
| author | Shreyansh Paliwal <shreyanshpaliwalcmsmn@gmail.com> | 2026-01-30 21:01:23 +0530 |
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2026-01-30 08:58:12 -0800 |
| commit | ea39808a22714b8f61b9472de7ef467ced15efea (patch) | |
| tree | aab290d527a3abe4eff682b41f913693f4ef6a77 | |
| parent | ea717645d199f6f1b66058886475db3e8c9330e9 (diff) | |
| download | git-ea39808a22714b8f61b9472de7ef467ced15efea.tar.gz git-ea39808a22714b8f61b9472de7ef467ced15efea.zip | |
show-index: warn when falling back to SHA-1 outside a repository
When 'git show-index' is run outside of a repository and no hashing
algorithm is specified via --object-format, it silently falls back
to SHA-1, relying on the historical default.
This works for existing SHA-1 based index files, but the behavior can
be ambiguous and confusing when the input index file uses a different
hash algorithm, such as SHA-256.
Add a warning when this fallback happens to make the assumption
explicit and to guide users toward using --object-format when needed.
Signed-off-by: Shreyansh Paliwal <shreyanshpaliwalcmsmn@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
| -rw-r--r-- | builtin/show-index.c | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/builtin/show-index.c b/builtin/show-index.c index 2c3e2940ce..45795da2da 100644 --- a/builtin/show-index.c +++ b/builtin/show-index.c @@ -43,11 +43,14 @@ int cmd_show_index(int argc, /* * Fallback to SHA1 if we are running outside of a repository. * - * TODO: Figure out and implement a way to detect the hash algorithm in use by the - * the index file passed in and use that instead. + * TODO: If a future implementation of index file version encodes the hash + * algorithm in its header, enable show-index to infer it from the + * header rather than relying on repository context or a default fallback. */ - if (!the_hash_algo) + if (!the_hash_algo) { + warning(_("assuming SHA-1; use --object-format to override")); repo_set_hash_algo(the_repository, GIT_HASH_DEFAULT); + } hashsz = the_hash_algo->rawsz; |
