summaryrefslogtreecommitdiffstats
path: root/commit.h
diff options
context:
space:
mode:
authorNguyễn Thái Ngọc Duy <pclouds@gmail.com>2018-05-19 07:28:31 +0200
committerJunio C Hamano <gitster@pobox.com>2018-05-21 07:07:21 +0200
commit9d2c97016fa09584337273ba6503e91e7c20d28e (patch)
tree7d730d3d1cdb6b11637d7c487a14da1c45c3a5c4 /commit.h
parentmerge: use commit-slab in merge remote desc instead of commit->util (diff)
downloadgit-9d2c97016fa09584337273ba6503e91e7c20d28e.tar.xz
git-9d2c97016fa09584337273ba6503e91e7c20d28e.zip
commit.h: delete 'util' field in struct commit
If you have come this far, you probably have seen that this 'util' pointer is used for many different purposes. Some are not even contained in a command code, but buried deep in common code with no clue who will use it and how. The move to using commit-slab gives us a much better picture of how some piece of data is associated with a commit and what for. Since nobody uses 'util' pointer anymore, we can retire so that nobody will abuse it again. commit-slab will be the way forward for associating data to a commit. As a side benefit, this shrinks struct commit by 8 bytes (on 64-bit architecture) which should help reduce memory usage for reachability test a bit. This is also what commit-slab is invented for [1]. [1] 96c4f4a370 (commit: allow associating auxiliary info on-demand - 2013-04-09) Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'commit.h')
-rw-r--r--commit.h6
1 files changed, 5 insertions, 1 deletions
diff --git a/commit.h b/commit.h
index 838f6a6b26..4432458367 100644
--- a/commit.h
+++ b/commit.h
@@ -16,9 +16,13 @@ struct commit_list {
struct commit_list *next;
};
+/*
+ * The size of this struct matters in full repo walk operations like
+ * 'git clone' or 'git gc'. Consider using commit-slab to attach data
+ * to a commit instead of adding new fields here.
+ */
struct commit {
struct object object;
- void *util;
unsigned int index;
timestamp_t date;
struct commit_list *parents;