@ -1966,7 +1966,7 @@ static void add_objects_in_unpacked_packs(struct rev_info *revs)
const unsigned char *sha1;
const unsigned char *sha1;
struct object *o;
struct object *o;
if (p->pack_keep)
if (!p->pack_local || p->pack_keep)
continue;
continue;
if (open_pack_index(p))
if (open_pack_index(p))
die("cannot open pack index");
die("cannot open pack index");
@ -1995,6 +1995,29 @@ static void add_objects_in_unpacked_packs(struct rev_info *revs)
free(in_pack.array);
free(in_pack.array);
}
}
static int has_sha1_pack_kept_or_nonlocal(const unsigned char *sha1)
{
static struct packed_git *last_found = (void *)1;
struct packed_git *p;
p = (last_found != (void *)1) ? last_found : packed_git;
while (p) {
if ((!p->pack_local || p->pack_keep) &&
find_pack_entry_one(sha1, p)) {
last_found = p;
return 1;
}
if (p == last_found)
p = packed_git;
else
p = p->next;
if (p == last_found)
p = p->next;
}
return 0;
}
static void loosen_unused_packed_objects(struct rev_info *revs)
static void loosen_unused_packed_objects(struct rev_info *revs)
{
{
struct packed_git *p;
struct packed_git *p;
@ -2002,7 +2025,7 @@ static void loosen_unused_packed_objects(struct rev_info *revs)
const unsigned char *sha1;
const unsigned char *sha1;
for (p = packed_git; p; p = p->next) {
for (p = packed_git; p; p = p->next) {
if (p->pack_keep)
if (!p->pack_local || p->pack_keep)
continue;
continue;
if (open_pack_index(p))
if (open_pack_index(p))
@ -2010,7 +2033,8 @@ static void loosen_unused_packed_objects(struct rev_info *revs)
for (i = 0; i < p->num_objects; i++) {
for (i = 0; i < p->num_objects; i++) {
sha1 = nth_packed_object_sha1(p, i);
sha1 = nth_packed_object_sha1(p, i);
if (!locate_object_entry(sha1))
if (!locate_object_entry(sha1) &&
!has_sha1_pack_kept_or_nonlocal(sha1))
if (force_object_loose(sha1, p->mtime))
if (force_object_loose(sha1, p->mtime))
die("unable to force loose object");
die("unable to force loose object");
}
}
@ -2200,7 +2224,6 @@ int cmd_pack_objects(int argc, const char **argv, const char *prefix)
continue;
continue;
}
}
if (!strcmp("--unpacked", arg) ||
if (!strcmp("--unpacked", arg) ||
!strcmp("--kept-pack-only", arg) ||
!strcmp("--reflog", arg) ||
!strcmp("--reflog", arg) ||
!strcmp("--all", arg)) {
!strcmp("--all", arg)) {
use_internal_rev_list = 1;
use_internal_rev_list = 1;