From: Junio C Hamano Date: Wed, 30 May 2018 06:29:25 +0000 (+0900) Subject: What's cooking (2018/05 #04) X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=1869796879c4e40ef9a43b1e5224f82fb8014e05;p=thirdparty%2Fgit.git What's cooking (2018/05 #04) --- diff --git a/whats-cooking.txt b/whats-cooking.txt index ca738169ff..6b9083d28b 100644 --- a/whats-cooking.txt +++ b/whats-cooking.txt @@ -1,10 +1,10 @@ To: git@vger.kernel.org Bcc: lwn@lwn.net -Subject: What's cooking in git.git (May 2018, #03; Wed, 23) -X-master-at: e144d126d74f5d2702870ca9423743102eec6fcd -X-next-at: 671052e690087fed435bbc7ce67a6a0cc77818e0 +Subject: What's cooking in git.git (May 2018, #04; Wed, 30) +X-master-at: f15a486ca1dd67757cb6a3c0545dc2c6ef992bc3 +X-next-at: e295dfb56eed062f935757b69da965cde0bc0927 -What's cooking in git.git (May 2018, #03; Wed, 23) +What's cooking in git.git (May 2018, #04; Wed, 30) -------------------------------------------------- Here are the topics that have been cooking. Commits prefixed with @@ -12,6 +12,9 @@ Here are the topics that have been cooking. Commits prefixed with '+' are in 'next'. The ones marked with '.' do not appear in any of the integration branches, but I am still holding onto them. +The recent fixes in v2.17.1 and downward have been merged to these +integration branches 'master' and above. + You can find the changes described here in the integration branches of the repositories listed at @@ -20,558 +23,448 @@ of the repositories listed at -------------------------------------------------- [Graduated to "master"] -* ab/perl-python-attrs (2018-04-27) 3 commits - (merged to 'next' on 2018-05-08 at b440e9bbb9) - + .gitattributes: add a diff driver for Python - + .gitattributes: use the "perl" differ for Perl - + .gitattributes: add *.pl extension for Perl +* ab/get-short-oid (2018-05-11) 5 commits + (merged to 'next' on 2018-05-23 at 07e1908439) + + get_short_oid: sort ambiguous objects by type, then SHA-1 + + sha1-name.c: move around the collect_ambiguous() function + + git-p4: change "commitish" typo to "committish" + + sha1-array.h: align function arguments + + sha1-name.c: remove stray newline - We learned that our source files with ".pl" and ".py" extensions - are Perl and Python files respectively and changes to them are - better viewed as such with appropriate diff drivers. + When a short hexadecimal string is used to name an object but there + are multiple objects that share the string as the prefix of their + names, the code lists these ambiguous candidates in a help message. + These object names are now sorted according to their types for + easier eyeballing. -* ah/misc-doc-updates (2018-05-06) 7 commits - (merged to 'next' on 2018-05-16 at e2e3b68a66) - + doc: normalize [--options] to [options] in git-diff - + doc: add note about shell quoting to revision.txt - + git-svn: remove ''--add-author-from' for 'commit-diff' - + doc: add '-d' and '-o' for 'git push' - + doc: clarify ignore rules for git ls-files - + doc: align 'diff --no-index' in text and synopsis - + doc: improve formatting in githooks.txt +* bc/object-id (2018-05-02) 42 commits + (merged to 'next' on 2018-05-23 at 916bcce829) + + merge-one-file: compute empty blob object ID + + add--interactive: compute the empty tree value + + Update shell scripts to compute empty tree object ID + + sha1_file: only expose empty object constants through git_hash_algo + + dir: use the_hash_algo for empty blob object ID + + sequencer: use the_hash_algo for empty tree object ID + + cache-tree: use is_empty_tree_oid + + sha1_file: convert cached object code to struct object_id + + builtin/reset: convert use of EMPTY_TREE_SHA1_BIN + + builtin/receive-pack: convert one use of EMPTY_TREE_SHA1_HEX + + wt-status: convert two uses of EMPTY_TREE_SHA1_HEX + + submodule: convert several uses of EMPTY_TREE_SHA1_HEX + + sequencer: convert one use of EMPTY_TREE_SHA1_HEX + + merge: convert empty tree constant to the_hash_algo + + builtin/merge: switch tree functions to use object_id + + builtin/am: convert uses of EMPTY_TREE_SHA1_BIN to the_hash_algo + + sha1-file: add functions for hex empty tree and blob OIDs + + builtin/receive-pack: avoid hard-coded constants for push certs + + diff: specify abbreviation size in terms of the_hash_algo + + upload-pack: replace use of several hard-coded constants + + revision: replace use of hard-coded constants + + http: eliminate hard-coded constants + + dir: convert struct untracked_cache_dir to object_id + + commit: convert uses of get_sha1_hex to get_oid_hex + + index-pack: abstract away hash function constant + + pack-redundant: convert linked lists to use struct object_id + + Update struct index_state to use struct object_id + + split-index: convert struct split_index to object_id + + submodule-config: convert structures to object_id + + fsck: convert static functions to struct object_id + + tree-walk: convert get_tree_entry_follow_symlinks to object_id + + tree-walk: avoid hard-coded 20 constant + + pack-redundant: abstract away hash algorithm + + pack-objects: abstract away hash algorithm + + packfile: abstract away hash constant values + + packfile: convert find_pack_entry to object_id + + sha1-file: convert freshen functions to object_id + + packfile: convert has_sha1_pack to object_id + + packfile: remove unused member from struct pack_entry + + Remove unused member in struct object_context + + server-info: remove unused members from struct pack_info + + cache: add a function to read an object ID from a buffer - Misc doc fixes. + Conversion from uchar[20] to struct object_id continues. -* ao/config-api-doc (2018-05-11) 1 commit - (merged to 'next' on 2018-05-22 at a17d6dda92) - + doc: fix config API documentation about config_with_options +* bp/merge-rename-config (2018-05-08) 3 commits + (merged to 'next' on 2018-05-22 at 911440a742) + + merge: pass aggressive when rename detection is turned off + + merge: add merge.renames config setting + + merge: update documentation for {merge,diff}.renameLimit + (this branch is used by ma/unpack-trees-free-msgs.) - Doc update. + With merge.renames configuration set to false, the recursive merge + strategy can be told not to spend cycles trying to find renamed + paths and merge them accordingly. -* bc/asciidoctor-tab-width (2018-05-07) 2 commits - (merged to 'next' on 2018-05-16 at be2a42c473) - + Documentation: render revisions correctly under Asciidoctor - + Documentation: use 8-space tabs with Asciidoctor +* bp/status-rename-config (2018-05-13) 1 commit + (merged to 'next' on 2018-05-22 at ffcb0a7aa7) + + add status config and command line options for rename detection - Asciidoctor gives a reasonable imitation for AsciiDoc, but does not - render illustration in a literal block correctly when indented with - HT by default. The problem is fixed by forcing 8-space tabs. + "git status" learned to honor a new status.renames configuration to + skip rename detection, which could be useful for those who want to + do so without disabling the default rename detection done by the + "git diff" command. -* bc/format-patch-cover-no-attach (2018-05-02) 1 commit - (merged to 'next' on 2018-05-16 at fa1ffeb3fe) - + format-patch: make cover letters always text/plain +* cf/submodule-progress-dissociate (2018-05-22) 3 commits + (merged to 'next' on 2018-05-22 at 9b3b96c54b) + + submodule: add --dissociate option to add/update commands + + submodule: add --progress option to add command + + submodule: clean up substitutions in script - "git format-patch --cover --attach" created a broken MIME multipart - message for the cover letter, which has been fixed by keeping the - cover letter as plain text file. + "git submodule update" and "git submodule add" supported the + "--reference" option to borrow objects from a neighbouring local + repository like "git clone" does, but lacked the more recent + invention "--dissociate". Also "git submodule add" has been taught + to take the "--progress" option. -* bc/mailmap-self (2018-05-08) 1 commit - (merged to 'next' on 2018-05-16 at a009c64bd2) - + mailmap: update brian m. carlson's email address +* dd/send-email-reedit (2018-05-06) 1 commit + (merged to 'next' on 2018-05-22 at 1f4c98324f) + + git-send-email: allow re-editing of message + "git send-email" can sometimes offer confirmation dialog "Send this + email?" with choices 'Yes', 'No', 'Quit', and 'All'. A new action + 'Edit' has been added to this dialog's choice. -* bp/test-drop-caches (2018-05-04) 1 commit - (merged to 'next' on 2018-05-16 at 0e40ab2408) - + test-drop-caches: simplify delay loading of NtSetSystemInformation - Code simplification. +* jk/unavailable-can-be-missing (2018-05-13) 4 commits + (merged to 'next' on 2018-05-22 at 91980c5d1e) + + mark_parents_uninteresting(): avoid most allocation + + mark_parents_uninteresting(): replace list with stack + + mark_parents_uninteresting(): drop missing object check + + mark_tree_contents_uninteresting(): drop missing object check + Code clean-up to turn history traversal more robust in a + semi-corrupt repository. -* bw/server-options (2018-04-24) 4 commits - (merged to 'next' on 2018-05-08 at a18ce56f3c) - + fetch: send server options when using protocol v2 - + ls-remote: send server options when using protocol v2 - + serve: introduce the server-option capability - + Merge branch 'bw/protocol-v2' into HEAD - - The transport protocol v2 is getting updated further. - - -* cc/perf-aggregate-unknown-option (2018-04-26) 1 commit - (merged to 'next' on 2018-05-08 at db7d2870f8) - + perf/aggregate: use Getopt::Long for option parsing - - Perf-test helper updates. - - -* cc/perf-bisect (2018-05-06) 1 commit - (merged to 'next' on 2018-05-16 at 5a078a2fdf) - + perf/bisect_run_script: disable codespeed - - Performance test updates. - - -* ds/lazy-load-trees (2018-05-02) 6 commits - (merged to 'next' on 2018-05-02 at d54016d9e3) - + coccinelle: avoid wrong transformation suggestions from commit.cocci - (merged to 'next' on 2018-04-25 at b90813f421) - + commit-graph: lazy-load trees for commits - + treewide: replace maybe_tree with accessor methods - + commit: create get_commit_tree() method - + treewide: rename tree to maybe_tree - + Merge branch 'bw/c-plus-plus' into ds/lazy-load-trees - (this branch is used by ds/commit-graph-lockfile-fix and ds/generation-numbers.) - - The code has been taught to use the duplicated information stored - in the commit-graph file to learn the tree object name for a commit - to avoid opening and parsing the commit object when it makes sense - to do so. - - -* em/status-rename-config (2018-05-06) 1 commit - (merged to 'next' on 2018-05-16 at 33c1cc093c) - + wt-status: use settings from git_diff_ui_config - (this branch is used by bp/status-rename-config.) - - "git status" learned to pay attention to UI related diff - configuration variables such as diff.renames. - - -* en/git-debugger (2018-04-25) 1 commit - (merged to 'next' on 2018-05-08 at 73369cd1e5) - + Make running git under other debugger-like programs easy - - Dev support. - - -* en/rename-directory-detection-reboot (2018-05-08) 36 commits - (merged to 'next' on 2018-05-08 at be350ebc17) - + merge-recursive: fix check for skipability of working tree updates - + merge-recursive: make "Auto-merging" comment show for other merges - + merge-recursive: fix remainder of was_dirty() to use original index - + merge-recursive: fix was_tracked() to quit lying with some renamed paths - + t6046: testcases checking whether updates can be skipped in a merge - + merge-recursive: avoid triggering add_cacheinfo error with dirty mod - + merge-recursive: move more is_dirty handling to merge_content - + merge-recursive: improve add_cacheinfo error handling - + merge-recursive: avoid spurious rename/rename conflict from dir renames - + directory rename detection: new testcases showcasing a pair of bugs - + merge-recursive: fix remaining directory rename + dirty overwrite cases - + merge-recursive: fix overwriting dirty files involved in renames - + merge-recursive: avoid clobbering untracked files with directory renames - + merge-recursive: apply necessary modifications for directory renames - + merge-recursive: when comparing files, don't include trees - + merge-recursive: check for file level conflicts then get new name - + merge-recursive: add computation of collisions due to dir rename & merging - + merge-recursive: check for directory level conflicts - + merge-recursive: add get_directory_renames() - + merge-recursive: make a helper function for cleanup for handle_renames - + merge-recursive: split out code for determining diff_filepairs - + merge-recursive: make !o->detect_rename codepath more obvious - + merge-recursive: fix leaks of allocated renames and diff_filepairs - + merge-recursive: introduce new functions to handle rename logic - + merge-recursive: move the get_renames() function - + directory rename detection: tests for handling overwriting dirty files - + directory rename detection: tests for handling overwriting untracked files - + directory rename detection: miscellaneous testcases to complete coverage - + directory rename detection: testcases exploring possibly suboptimal merges - + directory rename detection: more involved edge/corner testcases - + directory rename detection: testcases checking which side did the rename - + directory rename detection: files/directories in the way of some renames - + directory rename detection: partially renamed directory testcase/discussion - + directory rename detection: testcases to avoid taking detection too far - + directory rename detection: directory splitting testcases - + directory rename detection: basic testcases - (this branch is used by bp/merge-rename-config and ma/unpack-trees-free-msgs.) - - Rename detection logic in "diff" family that is used in "merge" has - learned to guess when all of x/a, x/b and x/c have moved to z/a, - z/b and z/c, it is likely that x/d added in the meantime would also - want to move to z/d by taking the hint that the entire directory - 'x' moved to 'z'. A bug causing dirty files involved in a rename - to be overwritten during merge has also been fixed as part of this - work. Incidentally, this also avoids updating a file in the - working tree after a (non-trivial) merge whose result matches what - our side originally had. - - -* en/unpack-trees-split-index-fix (2018-05-02) 1 commit - (merged to 'next' on 2018-05-16 at 1adff065b2) - + unpack_trees: fix breakage when o->src_index != o->dst_index - - The split-index feature had a long-standing and dormant bug in - certain use of the in-core merge machinery, which has been fixed. - cf. - - -* fg/completion-external (2018-05-07) 1 commit - (merged to 'next' on 2018-05-16 at 5d83f92caf) - + completion: load completion file for external subcommand - - The command line completion mechanism (in contrib/) learned to load - custom completion file for "git $command" where $command is a - custom "git-$command" that the end user has on the $PATH when using - newer version of bash. - cf. - - -* hn/sort-ls-remote (2018-05-14) 1 commit - (merged to 'next' on 2018-05-16 at 64336850f2) - + t5512: run git fetch inside test - - Hotfix. - - -* jk/apply-p-doc (2018-05-11) 1 commit - (merged to 'next' on 2018-05-22 at 48f280346b) - + apply: clarify "-p" documentation - - Doc update. - - -* js/deprecate-grafts (2018-04-30) 12 commits - (merged to 'next' on 2018-05-08 at 1d7b31d179) - + Remove obsolete script to convert grafts to replace refs - + technical/shallow: describe why shallow cannot use replace refs - + technical/shallow: stop referring to grafts - + filter-branch: stop suggesting to use grafts - + Deprecate support for .git/info/grafts - + Add a test for `git replace --convert-graft-file` - + replace: introduce --convert-graft-file - + replace: prepare create_graft() for converting graft files wholesale - + replace: "libify" create_graft() and callees - + replace: avoid using die() to indicate a bug - + commit: Let the callback of for_each_mergetag return on error - + argv_array: offer to split a string by whitespace - - The functionality of "$GIT_DIR/info/grafts" has been superseded by - the "refs/replace/" mechanism for some time now, but the internal - code had support for it in many places, which has been cleaned up - in order to drop support of the "grafts" mechanism. - - -* js/no-pager-shorthand (2018-05-04) 1 commit - (merged to 'next' on 2018-05-08 at 10e6031dd1) - + git: add -P as a short option for --no-pager - - "git --no-pager cmd" did not have short-and-sweet single letter - option. Now it does. - - -* js/rebase-i-clean-msg-after-fixup-continue (2018-05-02) 4 commits - (merged to 'next' on 2018-05-08 at 7e684c153d) - + rebase --skip: clean up commit message after a failed fixup/squash - + sequencer: always commit without editing when asked for - + rebase -i: Handle "combination of commits" with GETTEXT_POISON - + rebase -i: demonstrate bugs with fixup!/squash! commit messages - - "git rebase -i" sometimes left intermediate "# This is a - combination of N commits" message meant for the human consumption - inside an editor in the final result in certain corner cases, which - has been fixed. - - -* js/rebase-recreate-merge (2018-04-26) 17 commits - (merged to 'next' on 2018-05-16 at f1aeea2879) - + rebase -i --rebase-merges: add a section to the man page - + rebase -i: introduce --rebase-merges=[no-]rebase-cousins - + pull: accept --rebase=merges to recreate the branch topology - + rebase --rebase-merges: avoid "empty merges" - + sequencer: handle post-rewrite for merge commands - + sequencer: make refs generated by the `label` command worktree-local - + rebase --rebase-merges: add test for --keep-empty - + rebase: introduce the --rebase-merges option - + rebase-helper --make-script: introduce a flag to rebase merges - + sequencer: fast-forward `merge` commands, if possible - + sequencer: introduce the `merge` command - + sequencer: introduce new commands to reset the revision - + git-rebase--interactive: clarify arguments - + sequencer: offer helpful advice when a command was rescheduled - + sequencer: refactor how original todo list lines are accessed - + sequencer: make rearrange_squash() a bit more obvious - + sequencer: avoid using errno clobbered by rollback_lock_file() - (this branch is used by js/sequencer-and-root-commits.) - "git rebase" learned "--rebase-merges" to transplant the whole - topology of commit graph elsewhere. +* js/sequencer-and-root-commits (2018-05-06) 6 commits + (merged to 'next' on 2018-05-22 at c1a62f5bc9) + + rebase --rebase-merges: root commits can be cousins, too + + rebase --rebase-merges: a "merge" into a new root is a fast-forward + + sequencer: allow introducing new root commits + + rebase -i --root: let the sequencer handle even the initial part + + sequencer: learn about the special "fake root commit" handling + + sequencer: extract helper to update active_cache_tree + The implementation of "git rebase -i --root" has been updated to use + the sequencer machinery more. -* js/test-unset-prereq (2018-04-30) 1 commit - (merged to 'next' on 2018-05-08 at 3aecbf25a3) - + tests: introduce test_unset_prereq, for debugging - Test debugging aid. - cf. <20180507115950.3887-1-szeder.dev@gmail.com> +* js/use-bug-macro (2018-05-10) 5 commits + (merged to 'next' on 2018-05-22 at fd848c39ae) + + BUG_exit_code: fix sparse "symbol not declared" warning + + Convert remaining die*(BUG) messages + + Replace all die("BUG: ...") calls by BUG() ones + + run-command: use BUG() to report bugs, not die() + + test-tool: help verifying BUG() code paths + Developer support update, by using BUG() macro instead of die() to + mark codepaths that should not happen more clearly. + Further updates can come on top later. + cf. <20180507090109.GA367@sigill.intra.peff.net> -* nd/completion-aliasfiletype-typofix (2018-05-06) 1 commit - (merged to 'next' on 2018-05-16 at 045e4ac190) - + completion: fix misspelled config key aliasesfiletype - - Typofix. - - -* nd/doc-header (2018-05-02) 1 commit - (merged to 'next' on 2018-05-16 at 0599eb3ec9) - + doc: keep first level section header in upper case - - Doc formatting fix. - - -* nd/pack-format-doc (2018-05-13) 1 commit - (merged to 'next' on 2018-05-22 at ff2c48f356) - + pack-format.txt: more details on pack file format - - Doc update. - - -* nd/pack-objects-pack-struct (2018-04-16) 15 commits - (merged to 'next' on 2018-05-16 at 171459475d) - + ci: exercise the whole test suite with uncommon code in pack-objects - + pack-objects: reorder members to shrink struct object_entry - + pack-objects: shrink delta_size field in struct object_entry - + pack-objects: shrink size field in struct object_entry - + pack-objects: clarify the use of object_entry::size - + pack-objects: don't check size when the object is bad - + pack-objects: shrink z_delta_size field in struct object_entry - + pack-objects: refer to delta objects by index instead of pointer - + pack-objects: move in_pack out of struct object_entry - + pack-objects: move in_pack_pos out of struct object_entry - + pack-objects: use bitfield for object_entry::depth - + pack-objects: use bitfield for object_entry::dfs_state - + pack-objects: turn type and in_pack_type to bitfields - + pack-objects: a bit of document about struct object_entry - + read-cache.c: make $GIT_TEST_SPLIT_INDEX boolean - - "git pack-objects" needs to allocate tons of "struct object_entry" - while doing its work, and shrinking its size helps the performance - quite a bit. - cf. +* jt/partial-clone-proto-v2 (2018-05-06) 4 commits + (merged to 'next' on 2018-05-23 at f8b3692e8e) + + {fetch,upload}-pack: support filter in protocol v2 + + upload-pack: read config when serving protocol v2 + + upload-pack: fix error message typo + + Merge branch 'bw/protocol-v2' into jt/partial-clone-proto-v2 -* nd/pack-unreachable-objects-doc (2018-05-06) 1 commit - (merged to 'next' on 2018-05-16 at c4bf977564) - + pack-objects: validation and documentation about unreachable options + Transfer protocol v2 learned to support the partial clone. - Doc update. +* lm/credential-netrc (2018-05-14) 2 commits + (merged to 'next' on 2018-05-23 at c3a0417715) + + git-credential-netrc: accept gpg option + + git-credential-netrc: adapt to test framework for git -* nd/repack-keep-pack (2018-04-16) 7 commits - (merged to 'next' on 2018-05-08 at ab906be358) - + pack-objects: show some progress when counting kept objects - + gc --auto: exclude base pack if not enough mem to "repack -ad" - + gc: handle a corner case in gc.bigPackThreshold - + gc: add gc.bigPackThreshold config - + gc: add --keep-largest-pack option - + repack: add --keep-pack option - + t7700: have closing quote of a test at the beginning of line + Update credential-netrc helper (in contrib/) to allow customizing + the GPG used to decrypt the encrypted .netrc file. - "git gc" in a large repository takes a lot of time as it considers - to repack all objects into one pack by default. The command has - been taught to pretend as if the largest existing packfile is - marked with ".keep" so that it is left untouched while objects in - other packs and loose ones are repacked. - cf. +* ma/create-pseudoref-with-null-old-oid (2018-05-13) 3 commits + (merged to 'next' on 2018-05-22 at c751a19b67) + + refs: handle zero oid for pseudorefs + + t1400: add tests around adding/deleting pseudorefs + + refs.c: refer to "object ID", not "sha1", in error messages -* nd/term-columns (2018-05-13) 2 commits - (merged to 'next' on 2018-05-22 at e50b727a48) - + column: fix off-by-one default width - + pager: set COLUMNS to term_columns() + "git update-ref A B" is supposed to ensure that ref A does not yet + exist when B is a NULL OID, but this check was not done correctly + for pseudo-refs outside refs/ hierarchy, e.g. MERGE_HEAD. - The code did not propagate the terminal width to subprocesses via - COLUMNS environment variable, which it now does. This caused - trouble to "git column" helper subprocess when "git tag --column=row" - tried to list the existing tags on a display with non-default width. +* ma/lockfile-cleanup (2018-05-10) 5 commits + (merged to 'next' on 2018-05-22 at e2efbf0b90) + + lock_file: move static locks into functions + + lock_file: make function-local locks non-static + + refs.c: do not die if locking fails in `delete_pseudoref()` + + refs.c: do not die if locking fails in `write_pseudoref()` + + t/helper/test-write-cache: clean up lock-handling -* sb/object-store-replace (2018-05-21) 4 commits - (merged to 'next' on 2018-05-21 at 4fb28f7b16) - + get_main_ref_store: BUG() when outside a repository - (merged to 'next' on 2018-05-18 at c95db04db9) - + object.c: clear replace map before freeing it - (merged to 'next' on 2018-05-16 at 41bbedcc81) - + replace-object.c: remove the_repository from prepare_replace_object - + object.c: free replace map in raw_object_store_clear + Code clean-up to adjust to a more recent lockfile API convention that + allows lockfile instances kept on the stack. - Hotfix. +* nd/pack-struct-commit (2018-05-13) 1 commit + (merged to 'next' on 2018-05-22 at 38d8a651f0) + + commit.h: rearrange 'index' to shrink struct commit -* sb/oid-object-info (2018-04-26) 9 commits - (merged to 'next' on 2018-05-08 at f3c08f298e) - + cache.h: allow oid_object_info to handle arbitrary repositories - + packfile: add repository argument to cache_or_unpack_entry - + packfile: add repository argument to unpack_entry - + packfile: add repository argument to read_object - + packfile: add repository argument to packed_object_info - + packfile: add repository argument to packed_to_object_type - + packfile: add repository argument to retry_bad_packed_offset - + cache.h: add repository argument to oid_object_info - + cache.h: add repository argument to oid_object_info_extended - (this branch is used by sb/object-store-alloc and sb/object-store-grafts.) + Memory optimization. - The codepath around object-info API has been taught to take the - repository object (which in turn tells the API which object store - the objects are to be located). +* nd/repo-clear-keep-the-index (2018-05-10) 1 commit + (merged to 'next' on 2018-05-22 at 398c7ac4e9) + + repository: fix free problem with repo_clear(the_repository) -* sg/t5310-jgit-bitmap-test (2018-05-11) 1 commit - (merged to 'next' on 2018-05-22 at ef0d86084d) - + t5310-pack-bitmaps: make JGit tests work with GIT_TEST_SPLIT_INDEX + the_repository->index is not a allocated piece of memory but + repo_clear() indiscriminately attempted to free(3) it, which has + been corrected. - Test update. +* nd/travis-gcc-8 (2018-05-21) 1 commit + (merged to 'next' on 2018-05-22 at d5d54efa72) + + travis-ci: run gcc-8 on linux-gcc jobs -* sg/t5516-fixes (2018-05-11) 2 commits - (merged to 'next' on 2018-05-22 at 254fa59e3a) - + t5516-fetch-push: fix broken &&-chain - + t5516-fetch-push: fix 'push with dry-run' test + Developer support. Use newer GCC on one of the builds done at + TravisCI.org to get more warnings and errors diagnosed. - Test fixes. +* rs/no-null-ptr-arith-in-fast-export (2018-05-10) 1 commit + (merged to 'next' on 2018-05-22 at db60f06bba) + + fast-export: avoid NULL pointer arithmetic -* sg/t7005-spaces-in-filenames-cleanup (2018-05-15) 1 commit - (merged to 'next' on 2018-05-22 at 0bc626c61a) - + t7005-editor: get rid of the SPACES_IN_FILENAMES prereq + Code clean-up to avoid non-standard-conformant pointer arithmetic. - Test update. +* sb/blame-color (2018-04-24) 3 commits + (merged to 'next' on 2018-05-23 at 2e9c0daf0b) + + builtin/blame: add new coloring scheme config + + builtin/blame: highlight recently changed lines + + builtin/blame: dim uninteresting metadata lines -* tb/test-apfs-utf8-normalization (2018-05-02) 1 commit - (merged to 'next' on 2018-05-16 at feabe72b42) - + test: correct detection of UTF8_NFD_TO_NFC for APFS + "git blame" learns to unhighlight uninteresting metadata from the + originating commit on lines that are the same as the previous one, + and also paint lines in different colors depending on the age of + the commit. - A test to see if the filesystem normalizes UTF-8 filename has been - updated to check what we need to know in a more direct way, i.e. a - path created in NFC form can be accessed with NFD form (or vice - versa) to cope with APFS as well as HFS. +* sb/submodule-update-try-harder (2018-05-16) 1 commit + (merged to 'next' on 2018-05-23 at 698e6707d7) + + git-submodule.sh: try harder to fetch a submodule -* tg/worktree-add-existing-branch (2018-04-30) 4 commits - (merged to 'next' on 2018-05-08 at 8b76505192) - + worktree: teach "add" to check out existing branches - + worktree: factor out dwim_branch function - + worktree: improve message when creating a new worktree - + worktree: remove extra members from struct add_opts + "git submodule update" attempts two different kinds of "git fetch" + against the upstream repository to grab a commit bound at the + submodule's path, but it incorrectly gave up if the first kind + (i.e. a normal fetch) failed, making the second "last resort" one + (i.e. fetching an exact commit object by object name) ineffective. + This has been corrected. - "git worktree add" learned to check out an existing branch. + +* sg/complete-paths (2018-05-21) 13 commits + (merged to 'next' on 2018-05-22 at a00b992aec) + + t9902-completion: exercise __git_complete_index_file() directly + + completion: don't return with error from __gitcomp_file_direct() + (merged to 'next' on 2018-05-08 at 2a11444f90) + + completion: fill COMPREPLY directly when completing paths + + completion: improve handling quoted paths in 'git ls-files's output + + completion: remove repeated dirnames with 'awk' during path completion + + t9902-completion: ignore COMPREPLY element order in some tests + + completion: use 'awk' to strip trailing path components + + completion: let 'ls-files' and 'diff-index' filter matching paths + + completion: improve handling quoted paths on the command line + + completion: support completing non-ASCII pathnames + + completion: simplify prefix path component handling during path completion + + completion: move __git_complete_index_file() next to its helpers + + t9902-completion: add tests demonstrating issues with quoted pathnames + + Command line completion (in contrib/) learned to complete pathnames + for various commands better. + + +* sg/t6500-no-redirect-of-stdin (2018-05-09) 1 commit + (merged to 'next' on 2018-05-22 at 7019b3a1d5) + + t6050-replace: don't disable stdin for the whole test script + + Test cleanup. -------------------------------------------------- [New Topics] -* bw/ref-prefix-for-configured-refspec (2018-05-18) 2 commits - - fetch: generate ref-prefixes when using a configured refspec - - refspec: consolidate ref-prefix generation logic - (this branch uses bw/refspec-api.) +* pa/import-tars-long-names (2018-05-24) 1 commit + (merged to 'next' on 2018-05-30 at 5e043b2fca) + + import-tars: read overlong names from pax extended header - "git fetch $there $refspec" that talks over protocol v2 can take - advantage of server-side ref filtering; the code has been extended - so that this mechanism triggers also when fetching with configured - refspec. + The import-tars script (in contrib/) has been taught to handle + tarballs with overly long paths that use PAX extended headers. - Will merge to 'next'. + Will merge to 'master'. -* jk/config-blob-sans-repo (2018-05-21) 1 commit - - config: die when --blob is used outside a repository +* nd/use-opt-int-set-f (2018-05-24) 1 commit + (merged to 'next' on 2018-05-30 at f8f5d612ed) + + Use OPT_SET_INT_F() for cmdline option specification - Error codepath fix. + Code simplification. - Will merge to 'next'. + Will merge to 'master'. -* jk/snprintf-truncation (2018-05-21) 5 commits - - fmt_with_err: add a comment that truncation is OK - - shorten_unambiguous_ref: use xsnprintf - - fsmonitor: use internal argv_array of struct child_process - - log_write_email_headers: use strbufs - - http: use strbufs instead of fixed buffers +* ds/commit-graph-fsck (2018-05-29) 20 commits + - commit-graph: update design document + - gc: automatically write commit-graph files + - commit-graph: add '--reachable' option + - fsck: verify commit-graph + - commit-graph: verify contents match checksum + - commit-graph: test for corrupted octopus edge + - commit-graph: verify commit date + - commit-graph: verify generation number + - commit-graph: verify parent list + - commit-graph: verify root tree OIDs + - commit-graph: verify objects exist + - commit-graph: verify corrupt OID fanout and lookup + - commit-graph: verify required chunks are present + - commit-graph: verify catches corrupt signature + - commit-graph: add 'verify' subcommand + - commit-graph: load a root tree from specific graph + - commit: force commit to parse from object database + - commit-graph: parse commit from chosen graph + - commit-graph: fix GRAPH_MIN_SIZE + - commit-graph: UNLEAK before die() + (this branch uses ds/commit-graph-lockfile-fix and ds/generation-numbers.) - Avoid unchecked snprintf() to make future code auditing easier. + Expecting a reroll. + cf. + + +* en/merge-recursive-tests (2018-05-28) 5 commits + - t6036: prefer test_when_finished to manual cleanup in following test + - t6036, t6042: prefer test_cmp to sequences of test + - t6036, t6042: prefer test_path_is_file, test_path_is_missing + - t6036, t6042: use test_line_count instead of wc -l + - t6036, t6042: use test_create_repo to keep tests independent + + Clean up tests in t6xxx series about 'merge' command. Will merge to 'next'. -* js/empty-config-section-fix (2018-05-18) 1 commit - - config: a user-provided invalid section is not a BUG +* en/rev-parse-invalid-range (2018-05-25) 1 commit + (merged to 'next' on 2018-05-30 at aec27f8a94) + + rev-parse: check lookup'ed commit references for NULL - Error codepath fix. + "git rev-parse Y..." etc. misbehaved when given endpoints were + not committishes. - Will merge to 'next'. + Will merge to 'master'. -* ma/config-store-data-clear (2018-05-21) 3 commits - - config: let `config_store_data_clear()` handle `key` - - config: let `config_store_data_clear()` handle `value_regex` - - config: free resources of `struct config_store_data` +* jk/show-index (2018-05-29) 2 commits + - show-index: update documentation for index v2 + - make show-index a builtin - Leak plugging. + Modernize a less often used command. Will merge to 'next'. -* ma/regex-no-regfree-after-comp-fail (2018-05-21) 1 commit - - regex: do not call `regfree()` if compilation fails +* js/rebase-recreate-merge (2018-05-30) 2 commits + (merged to 'next' on 2018-05-30 at e295dfb56e) + + sequencer: ensure labels that are object IDs are rewritten + + git-rebase--interactive: fix copy-paste mistake - We used to call regfree() after regcomp() failed in some codepaths, - which have been corrected. + Hotfixes. - Will merge to 'next'. + Will merge to 'master'. -* ma/unpack-trees-free-msgs (2018-05-22) 4 commits - - unpack_trees_options: free messages when done - - argv-array: return the pushed string from argv_push*() - - merge-recursive: provide pair of `unpack_trees_{start,finish}()` - - merge: setup `opts` later in `checkout_fast_forward()` - (this branch uses bp/merge-rename-config.) +* jt/submodule-pull-recurse-rebase (2018-05-25) 1 commit + - submodule: do not pass null OID to setup_revisions - Leak plugging. + "git pull -recurse-submodules --rebase", when the submodule + repository's history did not have anything common between ours and + the upstream's, failed to execute. We need to fetch from them to + continue even in such a case. Will merge to 'next'. -* rm/p4-submit-with-commit-option (2018-05-21) 1 commit - - git-p4: add options --commit and --disable-rebase +* ma/wrapped-info (2018-05-28) 2 commits + - usage: prefix all lines in `vreportf()`, not just the first + - usage: extract `prefix_suffix_lines()` from `advise()` - Needs sign-off. + An attempt to help making multi-line messages fed to warning(), + error(), and friends more easily translatable. + Wait for discussion to settle. + cf. <20180529213957.GF7964@sigill.intra.peff.net> -* bw/remote-curl-compressed-responses (2018-05-23) 2 commits - - remote-curl: accept compressed responses with protocol v2 - - remote-curl: accept all encodings supported by curl - Our HTTP client code used to advertise that we accept gzip encoding - from the other side; instead, just let cURL library to advertise - and negotiate the best one. +* nd/complete-config-vars (2018-05-29) 13 commits + - completion: complete general config vars in two steps + - log-tree: allow to customize 'grafted' color + - completion: support case-insensitive config vars + - completion: keep other config var completion in camelCase + - completion: drop the hard coded list of config vars + - am: move advice.amWorkDir parsing back to advice.c + - advice: keep config name in camelCase in advice_config[] + - fsck: produce camelCase config key names + - help: add --config to list all available config + - fsck: factor out msg_id_info[] lazy initialization code + - grep: keep all colors in an array + - Add and use generic name->id mapping code for color slot parsing + - Merge branch 'nd/command-list' into nd/complete-config-vars + (this branch uses nd/command-list.) - Will merge to 'next'. + Continuing with the idea to programatically enumerate various + pieces of data required for command line completion, teach the + codebase to report the list of configuration variables + subcommands care about to help complete them. -* cc/tests-without-assuming-ref-files-backend (2018-05-23) 1 commit - - t: make many tests depend less on the refs being files +* nd/completion-negation (2018-05-29) 3 commits + - completion: collapse extra --no-.. options + - completion: suppress some -no- options + - parse-options: option to let --git-completion-helper show negative form - Quite a many tests assumed that newly created refs are made as - loose refs using the files backend, which have been updated to use - proper plumbing like rev-parse and update-ref, to avoid breakage - once we start using different ref backends. + Continuing with the idea to programatically enumerate various + pieces of data required for command line completion, the codebase + has been taught to enumerate options prefixed with "--no-" to + negate them. - Will merge to 'next'. --------------------------------------------------- -[Stalled] +* rd/doc-options-placeholder (2018-05-25) 1 commit + (merged to 'next' on 2018-05-30 at e3961b038f) + + Use proper syntax for replaceables in command docs -* jm/cache-entry-from-mem-pool (2018-05-02) 5 commits - - block alloc: add validations around cache_entry lifecyle - - block alloc: allocate cache entries from mem_pool - - mem-pool: fill out functionality - - block alloc: add lifecycle APIs for cache_entry structs - - read-cache: teach refresh_cache_entry() to take istate + Docfix. + + Will merge to 'master'. + + +* rd/tag-doc-lightweight (2018-05-29) 1 commit + (merged to 'next' on 2018-05-30 at 979ba9f720) + + tag: clarify in the doc that a tag can refer to a non-commit object + + Docfix. + + Will merge to 'master'. - For a large tree, the index needs to hold many cache entries - allocated on heap. These cache entries are now allocated out of a - dedicated memory pool to amortize malloc(3) overhead. - Needs review. - Is the "caller always knows which pool an entry came from and calls - the right kind of free" a feasible approach? - Oh, another thing, there is "lifecyle" typo in the title. +* rd/init-typo (2018-05-30) 1 commit + (merged to 'next' on 2018-05-30 at 8813a649eb) + + init: fix grammar in "templates not found" msg + Message fix. + + Will merge to 'master'. + +-------------------------------------------------- +[Stalled] * ab/fetch-tags-noclobber (2018-05-16) 9 commits - fixup! push tests: assert re-pushing annotated tags @@ -710,261 +603,284 @@ of the repositories listed at -------------------------------------------------- [Cooking] -* sg/t6500-no-redirect-of-stdin (2018-05-09) 1 commit - (merged to 'next' on 2018-05-22 at 7019b3a1d5) - + t6050-replace: don't disable stdin for the whole test script +* jm/cache-entry-from-mem-pool (2018-05-24) 7 commits + - block alloc: add validations around cache_entry lifecyle + - block alloc: allocate cache entries from mem_pool + - mem-pool: fill out functionality + - mem-pool: add lifecycle management functions + - mem-pool: only search head block for available space + - block alloc: add lifecycle APIs for cache_entry structs + - read-cache: teach refresh_cache_entry() to take istate - Test cleanup. + For a large tree, the index needs to hold many cache entries + allocated on heap. These cache entries are now allocated out of a + dedicated memory pool to amortize malloc(3) overhead. - Will merge to 'master'. + Is this ready for 'next'? -* bc/hash-independent-tests (2018-05-21) 28 commits - - t5300: abstract away SHA-1-specific constants - - t4208: abstract away SHA-1-specific constants - - t4045: abstract away SHA-1-specific constants - - t4042: abstract away SHA-1-specific constants - - t4205: sort log output in a hash-independent way - - t/lib-diff-alternative: abstract away SHA-1-specific constants - - t4030: abstract away SHA-1-specific constants - - t4029: abstract away SHA-1-specific constants - - t4029: fix test indentation - - t4022: abstract away SHA-1-specific constants - - t4020: abstract away SHA-1-specific constants - - t4014: abstract away SHA-1-specific constants - - t4008: abstract away SHA-1-specific constants - - t4007: abstract away SHA-1-specific constants - - t3905: abstract away SHA-1-specific constants - - t3702: abstract away SHA-1-specific constants - - t3103: abstract away SHA-1-specific constants - - t2203: abstract away SHA-1-specific constants - - t: skip pack tests if not using SHA-1 - - t4044: skip test if not using SHA-1 - - t1512: skip test if not using SHA-1 - - t1007: annotate with SHA1 prerequisite - - t0000: annotate with SHA1 prerequisite - - t: switch $_x40 to $OID_REGEX - - t/test-lib: introduce OID_REGEX - - t: switch $_z40 to $ZERO_OID - - t/test-lib: introduce ZERO_OID - - t/test-lib: add an SHA1 prerequisite +* bw/ref-prefix-for-configured-refspec (2018-05-18) 2 commits + (merged to 'next' on 2018-05-24 at a0d4af6180) + + fetch: generate ref-prefixes when using a configured refspec + + refspec: consolidate ref-prefix generation logic + (this branch uses bw/refspec-api.) - Many tests hardcode the raw object names, which would change once - we migrate away from SHA-1. While some of them must test against - exact object names, most of them do not have to use hardcoded - constants in the test. The latter kind of tests have been updated - to test the moral equivalent of the original without hardcoding the - actual object names. + "git fetch $there $refspec" that talks over protocol v2 can take + advantage of server-side ref filtering; the code has been extended + so that this mechanism triggers also when fetching with configured + refspec. - Will merge to 'next'. + Will merge to 'master'. -* bp/status-rename-config (2018-05-13) 1 commit - (merged to 'next' on 2018-05-22 at ffcb0a7aa7) - + add status config and command line options for rename detection +* jk/config-blob-sans-repo (2018-05-21) 1 commit + (merged to 'next' on 2018-05-24 at 3426d9508c) + + config: die when --blob is used outside a repository - "git status" learned to honor a new status.renames configuration to - skip rename detection, which could be useful for those who want to - do so without disabling the default rename detection done by the - "git diff" command. + Error codepath fix. Will merge to 'master'. -* bw/refspec-api (2018-05-18) 36 commits - - submodule: convert push_unpushed_submodules to take a struct refspec - - remote: convert check_push_refs to take a struct refspec - - remote: convert match_push_refs to take a struct refspec - - http-push: store refspecs in a struct refspec - - transport: remove transport_verify_remote_names - - send-pack: store refspecs in a struct refspec - - transport: convert transport_push to take a struct refspec - - push: convert to use struct refspec - - push: check for errors earlier - - remote: convert match_explicit_refs to take a struct refspec - - remote: convert get_ref_match to take a struct refspec - - remote: convert query_refspecs to take a struct refspec - - remote: convert apply_refspecs to take a struct refspec - - remote: convert get_stale_heads to take a struct refspec - - fetch: convert prune_refs to take a struct refspec - - fetch: convert get_ref_map to take a struct refspec - - fetch: convert do_fetch to take a struct refspec - - refspec: remove the deprecated functions - - fetch: convert refmap to use struct refspec - - fetch: convert fetch_one to use struct refspec - - transport-helper: convert to use struct refspec - - remote: remove add_prune_tags_to_fetch_refspec - - remote: convert fetch refspecs to struct refspec - - remote: convert push refspecs to struct refspec - - fast-export: convert to use struct refspec - - clone: convert cmd_clone to use refspec_item_init - - remote: convert match_push_refs to use struct refspec - - remote: convert check_push_refs to use struct refspec - - transport: convert transport_push to use struct refspec - - pull: convert get_tracking_branch to use refspec_item_init - - submodule--helper: convert push_check to use struct refspec - - refspec: convert valid_fetch_refspec to use parse_refspec - - refspec: introduce struct refspec - - refspec: factor out parsing a single refspec - - refspec: rename struct refspec to struct refspec_item - - refspec: move refspec parsing logic into its own file - (this branch is used by bw/ref-prefix-for-configured-refspec.) +* jk/snprintf-truncation (2018-05-21) 5 commits + (merged to 'next' on 2018-05-24 at 4b78e15f66) + + fmt_with_err: add a comment that truncation is OK + + shorten_unambiguous_ref: use xsnprintf + + fsmonitor: use internal argv_array of struct child_process + + log_write_email_headers: use strbufs + + http: use strbufs instead of fixed buffers - An API update for handling of refspecs used by fetch & push - codepath. + Avoid unchecked snprintf() to make future code auditing easier. - Will merge to 'next'. + Will merge to 'master'. -* ds/commit-graph-lockfile-fix (2018-05-22) 1 commit - - commit-graph: fix UX issue when .lock file exists - (this branch uses ds/generation-numbers.) +* js/empty-config-section-fix (2018-05-18) 1 commit + (merged to 'next' on 2018-05-24 at 3d0875c7b4) + + config: a user-provided invalid section is not a BUG - Update to ds/generation-numbers topic. + Error codepath fix. - Will merge to 'next'. + Will merge to 'master'. -* jk/unavailable-can-be-missing (2018-05-13) 4 commits - (merged to 'next' on 2018-05-22 at 91980c5d1e) - + mark_parents_uninteresting(): avoid most allocation - + mark_parents_uninteresting(): replace list with stack - + mark_parents_uninteresting(): drop missing object check - + mark_tree_contents_uninteresting(): drop missing object check +* ma/config-store-data-clear (2018-05-21) 3 commits + (merged to 'next' on 2018-05-24 at cc6e4b9371) + + config: let `config_store_data_clear()` handle `key` + + config: let `config_store_data_clear()` handle `value_regex` + + config: free resources of `struct config_store_data` - Code clean-up to turn history traversal more robust in a - semi-corrupt repository. + Leak plugging. Will merge to 'master'. -* lm/credential-netrc (2018-05-14) 2 commits - (merged to 'next' on 2018-05-23 at c3a0417715) - + git-credential-netrc: accept gpg option - + git-credential-netrc: adapt to test framework for git +* ma/regex-no-regfree-after-comp-fail (2018-05-21) 1 commit + (merged to 'next' on 2018-05-24 at 3e473da1b5) + + regex: do not call `regfree()` if compilation fails - Update credential-netrc helper (in contrib/) to allow customizing - the GPG used to decrypt the encrypted .netrc file. + We used to call regfree() after regcomp() failed in some codepaths, + which have been corrected. Will merge to 'master'. -* ma/create-pseudoref-with-null-old-oid (2018-05-13) 3 commits - (merged to 'next' on 2018-05-22 at c751a19b67) - + refs: handle zero oid for pseudorefs - + t1400: add tests around adding/deleting pseudorefs - + refs.c: refer to "object ID", not "sha1", in error messages +* ma/unpack-trees-free-msgs (2018-05-22) 4 commits + (merged to 'next' on 2018-05-24 at 84cbd459f7) + + unpack_trees_options: free messages when done + + argv-array: return the pushed string from argv_push*() + + merge-recursive: provide pair of `unpack_trees_{start,finish}()` + + merge: setup `opts` later in `checkout_fast_forward()` - "git update-ref A B" is supposed to ensure that ref A does not yet - exist when B is a NULL OID, but this check was not done correctly - for pseudo-refs outside refs/ hierarchy, e.g. MERGE_HEAD. + Leak plugging. Will merge to 'master'. -* ma/lockfile-cleanup (2018-05-10) 5 commits - (merged to 'next' on 2018-05-22 at e2efbf0b90) - + lock_file: move static locks into functions - + lock_file: make function-local locks non-static - + refs.c: do not die if locking fails in `delete_pseudoref()` - + refs.c: do not die if locking fails in `write_pseudoref()` - + t/helper/test-write-cache: clean up lock-handling +* rm/p4-submit-with-commit-option (2018-05-21) 1 commit + - git-p4: add options --commit and --disable-rebase - Code clean-up to adjust to a more recent lockfile API convention that - allows lockfile instances kept on the stack. + Needs sign-off. - Will merge to 'master'. +* bw/remote-curl-compressed-responses (2018-05-23) 2 commits + (merged to 'next' on 2018-05-24 at 98ee4308dc) + + remote-curl: accept compressed responses with protocol v2 + + remote-curl: accept all encodings supported by curl -* nd/commit-util-to-slab (2018-05-21) 15 commits - - commit.h: delete 'util' field in struct commit - - merge: use commit-slab in merge remote desc instead of commit->util - - log: use commit-slab in prepare_bases() instead of commit->util - - show-branch: note about its object flags usage - - show-branch: use commit-slab for commit-name instead of commit->util - - name-rev: use commit-slab for rev-name instead of commit->util - - bisect.c: use commit-slab for commit weight instead of commit->util - - revision.c: use commit-slab for show_source - - sequencer.c: use commit-slab to associate todo items to commits - - sequencer.c: use commit-slab to mark seen commits - - shallow.c: use commit-slab for commit depth instead of commit->util - - describe: use commit-slab for commit names instead of commit->util - - blame: use commit-slab for blame suspects instead of commit->util - - commit-slab: support shared commit-slab - - commit-slab.h: code split + Our HTTP client code used to advertise that we accept gzip encoding + from the other side; instead, just let cURL library to advertise + and negotiate the best one. - The in-core "commit" object had an all-purpose "void *util" field, - which was tricky to use especially in library-ish part of the - code. All of the existing uses of the field has been migrated to a - more dedicated "commit-slab" mechanism and the field is eliminated. + Will merge to 'master'. - Will merge to 'next'. +* cc/tests-without-assuming-ref-files-backend (2018-05-30) 2 commits + (merged to 'next' on 2018-05-30 at e9605bacf0) + + t990X: use '.git/objects' as 'deep inside .git' path + (merged to 'next' on 2018-05-24 at 19138b162f) + + t: make many tests depend less on the refs being files -* nd/diff-apply-ita (2018-05-14) 2 commits - (merged to 'next' on 2018-05-22 at a15cc0ce1c) - + apply: add --intent-to-add - + diff: turn --ita-invisible-in-index on by default + Quite a many tests assumed that newly created refs are made as + loose refs using the files backend, which have been updated to use + proper plumbing like rev-parse and update-ref, to avoid breakage + once we start using different ref backends. - "git diff" compares the index and the working tree. For paths - added with intent-to-add bit, the command shows the full contents - of them as added, but the paths themselves were not marked as new - files. They are now shown as new by default. + Will merge to 'master'. - "git apply" learned the "--intent-to-add" option so that an - otherwise working-tree-only application of a patch will add new - paths to the index marked with the "intent-to-add" bit. - Will merge to and cook in 'next'. +* bc/hash-independent-tests (2018-05-21) 28 commits + (merged to 'next' on 2018-05-24 at 40fb709f7c) + + t5300: abstract away SHA-1-specific constants + + t4208: abstract away SHA-1-specific constants + + t4045: abstract away SHA-1-specific constants + + t4042: abstract away SHA-1-specific constants + + t4205: sort log output in a hash-independent way + + t/lib-diff-alternative: abstract away SHA-1-specific constants + + t4030: abstract away SHA-1-specific constants + + t4029: abstract away SHA-1-specific constants + + t4029: fix test indentation + + t4022: abstract away SHA-1-specific constants + + t4020: abstract away SHA-1-specific constants + + t4014: abstract away SHA-1-specific constants + + t4008: abstract away SHA-1-specific constants + + t4007: abstract away SHA-1-specific constants + + t3905: abstract away SHA-1-specific constants + + t3702: abstract away SHA-1-specific constants + + t3103: abstract away SHA-1-specific constants + + t2203: abstract away SHA-1-specific constants + + t: skip pack tests if not using SHA-1 + + t4044: skip test if not using SHA-1 + + t1512: skip test if not using SHA-1 + + t1007: annotate with SHA1 prerequisite + + t0000: annotate with SHA1 prerequisite + + t: switch $_x40 to $OID_REGEX + + t/test-lib: introduce OID_REGEX + + t: switch $_z40 to $ZERO_OID + + t/test-lib: introduce ZERO_OID + + t/test-lib: add an SHA1 prerequisite + Many tests hardcode the raw object names, which would change once + we migrate away from SHA-1. While some of them must test against + exact object names, most of them do not have to use hardcoded + constants in the test. The latter kind of tests have been updated + to test the moral equivalent of the original without hardcoding the + actual object names. -* nd/pack-struct-commit (2018-05-13) 1 commit - (merged to 'next' on 2018-05-22 at 38d8a651f0) - + commit.h: rearrange 'index' to shrink struct commit + Will merge to 'master'. - Memory optimization. + +* bw/refspec-api (2018-05-18) 36 commits + (merged to 'next' on 2018-05-24 at 83d361419e) + + submodule: convert push_unpushed_submodules to take a struct refspec + + remote: convert check_push_refs to take a struct refspec + + remote: convert match_push_refs to take a struct refspec + + http-push: store refspecs in a struct refspec + + transport: remove transport_verify_remote_names + + send-pack: store refspecs in a struct refspec + + transport: convert transport_push to take a struct refspec + + push: convert to use struct refspec + + push: check for errors earlier + + remote: convert match_explicit_refs to take a struct refspec + + remote: convert get_ref_match to take a struct refspec + + remote: convert query_refspecs to take a struct refspec + + remote: convert apply_refspecs to take a struct refspec + + remote: convert get_stale_heads to take a struct refspec + + fetch: convert prune_refs to take a struct refspec + + fetch: convert get_ref_map to take a struct refspec + + fetch: convert do_fetch to take a struct refspec + + refspec: remove the deprecated functions + + fetch: convert refmap to use struct refspec + + fetch: convert fetch_one to use struct refspec + + transport-helper: convert to use struct refspec + + remote: remove add_prune_tags_to_fetch_refspec + + remote: convert fetch refspecs to struct refspec + + remote: convert push refspecs to struct refspec + + fast-export: convert to use struct refspec + + clone: convert cmd_clone to use refspec_item_init + + remote: convert match_push_refs to use struct refspec + + remote: convert check_push_refs to use struct refspec + + transport: convert transport_push to use struct refspec + + pull: convert get_tracking_branch to use refspec_item_init + + submodule--helper: convert push_check to use struct refspec + + refspec: convert valid_fetch_refspec to use parse_refspec + + refspec: introduce struct refspec + + refspec: factor out parsing a single refspec + + refspec: rename struct refspec to struct refspec_item + + refspec: move refspec parsing logic into its own file + (this branch is used by bw/ref-prefix-for-configured-refspec.) + + An API update for handling of refspecs used by fetch & push + codepath. Will merge to 'master'. -* nd/repo-clear-keep-the-index (2018-05-10) 1 commit - (merged to 'next' on 2018-05-22 at 398c7ac4e9) - + repository: fix free problem with repo_clear(the_repository) +* ds/commit-graph-lockfile-fix (2018-05-22) 1 commit + (merged to 'next' on 2018-05-24 at 3d12a02b0c) + + commit-graph: fix UX issue when .lock file exists + (this branch is used by ds/commit-graph-fsck; uses ds/generation-numbers.) - the_repository->index is not a allocated piece of memory but - repo_clear() indiscriminately attempted to free(3) it, which has - been corrected. + Update to ds/generation-numbers topic. Will merge to 'master'. -* nd/travis-gcc-8 (2018-05-21) 1 commit - (merged to 'next' on 2018-05-22 at d5d54efa72) - + travis-ci: run gcc-8 on linux-gcc jobs +* nd/commit-util-to-slab (2018-05-21) 15 commits + (merged to 'next' on 2018-05-24 at bb5643d75c) + + commit.h: delete 'util' field in struct commit + + merge: use commit-slab in merge remote desc instead of commit->util + + log: use commit-slab in prepare_bases() instead of commit->util + + show-branch: note about its object flags usage + + show-branch: use commit-slab for commit-name instead of commit->util + + name-rev: use commit-slab for rev-name instead of commit->util + + bisect.c: use commit-slab for commit weight instead of commit->util + + revision.c: use commit-slab for show_source + + sequencer.c: use commit-slab to associate todo items to commits + + sequencer.c: use commit-slab to mark seen commits + + shallow.c: use commit-slab for commit depth instead of commit->util + + describe: use commit-slab for commit names instead of commit->util + + blame: use commit-slab for blame suspects instead of commit->util + + commit-slab: support shared commit-slab + + commit-slab.h: code split - Developer support. Use newer GCC on one of the builds done at - TravisCI.org to get more warnings and errors diagnosed. + The in-core "commit" object had an all-purpose "void *util" field, + which was tricky to use especially in library-ish part of the + code. All of the existing uses of the field has been migrated to a + more dedicated "commit-slab" mechanism and the field is eliminated. Will merge to 'master'. -* rs/no-null-ptr-arith-in-fast-export (2018-05-10) 1 commit - (merged to 'next' on 2018-05-22 at db60f06bba) - + fast-export: avoid NULL pointer arithmetic +* nd/diff-apply-ita (2018-05-29) 4 commits + (merged to 'next' on 2018-05-30 at f98728de81) + + apply: add --intent-to-add + + t2203: add a test about "diff HEAD" case + + diff: turn --ita-invisible-in-index on by default + + diff: ignore --ita-[in]visible-in-index when diffing worktree-to-tree - Code clean-up to avoid non-standard-conformant pointer arithmetic. + "git diff" compares the index and the working tree. For paths + added with intent-to-add bit, the command shows the full contents + of them as added, but the paths themselves were not marked as new + files. They are now shown as new by default. - Will merge to 'master'. + "git apply" learned the "--intent-to-add" option so that an + otherwise working-tree-only application of a patch will add new + paths to the index marked with the "intent-to-add" bit. + + Kicked back to 'pu'. + cf. <20180526120846.23663-1-pclouds@gmail.com> * sb/grep-die-on-unreadable-index (2018-05-16) 1 commit - - grep: handle corrupt index files early + (merged to 'next' on 2018-05-24 at 6d78916503) + + grep: handle corrupt index files early Error behaviour of "git grep" when it cannot read the index was inconsistent with other commands that uses the index, which has been corrected to error out early. - Will merge to 'next'. + Will merge to 'master'. * sb/object-store-grafts (2018-05-18) 19 commits @@ -989,11 +905,17 @@ of the repositories listed at - object-store: move object access functions to object-store.h (this branch uses sb/object-store-alloc.) + The conversion to pass "the_repository" and then "a_repository" + throughout the object access API continues. + + Is this ready for 'next'? + * sb/submodule-merge-in-merge-recursive (2018-05-18) 3 commits - - merge-recursive: give notice when submodule commit gets fast-forwarded - - merge-recursive: i18n submodule merge output and respect verbosity - - submodule.c: move submodule merging to merge-recursive.c + (merged to 'next' on 2018-05-24 at 6228d22182) + + merge-recursive: give notice when submodule commit gets fast-forwarded + + merge-recursive: i18n submodule merge output and respect verbosity + + submodule.c: move submodule merging to merge-recursive.c By code restructuring of submodule merge in merge-recursive, informational messages from the codepath are now given using the @@ -1002,38 +924,16 @@ of the repositories listed at when a submodule three-way merge resolves cleanly when one side records a descendant of the commit chosen by the other side. - Will merge to 'next'. - - -* sb/submodule-update-try-harder (2018-05-16) 1 commit - (merged to 'next' on 2018-05-23 at 698e6707d7) - + git-submodule.sh: try harder to fetch a submodule - - "git submodule update" attempts two different kinds of "git fetch" - against the upstream repository to grab a commit bound at the - submodule's path, but it incorrectly gave up if the first kind - (i.e. a normal fetch) failed, making the second "last resort" one - (i.e. fetching an exact commit object by object name) ineffective. - This has been corrected. - Will merge to 'master'. -* tb/grep-only-matching (2018-05-14) 2 commits - - builtin/grep.c: teach '-o', '--only-matching' to 'git-grep' - - grep.c: extract show_line_header() - (this branch uses tb/grep-column.) - - -* ld/p4-unshelve (2018-05-23) 3 commits - - git-p4: unshelve: use action==add instead of rev==none - - SQUASH??? - - git-p4: add unshelve command +* ld/p4-unshelve (2018-05-24) 1 commit + (merged to 'next' on 2018-05-30 at 7367508399) + + git-p4: add unshelve command "git p4" learned to "unshelve" shelved commit from P4. - Expecting a reroll. - cf. + Will merge to 'master'. * pc/submodule-helper-foreach (2018-05-11) 4 commits @@ -1048,49 +948,6 @@ of the repositories listed at Will merge to and cook in 'next'. -* ab/get-short-oid (2018-05-11) 5 commits - (merged to 'next' on 2018-05-23 at 07e1908439) - + get_short_oid: sort ambiguous objects by type, then SHA-1 - + sha1-name.c: move around the collect_ambiguous() function - + git-p4: change "commitish" typo to "committish" - + sha1-array.h: align function arguments - + sha1-name.c: remove stray newline - - When a short hexadecimal string is used to name an object but there - are multiple objects that share the string as the prefix of their - names, the code lists these ambiguous candidates in a help message. - These object names are now sorted according to their types for - easier eyeballing. - - Will merge to 'master'. - - -* cf/submodule-progress-dissociate (2018-05-22) 3 commits - (merged to 'next' on 2018-05-22 at 9b3b96c54b) - + submodule: add --dissociate option to add/update commands - + submodule: add --progress option to add command - + submodule: clean up substitutions in script - - "git submodule update" and "git submodule add" supported the - "--reference" option to borrow objects from a neighbouring local - repository like "git clone" does, but lacked the more recent - invention "--dissociate". Also "git submodule add" has been taught - to take the "--progress" option. - - Will merge to 'master'. - - -* dd/send-email-reedit (2018-05-06) 1 commit - (merged to 'next' on 2018-05-22 at 1f4c98324f) - + git-send-email: allow re-editing of message - - "git send-email" can sometimes offer confirmation dialog "Send this - email?" with choices 'Yes', 'No', 'Quit', and 'All'. A new action - 'Edit' has been added to this dialog's choice. - - Will merge to 'master'. - - * js/branch-diff (2018-05-16) 19 commits - fixup! Add a function to solve least-cost assignment problems - completion: support branch-diff @@ -1120,59 +977,6 @@ of the repositories listed at cf. -* js/sequencer-and-root-commits (2018-05-06) 6 commits - (merged to 'next' on 2018-05-22 at c1a62f5bc9) - + rebase --rebase-merges: root commits can be cousins, too - + rebase --rebase-merges: a "merge" into a new root is a fast-forward - + sequencer: allow introducing new root commits - + rebase -i --root: let the sequencer handle even the initial part - + sequencer: learn about the special "fake root commit" handling - + sequencer: extract helper to update active_cache_tree - - The implementation of "git rebase -i --root" has been updated to use - the sequencer machinery more. - - Will merge to 'master'. - - -* js/use-bug-macro (2018-05-10) 5 commits - (merged to 'next' on 2018-05-22 at fd848c39ae) - + BUG_exit_code: fix sparse "symbol not declared" warning - + Convert remaining die*(BUG) messages - + Replace all die("BUG: ...") calls by BUG() ones - + run-command: use BUG() to report bugs, not die() - + test-tool: help verifying BUG() code paths - - Developer support update, by using BUG() macro instead of die() to - mark codepaths that should not happen more clearly. - - Will merge to 'master'. - Further updates can come on top later. - cf. <20180507090109.GA367@sigill.intra.peff.net> - - -* jt/partial-clone-proto-v2 (2018-05-06) 4 commits - (merged to 'next' on 2018-05-23 at f8b3692e8e) - + {fetch,upload}-pack: support filter in protocol v2 - + upload-pack: read config when serving protocol v2 - + upload-pack: fix error message typo - + Merge branch 'bw/protocol-v2' into jt/partial-clone-proto-v2 - - Transfer protocol v2 learned to support the partial clone. - - Will merge to 'master'. - - -* ma/doc-expand-tabs (2018-05-02) 1 commit - - revisions.txt: expand tabs to spaces in diagram - - Fix one instance of asciidoctor's misformatting by expanding a tab - into spaces in a literal block. - - Will discard. This approach is less maintainable than the approach - taken by bc/asciidoctor-tab-width topic. - - * sb/object-store-alloc (2018-05-16) 13 commits - alloc: allow arbitrary repositories for alloc functions - object: allow create_object to handle arbitrary repositories @@ -1192,6 +996,8 @@ of the repositories listed at The conversion to pass "the_repository" and then "a_repository" throughout the object access API continues. + Is this ready for 'next'? + * tb/grep-column (2018-05-14) 7 commits - contrib/git-jump/git-jump: jump to match column in addition to line @@ -1206,171 +1012,88 @@ of the repositories listed at "git grep" learned the "--column" option that gives not just the line number but the column number of the hit. + What's the doneness of this topic? -* bc/object-id (2018-05-02) 42 commits - (merged to 'next' on 2018-05-23 at 916bcce829) - + merge-one-file: compute empty blob object ID - + add--interactive: compute the empty tree value - + Update shell scripts to compute empty tree object ID - + sha1_file: only expose empty object constants through git_hash_algo - + dir: use the_hash_algo for empty blob object ID - + sequencer: use the_hash_algo for empty tree object ID - + cache-tree: use is_empty_tree_oid - + sha1_file: convert cached object code to struct object_id - + builtin/reset: convert use of EMPTY_TREE_SHA1_BIN - + builtin/receive-pack: convert one use of EMPTY_TREE_SHA1_HEX - + wt-status: convert two uses of EMPTY_TREE_SHA1_HEX - + submodule: convert several uses of EMPTY_TREE_SHA1_HEX - + sequencer: convert one use of EMPTY_TREE_SHA1_HEX - + merge: convert empty tree constant to the_hash_algo - + builtin/merge: switch tree functions to use object_id - + builtin/am: convert uses of EMPTY_TREE_SHA1_BIN to the_hash_algo - + sha1-file: add functions for hex empty tree and blob OIDs - + builtin/receive-pack: avoid hard-coded constants for push certs - + diff: specify abbreviation size in terms of the_hash_algo - + upload-pack: replace use of several hard-coded constants - + revision: replace use of hard-coded constants - + http: eliminate hard-coded constants - + dir: convert struct untracked_cache_dir to object_id - + commit: convert uses of get_sha1_hex to get_oid_hex - + index-pack: abstract away hash function constant - + pack-redundant: convert linked lists to use struct object_id - + Update struct index_state to use struct object_id - + split-index: convert struct split_index to object_id - + submodule-config: convert structures to object_id - + fsck: convert static functions to struct object_id - + tree-walk: convert get_tree_entry_follow_symlinks to object_id - + tree-walk: avoid hard-coded 20 constant - + pack-redundant: abstract away hash algorithm - + pack-objects: abstract away hash algorithm - + packfile: abstract away hash constant values - + packfile: convert find_pack_entry to object_id - + sha1-file: convert freshen functions to object_id - + packfile: convert has_sha1_pack to object_id - + packfile: remove unused member from struct pack_entry - + Remove unused member in struct object_context - + server-info: remove unused members from struct pack_info - + cache: add a function to read an object ID from a buffer - - Conversion from uchar[20] to struct object_id continues. - - Will merge to 'master'. - - -* bp/merge-rename-config (2018-05-08) 3 commits - (merged to 'next' on 2018-05-22 at 911440a742) - + merge: pass aggressive when rename detection is turned off - + merge: add merge.renames config setting - + merge: update documentation for {merge,diff}.renameLimit - (this branch is used by ma/unpack-trees-free-msgs.) - With merge.renames configuration set to false, the recursive merge - strategy can be told not to spend cycles trying to find renamed - paths and merge them accordingly. +* tb/grep-only-matching (2018-05-14) 2 commits + - builtin/grep.c: teach '-o', '--only-matching' to 'git-grep' + - grep.c: extract show_line_header() + (this branch uses tb/grep-column.) - Will merge to 'master'. + What's the doneness of this topic? * sb/diff-color-move-more (2018-05-21) 8 commits - - diff: color-moved white space handling options imply color-moved - - diff.c: add --color-moved-ignore-space-delta option - - diff.c: decouple white space treatment from move detection algorithm - - diff.c: add a blocks mode for moved code detection - - diff.c: adjust hash function signature to match hashmap expectation - - diff.c: do not pass diff options as keydata to hashmap - - xdiff/xdiffi.c: remove unneeded function declarations - - xdiff/xdiff.h: remove unused flags + (merged to 'next' on 2018-05-24 at 45f3fb7975) + + diff: color-moved white space handling options imply color-moved + + diff.c: add --color-moved-ignore-space-delta option + + diff.c: decouple white space treatment from move detection algorithm + + diff.c: add a blocks mode for moved code detection + + diff.c: adjust hash function signature to match hashmap expectation + + diff.c: do not pass diff options as keydata to hashmap + + xdiff/xdiffi.c: remove unneeded function declarations + + xdiff/xdiff.h: remove unused flags "git diff --color-moved" feature has further been tweaked. - Will merge to 'next'. + Will kick back to 'pu'. + cf. * ds/generation-numbers (2018-05-22) 11 commits - - commit-graph.txt: update design document - - merge: check config before loading commits - - commit: use generation number in remove_redundant() - - commit: add short-circuit to paint_down_to_common() - - commit: use generation numbers for in_merge_bases() - - ref-filter: use generation number for --contains - - commit-graph: always load commit-graph information - - commit: use generations in paint_down_to_common() - - commit-graph: compute generation numbers - - commit: add generation number to struct commit - - ref-filter: fix outdated comment on in_commit_list - (this branch is used by ds/commit-graph-lockfile-fix.) + (merged to 'next' on 2018-05-24 at 56fc38a1b6) + + commit-graph.txt: update design document + + merge: check config before loading commits + + commit: use generation number in remove_redundant() + + commit: add short-circuit to paint_down_to_common() + + commit: use generation numbers for in_merge_bases() + + ref-filter: use generation number for --contains + + commit-graph: always load commit-graph information + + commit: use generations in paint_down_to_common() + + commit-graph: compute generation numbers + + commit: add generation number to struct commit + + ref-filter: fix outdated comment on in_commit_list + (this branch is used by ds/commit-graph-fsck and ds/commit-graph-lockfile-fix.) A recently added "commit-graph" datafile has learned to store pre-computed generation numbers to speed up the decisions to stop history traversal. - Will merge to 'next'. + Will merge to 'master'. * nd/command-list (2018-05-21) 17 commits - - completion: allow to customize the completable command list - - completion: add and use --list-cmds=alias - - completion: add and use --list-cmds=nohelpers - - Move declaration for alias.c to alias.h - - completion: reduce completable command list - - completion: let git provide the completable command list - - command-list.txt: documentation and guide line - - help: use command-list.txt for the source of guides - - help: add "-a --verbose" to list all commands with synopsis - - git: support --list-cmds=list- - - completion: implement and use --list-cmds=main,others - - git --list-cmds: collect command list in a string_list - - git.c: convert --list-* to --list-cmds=* - - Remove common-cmds.h - - help: use command-list.h for common command list - - generate-cmds.sh: export all commands to command-list.h - - generate-cmds.sh: factor out synopsis extract code + (merged to 'next' on 2018-05-24 at 093e983b05) + + completion: allow to customize the completable command list + + completion: add and use --list-cmds=alias + + completion: add and use --list-cmds=nohelpers + + Move declaration for alias.c to alias.h + + completion: reduce completable command list + + completion: let git provide the completable command list + + command-list.txt: documentation and guide line + + help: use command-list.txt for the source of guides + + help: add "-a --verbose" to list all commands with synopsis + + git: support --list-cmds=list- + + completion: implement and use --list-cmds=main,others + + git --list-cmds: collect command list in a string_list + + git.c: convert --list-* to --list-cmds=* + + Remove common-cmds.h + + help: use command-list.h for common command list + + generate-cmds.sh: export all commands to command-list.h + + generate-cmds.sh: factor out synopsis extract code + (this branch is used by nd/complete-config-vars.) The list of commands with their various attributes were spread across a few places in the build procedure, but it now is getting a bit more consolidated to allow more automation. - Will merge to 'next'. - - -* sg/complete-paths (2018-05-21) 13 commits - (merged to 'next' on 2018-05-22 at a00b992aec) - + t9902-completion: exercise __git_complete_index_file() directly - + completion: don't return with error from __gitcomp_file_direct() - (merged to 'next' on 2018-05-08 at 2a11444f90) - + completion: fill COMPREPLY directly when completing paths - + completion: improve handling quoted paths in 'git ls-files's output - + completion: remove repeated dirnames with 'awk' during path completion - + t9902-completion: ignore COMPREPLY element order in some tests - + completion: use 'awk' to strip trailing path components - + completion: let 'ls-files' and 'diff-index' filter matching paths - + completion: improve handling quoted paths on the command line - + completion: support completing non-ASCII pathnames - + completion: simplify prefix path component handling during path completion - + completion: move __git_complete_index_file() next to its helpers - + t9902-completion: add tests demonstrating issues with quoted pathnames - - Command line completion (in contrib/) learned to complete pathnames - for various commands better. - - Will merge to 'master'. - - -* sb/blame-color (2018-04-24) 3 commits - (merged to 'next' on 2018-05-23 at 2e9c0daf0b) - + builtin/blame: add new coloring scheme config - + builtin/blame: highlight recently changed lines - + builtin/blame: dim uninteresting metadata lines - - "git blame" learns to unhighlight uninteresting metadata from the - originating commit on lines that are the same as the previous one, - and also paint lines in different colors depending on the age of - the commit. - Will merge to 'master'. -* jk/branch-l-0-deprecation (2018-03-26) 3 commits +* jk/branch-l-0-deprecation (2018-05-25) 5 commits + (merged to 'next' on 2018-05-30 at a94574dfd5) + + branch: customize "-l" warning in list mode + + branch: issue "-l" deprecation warning after pager starts (merged to 'next' on 2018-04-11 at 9b2b0305dd) + branch: deprecate "-l" option + t: switch "branch -l" to "branch --create-reflog" @@ -1387,7 +1110,7 @@ of the repositories listed at Perhaps merge to 'master' immediately after 2.18 release? -* jk/branch-l-1-removal (2018-03-26) 1 commit +* jk/branch-l-1-removal (2018-05-30) 1 commit - branch: drop deprecated "-l" option (this branch is used by jk/branch-l-2-reincarnation; uses jk/branch-l-0-deprecation.) @@ -1396,7 +1119,7 @@ of the repositories listed at Will keep in 'pu'. -* jk/branch-l-2-reincarnation (2018-03-26) 1 commit +* jk/branch-l-2-reincarnation (2018-05-30) 1 commit - branch: make "-l" a synonym for "--list" (this branch uses jk/branch-l-0-deprecation and jk/branch-l-1-removal.) @@ -1435,3 +1158,14 @@ of the repositories listed at Retracted. cf. <0de30972-b0a2-67e8-7cff-c19daf9ece8b@gmail.com> + + +* ma/doc-expand-tabs (2018-05-02) 1 commit + . revisions.txt: expand tabs to spaces in diagram + + Fix one instance of asciidoctor's misformatting by expanding a tab + into spaces in a literal block. + + Discarded. + This approach is less maintainable than the approach taken by + bc/asciidoctor-tab-width topic.