This patch series implements part of the ground work for the 'notes' feature discussed earlier in the thread "[PATCH 00/15] git-note: A mechanism for providing free-form after-the-fact annotations on commits". The following patches refactors the tag object by: 1. Unifying parsing and verification of tag objects (patches 1-9) 2. Do better and more thorough verification of tag objects (patches 10-13) 3. Making the "tagger" header mandatory as far as possible (patch 14) 4. Making the "tag" header optional (patch 15) 5. Introducing a new optional "keywords" header (patch 16) 6. Auxiliary changes supporting the above (patches 17-21) This patch series replaces the earlier patch series of the same name (plus the current bugfixes on top of that series). It's also much easier on the eyes for those with 80 chars wide displays. Also, the selftest suite should run successfully at any point in this patch series. Here's the shortlog: Johan Herland (21): Remove unnecessary code and comments on non-existing 8kB tag object restriction Return error messages when parsing fails. Refactoring to make verify_tag() and parse_tag_buffer() more similar Refactor verification of "tagger" line to be more similar to verification of "type" and "tagger" lines Make parse_tag_buffer_internal() handle item == NULL Refactor tag name verification loop to use index 'i' instead of incrementing pointer 'tag_line' Copy the remaining differences from verify_tag() to parse_tag_buffer_internal() Switch from verify_tag() to parse_and_verify_tag_buffer() for verifying tag objects in git-mktag Remove unneeded code from mktag.c Free mktag's buffer before dying Rewrite error messages; fix up line lengths Use prefixcmp() instead of memcmp() for cleaner code with less magic numbers Collect skipping of header field names and calculation of line lengths in one place Add proper parsing of "tagger" line, but only when thorough_verify is set Make tag names (i.e. the tag object's "tag" line) optional Introduce optional "keywords" on tag objects Update comments on tag objects in mktag.c git-fsck: Do thorough verification of tag objects Documentation/git-mktag: Document the changes in tag object structure git-mktag tests: Expand on mktag selftests according to the new tag object structure Add fsck_verify_ref_to_tag_object() to verify that refname matches name stored in tag object Documentation/git-mktag.txt | 41 +++++-- builtin-fsck.c | 41 +++++++ builtin-log.c | 2 +- mktag.c | 147 +++++------------------- t/t3800-mktag.sh | 231 ++++++++++++++++++++++++++++++++++--- tag.c | 268 +++++++++++++++++++++++++++++++++++-------- tag.h | 5 +- 7 files changed, 540 insertions(+), 195 deletions(-) Have fun! ...Johan - To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html