File tree Expand file tree Collapse file tree 2 files changed +28
-0
lines changed Expand file tree Collapse file tree 2 files changed +28
-0
lines changed Original file line number Diff line number Diff line change @@ -1892,6 +1892,7 @@ int cmd_index_pack(int argc,
18921892 unsigned foreign_nr = 1 ; /* zero is a "good" value, assume bad */
18931893 int report_end_of_input = 0 ;
18941894 int hash_algo = 0 ;
1895+ int dash_o = 0 ;
18951896
18961897 /*
18971898 * index-pack never needs to fetch missing objects except when
@@ -1976,6 +1977,7 @@ int cmd_index_pack(int argc,
19761977 if (index_name || (i + 1 ) >= argc )
19771978 usage (index_pack_usage );
19781979 index_name = argv [++ i ];
1980+ dash_o = 1 ;
19791981 } else if (starts_with (arg , "--index-version=" )) {
19801982 char * c ;
19811983 opts .version = strtoul (arg + 16 , & c , 10 );
@@ -2029,6 +2031,8 @@ int cmd_index_pack(int argc,
20292031 repo_set_hash_algo (the_repository , GIT_HASH_SHA1 );
20302032
20312033 opts .flags &= ~(WRITE_REV | WRITE_REV_VERIFY );
2034+ if (rev_index && dash_o && !ends_with (index_name , ".idx" ))
2035+ rev_index = 0 ;
20322036 if (rev_index ) {
20332037 opts .flags |= verify ? WRITE_REV_VERIFY : WRITE_REV ;
20342038 if (index_name )
Original file line number Diff line number Diff line change @@ -357,6 +357,30 @@ test_expect_success 'build pack index for an existing pack' '
357357 :
358358'
359359
360+ # The `--rev-index` option of `git index-pack` is now the default, so
361+ # a `foo.rev` REV file will be created when a `foo.idx` IDX file is
362+ # created. Normally, these pathnames are based upon the `foo.pack`
363+ # PACK file pathname.
364+ #
365+ # However, the `-o` option lets you set the pathname of the IDX file
366+ # indepdent of the PACK file.
367+ #
368+ # Verify what happens if these suffixes are changed.
369+ #
370+ test_expect_success ' complain about index name' '
371+ # Normal case { .pack, .idx, .rev }
372+ cat test-1-${packname_1}.pack >test-complain-0.pack &&
373+ git index-pack -o test-complain-0.idx --rev-index test-complain-0.pack &&
374+ test -f test-complain-0.idx &&
375+ test -f test-complain-0.rev &&
376+
377+ # Non .idx suffix -- implicitly omits the .rev
378+ cat test-1-${packname_1}.pack >test-complain-1.pack &&
379+ git index-pack -o test-complain-1.idx-suffix --rev-index test-complain-1.pack &&
380+ test -f test-complain-1.idx-suffix &&
381+ ! test -f test-complain-1.rev
382+ '
383+
360384test_expect_success ' unpacking with --strict' '
361385
362386 for j in a b c d e f g
You can’t perform that action at this time.
0 commit comments