[PATCH v3 00/17] Pulling signed tags

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



The third iteration of the fourth approach to give more confidence on the
authenticity of history, but the third approach of giving GPG signature to
individual commits is independently useful and has been rebased on top.

Notable differences from the previous round are:

 - The way to handle multi-line header lines in a commit object is
   officially defined --- the second and subsequent lines begin with a
   single SP to indent them. The "mergetag" header and "gpgsig" header are
   now expressed using it;

 - commit_tree() figures out what "mergetag" extra headers to generate by
   inspecting the annotation added to the util field of parent commits as
   before; it uses a new lower level commit_tree_extended() API to record
   the extra headers.

 - "commit --amend" propagates "mergetag" extra header from the original
   (but not "gpgsig" for obvious reasons).


 . Split GPG interface into its own helper library
 . fetch: do not store peeled tag object names in FETCH_HEAD
 . merge: notice local merging of tags and keep it unwrapped
 . fetch: allow "git fetch $there v1.0" to fetch a tag
 . refs DWIMmery: use the same rule for both "git fetch" and others
 . fmt-merge-msg: avoid early returns
 . fmt-merge-msg: package options into a structure
 . fmt-merge-msg: Add contents of merged tag in the merge message
 . merge: make usage of commit->util more extensible
 . merge: record tag objects without peeling in MERGE_HEAD

   Unchanged from the previous round.

 . commit: copy merged signed tags to headers of merge commit

   The way commit_tree() notices that some parents are signed tags and
   copies them to "mergetag" extra header has been reimplemented by using
   the new commit_tree_extended() API.

 . merge: force edit mode when merging a tag object

   Unchanged.

 . commit: teach --amend to carry forward extra headers

   New. This is the reason commit_tree_extended() was introduced. The
   plumbing "git commit-tree" should learn to read list of extra headers
   and record them to its product to help scripts (e.g. "rebase -i"), but
   it is outside the scope of this series for now.

 . commit: teach --gpg-sign option
 . log: --show-signature

   These two use the new multi-line header format, but otherwise
   unchanged.

 . test "commit -S" and "log --show-signature"
 . pretty: %G[?GS] placeholders

   Unchanged.

 Makefile                                           |    2 +
 builtin.h                                          |    8 +-
 builtin/commit-tree.c                              |   24 ++-
 builtin/commit.c                                   |   28 ++-
 builtin/fetch.c                                    |    3 +-
 builtin/fmt-merge-msg.c                            |  113 +++++++--
 builtin/merge.c                                    |  109 +++++----
 builtin/tag.c                                      |   76 +------
 builtin/verify-tag.c                               |   35 +---
 cache.h                                            |    2 +-
 commit.c                                           |  260 +++++++++++++++++++-
 commit.h                                           |   39 +++-
 gpg-interface.c                                    |  138 +++++++++++
 gpg-interface.h                                    |   10 +
 log-tree.c                                         |   39 +++
 merge-recursive.c                                  |   13 +-
 notes-cache.c                                      |    2 +-
 notes-merge.c                                      |    2 +-
 pretty.c                                           |   86 +++++++
 refs.c                                             |    7 -
 revision.c                                         |    2 +
 revision.h                                         |    1 +
 strbuf.c                                           |   14 +
 strbuf.h                                           |    8 +
 t/t4202-log.sh                                     |    4 +-
 t/t5510-fetch.sh                                   |    5 +-
 t/t5515/fetch.br-branches-default                  |    6 +-
 t/t5515/fetch.br-branches-default-merge            |    6 +-
 ...etch.br-branches-default-merge_branches-default |    6 +-
 t/t5515/fetch.br-branches-default-octopus          |    6 +-
 ...ch.br-branches-default-octopus_branches-default |    6 +-
 t/t5515/fetch.br-branches-default_branches-default |    6 +-
 t/t5515/fetch.br-branches-one                      |    6 +-
 t/t5515/fetch.br-branches-one-merge                |    6 +-
 t/t5515/fetch.br-branches-one-merge_branches-one   |    6 +-
 t/t5515/fetch.br-branches-one-octopus              |    6 +-
 t/t5515/fetch.br-branches-one-octopus_branches-one |    6 +-
 t/t5515/fetch.br-branches-one_branches-one         |    6 +-
 t/t5515/fetch.br-config-explicit                   |    6 +-
 t/t5515/fetch.br-config-explicit-merge             |    6 +-
 .../fetch.br-config-explicit-merge_config-explicit |    6 +-
 t/t5515/fetch.br-config-explicit-octopus           |    6 +-
 ...etch.br-config-explicit-octopus_config-explicit |    6 +-
 t/t5515/fetch.br-config-explicit_config-explicit   |    6 +-
 t/t5515/fetch.br-config-glob                       |    6 +-
 t/t5515/fetch.br-config-glob-merge                 |    6 +-
 t/t5515/fetch.br-config-glob-merge_config-glob     |    6 +-
 t/t5515/fetch.br-config-glob-octopus               |    6 +-
 t/t5515/fetch.br-config-glob-octopus_config-glob   |    6 +-
 t/t5515/fetch.br-config-glob_config-glob           |    6 +-
 t/t5515/fetch.br-remote-explicit                   |    6 +-
 t/t5515/fetch.br-remote-explicit-merge             |    6 +-
 .../fetch.br-remote-explicit-merge_remote-explicit |    6 +-
 t/t5515/fetch.br-remote-explicit-octopus           |    6 +-
 ...etch.br-remote-explicit-octopus_remote-explicit |    6 +-
 t/t5515/fetch.br-remote-explicit_remote-explicit   |    6 +-
 t/t5515/fetch.br-remote-glob                       |    6 +-
 t/t5515/fetch.br-remote-glob-merge                 |    6 +-
 t/t5515/fetch.br-remote-glob-merge_remote-glob     |    6 +-
 t/t5515/fetch.br-remote-glob-octopus               |    6 +-
 t/t5515/fetch.br-remote-glob-octopus_remote-glob   |    6 +-
 t/t5515/fetch.br-remote-glob_remote-glob           |    6 +-
 t/t5515/fetch.br-unconfig                          |    6 +-
 t/t5515/fetch.br-unconfig_--tags_.._.git           |    6 +-
 ...nfig_.._.git_one_tag_tag-one_tag_tag-three-file |    6 +-
 ...fig_.._.git_tag_tag-one-tree_tag_tag-three-file |    6 +-
 ...h.br-unconfig_.._.git_tag_tag-one_tag_tag-three |    6 +-
 t/t5515/fetch.br-unconfig_branches-default         |    6 +-
 t/t5515/fetch.br-unconfig_branches-one             |    6 +-
 t/t5515/fetch.br-unconfig_config-explicit          |    6 +-
 t/t5515/fetch.br-unconfig_config-glob              |    6 +-
 t/t5515/fetch.br-unconfig_remote-explicit          |    6 +-
 t/t5515/fetch.br-unconfig_remote-glob              |    6 +-
 t/t5515/fetch.master                               |    6 +-
 t/t5515/fetch.master_--tags_.._.git                |    6 +-
 ...ster_.._.git_one_tag_tag-one_tag_tag-three-file |    6 +-
 ...ter_.._.git_tag_tag-one-tree_tag_tag-three-file |    6 +-
 .../fetch.master_.._.git_tag_tag-one_tag_tag-three |    6 +-
 t/t5515/fetch.master_branches-default              |    6 +-
 t/t5515/fetch.master_branches-one                  |    6 +-
 t/t5515/fetch.master_config-explicit               |    6 +-
 t/t5515/fetch.master_config-glob                   |    6 +-
 t/t5515/fetch.master_remote-explicit               |    6 +-
 t/t5515/fetch.master_remote-glob                   |    6 +-
 t/t7510-signed-commit.sh                           |   71 ++++++
 t/t7600-merge.sh                                   |   12 +-
 t/t7604-merge-custom-message.sh                    |    2 +-
 t/t7608-merge-messages.sh                          |    4 +-
 tag.c                                              |    5 +
 89 files changed, 1080 insertions(+), 392 deletions(-)
 create mode 100644 gpg-interface.c
 create mode 100644 gpg-interface.h
 create mode 100755 t/t7510-signed-commit.sh

-- 
1.7.8.rc1.82.g90e080

--
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


[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]