diff options
author | Johan Herland <johan@herland.net> | 2010-02-13 22:28:23 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2010-02-14 04:36:13 +0100 |
commit | 851c2b3791f24e319c23331887d4b8150ca4d9ba (patch) | |
tree | f178c0cfacf7bbda0079d006da35a03dea9dfd12 /notes.h | |
parent | t3305: Verify that adding many notes with git-notes triggers increased fanout (diff) | |
download | git-851c2b3791f24e319c23331887d4b8150ca4d9ba.tar.xz git-851c2b3791f24e319c23331887d4b8150ca4d9ba.zip |
Teach notes code to properly preserve non-notes in the notes tree
The note tree structure allows for non-note entries to coexist with note
entries in a notes tree. Although we certainly expect there to be very
few non-notes in a notes tree, we should still support them to a certain
degree.
This patch teaches the notes code to preserve non-notes when updating the
notes tree with write_notes_tree(). Non-notes are not affected by fanout
restructuring.
For non-notes to be handled correctly, we can no longer allow subtree
entries that do not match the fanout structure produced by the notes code
itself. This means that fanouts like 4/36, 6/34, 8/32, 4/4/32, etc. are
no longer recognized as note subtrees; only 2-based fanouts are allowed
(2/38, 2/2/36, 2/2/2/34, etc.). Since the notes code has never at any point
_produced_ non-2-based fanouts, it is highly unlikely that this change will
cause problems for anyone.
The patch also adds some tests verifying the correct handling of non-notes
in a notes tree.
Signed-off-by: Johan Herland <johan@herland.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'notes.h')
-rw-r--r-- | notes.h | 1 |
1 files changed, 1 insertions, 0 deletions
@@ -36,6 +36,7 @@ int combine_notes_ignore(unsigned char *cur_sha1, const unsigned char *new_sha1) */ extern struct notes_tree { struct int_node *root; + struct non_note *first_non_note, *prev_non_note; char *ref; combine_notes_fn *combine_notes; int initialized; |