Skip to content

Commit d88f9fd

Browse files
stefanbellergitster
authored andcommitted
replace-object: move replace_map to object store
The relationship between an object X and another object Y that replaces the object X is defined only within the scope of a single repository. The exception in reachability rule around these replacement objects is also local to a repository (i.e. if traversal from refs reaches X, then both X and Y are reachable and need to be kept from gc). Signed-off-by: Stefan Beller <sbeller@google.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
1 parent f37b9bc commit d88f9fd

File tree

3 files changed

+24
-10
lines changed

3 files changed

+24
-10
lines changed

object-store.h

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,8 @@
11
#ifndef OBJECT_STORE_H
22
#define OBJECT_STORE_H
33

4+
#include "oidmap.h"
5+
46
struct alternate_object_database {
57
struct alternate_object_database *next;
68

@@ -93,6 +95,12 @@ struct raw_object_store {
9395
struct alternate_object_database *alt_odb_list;
9496
struct alternate_object_database **alt_odb_tail;
9597

98+
/*
99+
* Objects that should be substituted by other objects
100+
* (see git-replace(1)).
101+
*/
102+
struct oidmap replace_map;
103+
96104
/*
97105
* private data
98106
*

replace-object.h

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
#ifndef REPLACE_OBJECT_H
2+
#define REPLACE_OBJECT_H
3+
4+
struct replace_object {
5+
struct oidmap_entry original;
6+
struct object_id replacement;
7+
};
8+
9+
#endif /* REPLACE_OBJECT_H */

replace_object.c

Lines changed: 7 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -1,15 +1,11 @@
11
#include "cache.h"
22
#include "oidmap.h"
3+
#include "object-store.h"
4+
#include "replace-object.h"
35
#include "refs.h"
6+
#include "repository.h"
47
#include "commit.h"
58

6-
struct replace_object {
7-
struct oidmap_entry original;
8-
struct object_id replacement;
9-
};
10-
11-
static struct oidmap replace_map = OIDMAP_INIT;
12-
139
static int register_replace_ref(const char *refname,
1410
const struct object_id *oid,
1511
int flag, void *cb_data)
@@ -29,7 +25,7 @@ static int register_replace_ref(const char *refname,
2925
oidcpy(&repl_obj->replacement, oid);
3026

3127
/* Register new object */
32-
if (oidmap_put(&replace_map, repl_obj))
28+
if (oidmap_put(&the_repository->objects->replace_map, repl_obj))
3329
die("duplicate replace ref: %s", refname);
3430

3531
return 0;
@@ -44,7 +40,7 @@ static void prepare_replace_object(void)
4440

4541
for_each_replace_ref(register_replace_ref, NULL);
4642
replace_object_prepared = 1;
47-
if (!replace_map.map.tablesize)
43+
if (!the_repository->objects->replace_map.map.tablesize)
4844
check_replace_refs = 0;
4945
}
5046

@@ -67,7 +63,8 @@ const struct object_id *do_lookup_replace_object(const struct object_id *oid)
6763

6864
/* Try to recursively replace the object */
6965
while (depth-- > 0) {
70-
struct replace_object *repl_obj = oidmap_get(&replace_map, cur);
66+
struct replace_object *repl_obj =
67+
oidmap_get(&the_repository->objects->replace_map, cur);
7168
if (!repl_obj)
7269
return cur;
7370
cur = &repl_obj->replacement;

0 commit comments

Comments
 (0)