From 3ebd1484183fed4fc69277e4f3efd09135df8bb3 Mon Sep 17 00:00:00 2001 From: Lorenz Leutgeb Date: Wed, 1 Nov 2023 22:10:22 +0100 Subject: [PATCH] dry: Add descriptions --- doc/git-a/description.md | 7 + doc/git-aa/description.md | 8 + doc/git-add-alias/description.md | 8 + doc/git-add-cached/description.md | 29 +++ doc/git-add-deleted/description.md | 29 +++ doc/git-add-ignored/description.md | 29 +++ doc/git-add-killed/description.md | 29 +++ doc/git-add-modified/description.md | 29 +++ doc/git-add-others/description.md | 29 +++ doc/git-add-stage/description.md | 29 +++ doc/git-add-unmerged/description.md | 29 +++ doc/git-add/description.md | 42 ++++ doc/git-alias/description.md | 7 + doc/git-aliases/description.md | 21 ++ doc/git-ap/description.md | 9 + doc/git-archive/description.md | 10 + doc/git-assume-all/description.md | 9 + .../description.md | 50 +++++ doc/git-assume/description.md | 9 + doc/git-assumed/description.md | 9 + doc/git-au/description.md | 26 +++ doc/git-b/description.md | 7 + doc/git-bed/description.md | 9 + doc/git-bm/description.md | 3 + doc/git-bnm/description.md | 3 + doc/git-branch-commit-first/description.md | 39 ++++ doc/git-branch-commit-last/description.md | 38 ++++ doc/git-branch-commit-next/description.md | 38 ++++ doc/git-branch-commit-prev/description.md | 38 ++++ doc/git-branch-commit/description.md | 14 ++ doc/git-branch/description.md | 38 ++++ doc/git-branches/description.md | 15 ++ doc/git-bsd/description.md | 13 ++ doc/git-bv/description.md | 17 ++ doc/git-bvv/description.md | 17 ++ doc/git-c/description.md | 7 + doc/git-ca/description.md | 7 + doc/git-caa/description.md | 7 + doc/git-caam/description.md | 7 + doc/git-caane/description.md | 7 + doc/git-cam/description.md | 7 + doc/git-cane/description.md | 7 + doc/git-chart/description.md | 47 ++++ doc/git-cherry-pick-merge/description.md | 9 + doc/git-churn/description.md | 61 +++++ doc/git-ci/description.md | 7 + doc/git-cleaner/description.md | 20 ++ doc/git-cleanest/description.md | 23 ++ doc/git-cleanout/description.md | 7 + doc/git-clone-lean/description.md | 37 +++ doc/git-cloner/description.md | 7 + doc/git-cm/description.md | 7 + doc/git-co/description.md | 7 + doc/git-cob/description.md | 7 + doc/git-cog/description.md | 7 + doc/git-commit-is-merge/description.md | 7 + .../description.md | 56 +++++ doc/git-commit-parents/description.md | 7 + doc/git-cong/description.md | 7 + doc/git-count/description.md | 0 doc/git-cp/description.md | 9 + doc/git-cpa/description.md | 7 + doc/git-cpc/description.md | 7 + doc/git-cpn/description.md | 7 + doc/git-cpnx/description.md | 12 + doc/git-current-branch/description.md | 16 ++ doc/git-cvs-e/description.md | 7 + doc/git-cvs-i/description.md | 7 + doc/git-cvs/description.md | 17 ++ doc/git-d/description.md | 7 + doc/git-dc/description.md | 7 + doc/git-dd/description.md | 9 + doc/git-debug/description.md | 14 ++ doc/git-default-branch/description.md | 8 + doc/git-diff-all/description.md | 7 + doc/git-diff-changes/description.md | 7 + doc/git-diff-chunk/description.md | 19 ++ doc/git-diff-deep/description.md | 7 + doc/git-diff-staged/description.md | 7 + doc/git-diff-stat/description.md | 7 + doc/git-diff/description.md | 24 ++ doc/git-discard/description.md | 7 + doc/git-ds/description.md | 7 + doc/git-dw/description.md | 7 + doc/git-dwd/description.md | 7 + doc/git-edit-cached/description.md | 29 +++ doc/git-edit-deleted/description.md | 29 +++ doc/git-edit-ignored/description.md | 29 +++ doc/git-edit-killed/description.md | 29 +++ doc/git-edit-modified/description.md | 29 +++ doc/git-edit-others/description.md | 27 +++ doc/git-edit-stage/description.md | 29 +++ doc/git-edit-unmerged/description.md | 29 +++ doc/git-edit/description.md | 31 +++ doc/git-exec/description.md | 10 + doc/git-expunge/description.md | 15 ++ doc/git-f/description.md | 7 + doc/git-fa/description.md | 7 + doc/git-fav/description.md | 7 + doc/git-fixup/description.md | 11 + doc/git-g/description.md | 11 + doc/git-get-git-put/description.md | 45 ++++ doc/git-get/description.md | 15 ++ doc/git-gg/description.md | 9 + doc/git-gitk-conflict/description.md | 7 + doc/git-gitk-history-all/description.md | 9 + doc/git-gitk/description.md | 6 + doc/git-gn/description.md | 9 + doc/git-graphviz/description.md | 17 ++ doc/git-grep-ack/description.md | 7 + doc/git-grep-all/description.md | 13 ++ doc/git-grep-group/description.md | 13 ++ doc/git-grep/description.md | 28 +++ doc/git-heads/description.md | 9 + doc/git-hew-dry-run/description.md | 34 +++ doc/git-hew-local-dry-run/description.md | 38 ++++ doc/git-hew-local/description.md | 38 ++++ doc/git-hew-remote-dry-run/description.md | 38 ++++ doc/git-hew-remote/description.md | 38 ++++ doc/git-hew/description.md | 34 +++ doc/git-ignore/description.md | 7 + doc/git-inbound/description.md | 9 + doc/git-init-empty/description.md | 10 + doc/git-initer/description.md | 13 ++ doc/git-intercommit/description.md | 11 + doc/git-issues/description.md | 25 +++ doc/git-l/description.md | 7 + doc/git-last-tag/description.md | 17 ++ doc/git-last-tagged/description.md | 7 + doc/git-lfp/description.md | 9 + doc/git-lg/description.md | 7 + doc/git-ll/description.md | 31 +++ doc/git-lll/description.md | 31 +++ doc/git-lo/description.md | 7 + doc/git-log-1-day/description.md | 31 +++ doc/git-log-1-hour/description.md | 31 +++ doc/git-log-1-month/description.md | 31 +++ doc/git-log-1-week/description.md | 31 +++ doc/git-log-1-year/description.md | 31 +++ doc/git-log-date-first/description.md | 10 + doc/git-log-date-last/description.md | 9 + doc/git-log-fetched/description.md | 9 + doc/git-log-fresh/description.md | 7 + doc/git-log-graph/description.md | 1 + doc/git-log-list-long/description.md | 32 +++ doc/git-log-list/description.md | 32 +++ doc/git-log-local/description.md | 1 + doc/git-log-my-day/description.md | 31 +++ doc/git-log-my-hour/description.md | 31 +++ doc/git-log-my-month/description.md | 31 +++ doc/git-log-my-week/description.md | 31 +++ doc/git-log-my-year/description.md | 31 +++ doc/git-log-my/description.md | 7 + .../description.md | 9 + doc/git-log-of-count-and-day/description.md | 9 + doc/git-log-of-count-and-email/description.md | 9 + .../description.md | 9 + .../description.md | 9 + .../description.md | 9 + doc/git-log-of-count-and-hour/description.md | 9 + doc/git-log-of-count-and-month/description.md | 9 + .../description.md | 9 + doc/git-log-of-count-and-week/description.md | 9 + doc/git-log-of-count-and-year/description.md | 9 + doc/git-log-of-day-and-count/description.md | 9 + .../description.md | 9 + doc/git-log-of-email-and-count/description.md | 9 + .../description.md | 9 + .../description.md | 9 + doc/git-log-of-hour-and-count/description.md | 9 + .../description.md | 9 + doc/git-log-of-month-and-count/description.md | 9 + doc/git-log-of-week-and-count/description.md | 9 + .../description.md | 9 + doc/git-log-of-year-and-count/description.md | 9 + doc/git-log-of/description.md | 212 ++++++++++++++++++ doc/git-log-refs/description.md | 7 + doc/git-log-timeline/description.md | 1 + doc/git-log/description.md | 94 ++++++++ doc/git-lor/description.md | 7 + doc/git-lp/description.md | 7 + doc/git-ls/description.md | 7 + doc/git-lsd/description.md | 7 + doc/git-lsfn/description.md | 7 + doc/git-lsio/description.md | 31 +++ doc/git-lto/description.md | 9 + doc/git-m/description.md | 7 + doc/git-ma/description.md | 7 + doc/git-mainly/description.md | 11 + doc/git-mc/description.md | 7 + doc/git-merge-safe/description.md | 33 +++ doc/git-merge-span-diff/description.md | 14 ++ doc/git-merge-span-difftool/description.md | 14 ++ doc/git-merge-span-log/description.md | 14 ++ doc/git-merge-span/description.md | 17 ++ doc/git-mncnf/description.md | 9 + doc/git-move-alias/description.md | 8 + doc/git-o/description.md | 7 + doc/git-optimizer/description.md | 21 ++ doc/git-orphans/description.md | 15 ++ doc/git-ours-git-theirs/description.md | 28 +++ doc/git-ours/description.md | 15 ++ doc/git-outbound/description.md | 9 + doc/git-p/description.md | 7 + doc/git-panic/description.md | 9 + doc/git-pf/description.md | 7 + doc/git-pr/description.md | 47 ++++ doc/git-prp/description.md | 45 ++++ doc/git-pruner/description.md | 13 ++ doc/git-publish-git-unpublish/description.md | 8 + doc/git-publish/description.md | 18 ++ doc/git-pull1/description.md | 9 + doc/git-push1/description.md | 9 + doc/git-pushy/description.md | 14 ++ doc/git-put/description.md | 12 + doc/git-rb/description.md | 7 + doc/git-rba/description.md | 7 + doc/git-rbc/description.md | 9 + doc/git-rbi/description.md | 7 + doc/git-rbiu/description.md | 42 ++++ doc/git-rbs/description.md | 7 + doc/git-rebase-branch/description.md | 7 + .../description.md | 7 + doc/git-rebase-recent/description.md | 9 + doc/git-refs-by-date/description.md | 9 + doc/git-reincarnate/description.md | 14 ++ doc/git-remote-ref/description.md | 7 + doc/git-remotes-prune/description.md | 12 + doc/git-remotes-push/description.md | 7 + doc/git-repacker/description.md | 36 +++ .../description.md | 12 + doc/git-reset-commit-hard/description.md | 12 + doc/git-reset-commit/description.md | 12 + doc/git-reset-to-pristine/description.md | 12 + doc/git-reset-to-upstream/description.md | 12 + doc/git-reset/description.md | 28 +++ .../description.md | 9 + .../description.md | 9 + doc/git-rl/description.md | 9 + doc/git-rr/description.md | 7 + doc/git-rrp/description.md | 7 + doc/git-rrs/description.md | 7 + doc/git-rru/description.md | 7 + doc/git-rv/description.md | 9 + doc/git-rvnc/description.md | 10 + doc/git-s/description.md | 7 + doc/git-sb/description.md | 7 + doc/git-sbdo/description.md | 7 + doc/git-sbto/description.md | 7 + doc/git-search-commits/description.md | 27 +++ doc/git-serve/description.md | 9 + doc/git-show-unreachable/description.md | 9 + doc/git-sm/description.md | 9 + doc/git-sma/description.md | 7 + doc/git-smi/description.md | 7 + doc/git-sms/description.md | 7 + doc/git-smu/description.md | 7 + doc/git-smui/description.md | 7 + doc/git-smuir/description.md | 9 + doc/git-snapshot/description.md | 28 +++ doc/git-ss/description.md | 7 + doc/git-ssb/description.md | 7 + doc/git-stashes/description.md | 17 ++ doc/git-submodule/description.md | 14 ++ doc/git-summary/description.md | 70 ++++++ doc/git-svn-b/description.md | 7 + doc/git-svn-c/description.md | 7 + doc/git-svn-cp/description.md | 7 + doc/git-svn-m/description.md | 7 + doc/git-svn/description.md | 21 ++ doc/git-tags/description.md | 21 ++ doc/git-theirs/description.md | 15 ++ doc/git-top/description.md | 8 + doc/git-topic-base-branch/description.md | 49 ++++ doc/git-topic-begin/description.md | 27 +++ doc/git-topic-end/description.md | 34 +++ doc/git-topic-move/description.md | 15 ++ doc/git-topic-sync/description.md | 19 ++ doc/git-topic/description.md | 61 +++++ .../description.md | 11 + doc/git-track/description.md | 9 + doc/git-unadd/description.md | 7 + doc/git-unassume-all/description.md | 9 + doc/git-unassume/description.md | 9 + doc/git-uncommit/description.md | 7 + doc/git-undo-commit-hard-clean/description.md | 12 + doc/git-undo-commit-hard/description.md | 12 + doc/git-undo-commit/description.md | 12 + doc/git-undo-to-pristine/description.md | 12 + doc/git-undo-to-upstream/description.md | 12 + doc/git-undo/description.md | 28 +++ doc/git-unpublish/description.md | 18 ++ doc/git-untrack/description.md | 9 + doc/git-unwip/description.md | 15 ++ doc/git-upstream-branch/description.md | 14 ++ doc/git-w/description.md | 7 + doc/git-whatis/description.md | 7 + doc/git-who/description.md | 7 + doc/git-whois/description.md | 8 + doc/git-wip-git-unwip/description.md | 30 +++ doc/git-wip/description.md | 15 ++ 301 files changed, 4900 insertions(+) create mode 100644 doc/git-a/description.md create mode 100644 doc/git-aa/description.md create mode 100644 doc/git-add-alias/description.md create mode 100644 doc/git-add-cached/description.md create mode 100644 doc/git-add-deleted/description.md create mode 100644 doc/git-add-ignored/description.md create mode 100644 doc/git-add-killed/description.md create mode 100644 doc/git-add-modified/description.md create mode 100644 doc/git-add-others/description.md create mode 100644 doc/git-add-stage/description.md create mode 100644 doc/git-add-unmerged/description.md create mode 100644 doc/git-add/description.md create mode 100644 doc/git-alias/description.md create mode 100644 doc/git-aliases/description.md create mode 100644 doc/git-ap/description.md create mode 100644 doc/git-archive/description.md create mode 100644 doc/git-assume-all/description.md create mode 100644 doc/git-assume-and-git-unassume/description.md create mode 100644 doc/git-assume/description.md create mode 100644 doc/git-assumed/description.md create mode 100644 doc/git-au/description.md create mode 100644 doc/git-b/description.md create mode 100644 doc/git-bed/description.md create mode 100644 doc/git-bm/description.md create mode 100644 doc/git-bnm/description.md create mode 100644 doc/git-branch-commit-first/description.md create mode 100644 doc/git-branch-commit-last/description.md create mode 100644 doc/git-branch-commit-next/description.md create mode 100644 doc/git-branch-commit-prev/description.md create mode 100644 doc/git-branch-commit/description.md create mode 100644 doc/git-branch/description.md create mode 100644 doc/git-branches/description.md create mode 100644 doc/git-bsd/description.md create mode 100644 doc/git-bv/description.md create mode 100644 doc/git-bvv/description.md create mode 100644 doc/git-c/description.md create mode 100644 doc/git-ca/description.md create mode 100644 doc/git-caa/description.md create mode 100644 doc/git-caam/description.md create mode 100644 doc/git-caane/description.md create mode 100644 doc/git-cam/description.md create mode 100644 doc/git-cane/description.md create mode 100644 doc/git-chart/description.md create mode 100644 doc/git-cherry-pick-merge/description.md create mode 100644 doc/git-churn/description.md create mode 100644 doc/git-ci/description.md create mode 100644 doc/git-cleaner/description.md create mode 100644 doc/git-cleanest/description.md create mode 100644 doc/git-cleanout/description.md create mode 100644 doc/git-clone-lean/description.md create mode 100644 doc/git-cloner/description.md create mode 100644 doc/git-cm/description.md create mode 100644 doc/git-co/description.md create mode 100644 doc/git-cob/description.md create mode 100644 doc/git-cog/description.md create mode 100644 doc/git-commit-is-merge/description.md create mode 100644 doc/git-commit-message-key-lines/description.md create mode 100644 doc/git-commit-parents/description.md create mode 100644 doc/git-cong/description.md create mode 100644 doc/git-count/description.md create mode 100644 doc/git-cp/description.md create mode 100644 doc/git-cpa/description.md create mode 100644 doc/git-cpc/description.md create mode 100644 doc/git-cpn/description.md create mode 100644 doc/git-cpnx/description.md create mode 100644 doc/git-current-branch/description.md create mode 100644 doc/git-cvs-e/description.md create mode 100644 doc/git-cvs-i/description.md create mode 100644 doc/git-cvs/description.md create mode 100644 doc/git-d/description.md create mode 100644 doc/git-dc/description.md create mode 100644 doc/git-dd/description.md create mode 100644 doc/git-debug/description.md create mode 100644 doc/git-default-branch/description.md create mode 100644 doc/git-diff-all/description.md create mode 100644 doc/git-diff-changes/description.md create mode 100644 doc/git-diff-chunk/description.md create mode 100644 doc/git-diff-deep/description.md create mode 100644 doc/git-diff-staged/description.md create mode 100644 doc/git-diff-stat/description.md create mode 100644 doc/git-diff/description.md create mode 100644 doc/git-discard/description.md create mode 100644 doc/git-ds/description.md create mode 100644 doc/git-dw/description.md create mode 100644 doc/git-dwd/description.md create mode 100644 doc/git-edit-cached/description.md create mode 100644 doc/git-edit-deleted/description.md create mode 100644 doc/git-edit-ignored/description.md create mode 100644 doc/git-edit-killed/description.md create mode 100644 doc/git-edit-modified/description.md create mode 100644 doc/git-edit-others/description.md create mode 100644 doc/git-edit-stage/description.md create mode 100644 doc/git-edit-unmerged/description.md create mode 100644 doc/git-edit/description.md create mode 100644 doc/git-exec/description.md create mode 100644 doc/git-expunge/description.md create mode 100644 doc/git-f/description.md create mode 100644 doc/git-fa/description.md create mode 100644 doc/git-fav/description.md create mode 100644 doc/git-fixup/description.md create mode 100644 doc/git-g/description.md create mode 100644 doc/git-get-git-put/description.md create mode 100644 doc/git-get/description.md create mode 100644 doc/git-gg/description.md create mode 100644 doc/git-gitk-conflict/description.md create mode 100644 doc/git-gitk-history-all/description.md create mode 100644 doc/git-gitk/description.md create mode 100644 doc/git-gn/description.md create mode 100644 doc/git-graphviz/description.md create mode 100644 doc/git-grep-ack/description.md create mode 100644 doc/git-grep-all/description.md create mode 100644 doc/git-grep-group/description.md create mode 100644 doc/git-grep/description.md create mode 100644 doc/git-heads/description.md create mode 100644 doc/git-hew-dry-run/description.md create mode 100644 doc/git-hew-local-dry-run/description.md create mode 100644 doc/git-hew-local/description.md create mode 100644 doc/git-hew-remote-dry-run/description.md create mode 100644 doc/git-hew-remote/description.md create mode 100644 doc/git-hew/description.md create mode 100644 doc/git-ignore/description.md create mode 100644 doc/git-inbound/description.md create mode 100644 doc/git-init-empty/description.md create mode 100644 doc/git-initer/description.md create mode 100644 doc/git-intercommit/description.md create mode 100644 doc/git-issues/description.md create mode 100644 doc/git-l/description.md create mode 100644 doc/git-last-tag/description.md create mode 100644 doc/git-last-tagged/description.md create mode 100644 doc/git-lfp/description.md create mode 100644 doc/git-lg/description.md create mode 100644 doc/git-ll/description.md create mode 100644 doc/git-lll/description.md create mode 100644 doc/git-lo/description.md create mode 100644 doc/git-log-1-day/description.md create mode 100644 doc/git-log-1-hour/description.md create mode 100644 doc/git-log-1-month/description.md create mode 100644 doc/git-log-1-week/description.md create mode 100644 doc/git-log-1-year/description.md create mode 100644 doc/git-log-date-first/description.md create mode 100644 doc/git-log-date-last/description.md create mode 100644 doc/git-log-fetched/description.md create mode 100644 doc/git-log-fresh/description.md create mode 100644 doc/git-log-graph/description.md create mode 100644 doc/git-log-list-long/description.md create mode 100644 doc/git-log-list/description.md create mode 100644 doc/git-log-local/description.md create mode 100644 doc/git-log-my-day/description.md create mode 100644 doc/git-log-my-hour/description.md create mode 100644 doc/git-log-my-month/description.md create mode 100644 doc/git-log-my-week/description.md create mode 100644 doc/git-log-my-year/description.md create mode 100644 doc/git-log-my/description.md create mode 100644 doc/git-log-of-count-and-day-of-week/description.md create mode 100644 doc/git-log-of-count-and-day/description.md create mode 100644 doc/git-log-of-count-and-email/description.md create mode 100644 doc/git-log-of-count-and-format-with-date/description.md create mode 100644 doc/git-log-of-count-and-format/description.md create mode 100644 doc/git-log-of-count-and-hour-of-day/description.md create mode 100644 doc/git-log-of-count-and-hour/description.md create mode 100644 doc/git-log-of-count-and-month/description.md create mode 100644 doc/git-log-of-count-and-week-of-year/description.md create mode 100644 doc/git-log-of-count-and-week/description.md create mode 100644 doc/git-log-of-count-and-year/description.md create mode 100644 doc/git-log-of-day-and-count/description.md create mode 100644 doc/git-log-of-day-of-week-and-count/description.md create mode 100644 doc/git-log-of-email-and-count/description.md create mode 100644 doc/git-log-of-format-and-count-with-date/description.md create mode 100644 doc/git-log-of-format-and-count/description.md create mode 100644 doc/git-log-of-hour-and-count/description.md create mode 100644 doc/git-log-of-hour-of-day-and-count/description.md create mode 100644 doc/git-log-of-month-and-count/description.md create mode 100644 doc/git-log-of-week-and-count/description.md create mode 100644 doc/git-log-of-week-of-year-and-count/description.md create mode 100644 doc/git-log-of-year-and-count/description.md create mode 100644 doc/git-log-of/description.md create mode 100644 doc/git-log-refs/description.md create mode 100644 doc/git-log-timeline/description.md create mode 100644 doc/git-log/description.md create mode 100644 doc/git-lor/description.md create mode 100644 doc/git-lp/description.md create mode 100644 doc/git-ls/description.md create mode 100644 doc/git-lsd/description.md create mode 100644 doc/git-lsfn/description.md create mode 100644 doc/git-lsio/description.md create mode 100644 doc/git-lto/description.md create mode 100644 doc/git-m/description.md create mode 100644 doc/git-ma/description.md create mode 100644 doc/git-mainly/description.md create mode 100644 doc/git-mc/description.md create mode 100644 doc/git-merge-safe/description.md create mode 100644 doc/git-merge-span-diff/description.md create mode 100644 doc/git-merge-span-difftool/description.md create mode 100644 doc/git-merge-span-log/description.md create mode 100644 doc/git-merge-span/description.md create mode 100644 doc/git-mncnf/description.md create mode 100644 doc/git-move-alias/description.md create mode 100644 doc/git-o/description.md create mode 100644 doc/git-optimizer/description.md create mode 100644 doc/git-orphans/description.md create mode 100644 doc/git-ours-git-theirs/description.md create mode 100644 doc/git-ours/description.md create mode 100644 doc/git-outbound/description.md create mode 100644 doc/git-p/description.md create mode 100644 doc/git-panic/description.md create mode 100644 doc/git-pf/description.md create mode 100644 doc/git-pr/description.md create mode 100644 doc/git-prp/description.md create mode 100644 doc/git-pruner/description.md create mode 100644 doc/git-publish-git-unpublish/description.md create mode 100644 doc/git-publish/description.md create mode 100644 doc/git-pull1/description.md create mode 100644 doc/git-push1/description.md create mode 100644 doc/git-pushy/description.md create mode 100644 doc/git-put/description.md create mode 100644 doc/git-rb/description.md create mode 100644 doc/git-rba/description.md create mode 100644 doc/git-rbc/description.md create mode 100644 doc/git-rbi/description.md create mode 100644 doc/git-rbiu/description.md create mode 100644 doc/git-rbs/description.md create mode 100644 doc/git-rebase-branch/description.md create mode 100644 doc/git-rebase-interactive-branch/description.md create mode 100644 doc/git-rebase-recent/description.md create mode 100644 doc/git-refs-by-date/description.md create mode 100644 doc/git-reincarnate/description.md create mode 100644 doc/git-remote-ref/description.md create mode 100644 doc/git-remotes-prune/description.md create mode 100644 doc/git-remotes-push/description.md create mode 100644 doc/git-repacker/description.md create mode 100644 doc/git-reset-commit-hard-clean/description.md create mode 100644 doc/git-reset-commit-hard/description.md create mode 100644 doc/git-reset-commit/description.md create mode 100644 doc/git-reset-to-pristine/description.md create mode 100644 doc/git-reset-to-upstream/description.md create mode 100644 doc/git-reset/description.md create mode 100644 doc/git-rev-list-all-objects-by-size-and-name/description.md create mode 100644 doc/git-rev-list-all-objects-by-size/description.md create mode 100644 doc/git-rl/description.md create mode 100644 doc/git-rr/description.md create mode 100644 doc/git-rrp/description.md create mode 100644 doc/git-rrs/description.md create mode 100644 doc/git-rru/description.md create mode 100644 doc/git-rv/description.md create mode 100644 doc/git-rvnc/description.md create mode 100644 doc/git-s/description.md create mode 100644 doc/git-sb/description.md create mode 100644 doc/git-sbdo/description.md create mode 100644 doc/git-sbto/description.md create mode 100644 doc/git-search-commits/description.md create mode 100644 doc/git-serve/description.md create mode 100644 doc/git-show-unreachable/description.md create mode 100644 doc/git-sm/description.md create mode 100644 doc/git-sma/description.md create mode 100644 doc/git-smi/description.md create mode 100644 doc/git-sms/description.md create mode 100644 doc/git-smu/description.md create mode 100644 doc/git-smui/description.md create mode 100644 doc/git-smuir/description.md create mode 100644 doc/git-snapshot/description.md create mode 100644 doc/git-ss/description.md create mode 100644 doc/git-ssb/description.md create mode 100644 doc/git-stashes/description.md create mode 100644 doc/git-submodule/description.md create mode 100644 doc/git-summary/description.md create mode 100644 doc/git-svn-b/description.md create mode 100644 doc/git-svn-c/description.md create mode 100644 doc/git-svn-cp/description.md create mode 100644 doc/git-svn-m/description.md create mode 100644 doc/git-svn/description.md create mode 100644 doc/git-tags/description.md create mode 100644 doc/git-theirs/description.md create mode 100644 doc/git-top/description.md create mode 100644 doc/git-topic-base-branch/description.md create mode 100644 doc/git-topic-begin/description.md create mode 100644 doc/git-topic-end/description.md create mode 100644 doc/git-topic-move/description.md create mode 100644 doc/git-topic-sync/description.md create mode 100644 doc/git-topic/description.md create mode 100644 doc/git-track-all-remote-branches/description.md create mode 100644 doc/git-track/description.md create mode 100644 doc/git-unadd/description.md create mode 100644 doc/git-unassume-all/description.md create mode 100644 doc/git-unassume/description.md create mode 100644 doc/git-uncommit/description.md create mode 100644 doc/git-undo-commit-hard-clean/description.md create mode 100644 doc/git-undo-commit-hard/description.md create mode 100644 doc/git-undo-commit/description.md create mode 100644 doc/git-undo-to-pristine/description.md create mode 100644 doc/git-undo-to-upstream/description.md create mode 100644 doc/git-undo/description.md create mode 100644 doc/git-unpublish/description.md create mode 100644 doc/git-untrack/description.md create mode 100644 doc/git-unwip/description.md create mode 100644 doc/git-upstream-branch/description.md create mode 100644 doc/git-w/description.md create mode 100644 doc/git-whatis/description.md create mode 100644 doc/git-who/description.md create mode 100644 doc/git-whois/description.md create mode 100644 doc/git-wip-git-unwip/description.md create mode 100644 doc/git-wip/description.md diff --git a/doc/git-a/description.md b/doc/git-a/description.md new file mode 100644 index 00000000..cc847397 --- /dev/null +++ b/doc/git-a/description.md @@ -0,0 +1,7 @@ +Short for `git add`. + +Example: + +```shell +git a file.txt +``` diff --git a/doc/git-aa/description.md b/doc/git-aa/description.md new file mode 100644 index 00000000..5c533388 --- /dev/null +++ b/doc/git-aa/description.md @@ -0,0 +1,8 @@ +Short for "git add --all" (add all paths). + +Example: + +```shell +git aa +``` + diff --git a/doc/git-add-alias/description.md b/doc/git-add-alias/description.md new file mode 100644 index 00000000..6f67c8d9 --- /dev/null +++ b/doc/git-add-alias/description.md @@ -0,0 +1,8 @@ +Create a new Git alias. + +Example: + +```shell +git add-alias --local myalias mycommand +git add-alias --global myalias mycommand +``` diff --git a/doc/git-add-cached/description.md b/doc/git-add-cached/description.md new file mode 100644 index 00000000..0224d925 --- /dev/null +++ b/doc/git-add-cached/description.md @@ -0,0 +1,29 @@ +Add cached files. + +Example: + +```shell +git add-cached +``` + +Compare: + +* [git add-cached](../git-add-cached) (this alias) +* [git add-deleted](../git-add-deleted) +* [git add-others](../git-add-others) +* [git add-ignored](../git-add-ignored) +* [git add-killed](../git-add-killed) +* [git add-modified](../git-add-modified) +* [git add-stage](../git-add-stage) +* [git add-unmerged](../git-add-unmerged) + +Compare corresponding aliases for `edit-*`: + +* [git edit-cached](../git-edit-cached) +* [git edit-deleted](../git-edit-deleted) +* [git edit-others](../git-edit-others) +* [git edit-ignored](../git-edit-ignored) +* [git edit-killed](../git-edit-killed) +* [git edit-modified](../git-edit-modified) +* [git edit-stage](../git-edit-stage) +* [git edit-unmerged](../git-edit-unmerged) diff --git a/doc/git-add-deleted/description.md b/doc/git-add-deleted/description.md new file mode 100644 index 00000000..70897479 --- /dev/null +++ b/doc/git-add-deleted/description.md @@ -0,0 +1,29 @@ +Add deleted files. + +Example: + +```shell +git add-deleted +``` + +Compare: + +* [git add-cached](../git-add-cached) +* [git add-deleted](../git-add-deleted) (this alias) +* [git add-others](../git-add-others) +* [git add-ignored](../git-add-ignored) +* [git add-killed](../git-add-killed) +* [git add-modified](../git-add-modified) +* [git add-stage](../git-add-stage) +* [git add-unmerged](../git-add-unmerged) + +Compare corresponding aliases for `edit-*`: + +* [git edit-cached](../git-edit-cached) +* [git edit-deleted](../git-edit-deleted) +* [git edit-others](../git-edit-others) +* [git edit-ignored](../git-edit-ignored) +* [git edit-killed](../git-edit-killed) +* [git edit-modified](../git-edit-modified) +* [git edit-stage](../git-edit-stage) +* [git edit-unmerged](../git-edit-unmerged) diff --git a/doc/git-add-ignored/description.md b/doc/git-add-ignored/description.md new file mode 100644 index 00000000..c25fe822 --- /dev/null +++ b/doc/git-add-ignored/description.md @@ -0,0 +1,29 @@ +Add ignored files. + +Example: + +```shell +git add-ignored +``` + +Compare aliases for `add-*`: + +* [git add-cached](../git-add-cached) +* [git add-deleted](../git-add-deleted) +* [git add-others](../git-add-others) +* [git add-ignored](../git-add-ignored) (this alias) +* [git add-killed](../git-add-killed) +* [git add-modified](../git-add-modified) +* [git add-stage](../git-add-stage) +* [git add-unmerged](../git-add-unmerged) + +Compare aliases for `edit-*`: + +* [git edit-cached](../git-edit-cached) +* [git edit-deleted](../git-edit-deleted) +* [git edit-others](../git-edit-others) +* [git edit-ignored](../git-edit-ignored) +* [git edit-killed](../git-edit-killed) +* [git edit-modified](../git-edit-modified) +* [git edit-stage](../git-edit-stage) +* [git edit-unmerged](../git-edit-unmerged) diff --git a/doc/git-add-killed/description.md b/doc/git-add-killed/description.md new file mode 100644 index 00000000..0c64d20f --- /dev/null +++ b/doc/git-add-killed/description.md @@ -0,0 +1,29 @@ +Add killed files. + +Example: + +```shell +git add-killed +``` + +Compare: + +* [git add-cached](../git-add-cached) +* [git add-deleted](../git-add-deleted) +* [git add-others](../git-add-others) +* [git add-ignored](../git-add-ignored) +* [git add-killed](../git-add-killed) (this alias) +* [git add-modified](../git-add-modified) +* [git add-stage](../git-add-stage) +* [git add-unmerged](../git-add-unmerged) + +Compare corresponding aliases for `edit-*`: + +* [git edit-cached](../git-edit-cached) +* [git edit-deleted](../git-edit-deleted) +* [git edit-others](../git-edit-others) +* [git edit-ignored](../git-edit-ignored) +* [git edit-killed](../git-edit-killed) +* [git edit-modified](../git-edit-modified) +* [git edit-stage](../git-edit-stage) +* [git edit-unmerged](../git-edit-unmerged) diff --git a/doc/git-add-modified/description.md b/doc/git-add-modified/description.md new file mode 100644 index 00000000..36acaa03 --- /dev/null +++ b/doc/git-add-modified/description.md @@ -0,0 +1,29 @@ +Add modified files. + +Example: + +```shell +git add-modified +``` + +Compare: + +* [git add-cached](../git-add-cached) +* [git add-deleted](../git-add-deleted) +* [git add-others](../git-add-others) +* [git add-ignored](../git-add-ignored) +* [git add-killed](../git-add-killed) +* [git add-modified](../git-add-modified) (this alias) +* [git add-stage](../git-add-stage) +* [git add-unmerged](../git-add-unmerged) + +Compare corresponding aliases for `edit-*`: + +* [git edit-cached](../git-edit-cached) +* [git edit-deleted](../git-edit-deleted) +* [git edit-others](../git-edit-others) +* [git edit-ignored](../git-edit-ignored) +* [git edit-killed](../git-edit-killed) +* [git edit-modified](../git-edit-modified) +* [git edit-stage](../git-edit-stage) +* [git edit-unmerged](../git-edit-unmerged) diff --git a/doc/git-add-others/description.md b/doc/git-add-others/description.md new file mode 100644 index 00000000..fe4557e6 --- /dev/null +++ b/doc/git-add-others/description.md @@ -0,0 +1,29 @@ +Add other files. + +Example: + +```shell +git add-others +``` + +Compare: + +* [git add-cached](../git-add-cached) +* [git add-deleted](../git-add-deleted) +* [git add-others](../git-add-others) (this alias) +* [git add-ignored](../git-add-ignored) +* [git add-killed](../git-add-killed) +* [git add-modified](../git-add-modified) +* [git add-stage](../git-add-stage) +* [git add-unmerged](../git-add-unmerged) + +Compare corresponding aliases for `edit-*`: + +* [git edit-cached](../git-edit-cached) +* [git edit-deleted](../git-edit-deleted) +* [git edit-others](../git-edit-others) +* [git edit-ignored](../git-edit-ignored) +* [git edit-killed](../git-edit-killed) +* [git edit-modified](../git-edit-modified) +* [git edit-stage](../git-edit-stage) +* [git edit-unmerged](../git-edit-unmerged) diff --git a/doc/git-add-stage/description.md b/doc/git-add-stage/description.md new file mode 100644 index 00000000..3a0dfa22 --- /dev/null +++ b/doc/git-add-stage/description.md @@ -0,0 +1,29 @@ +Add stage files. + +Example: + +```shell +git add-stage +``` + +Compare: + +* [git add-cached](../git-add-cached) +* [git add-deleted](../git-add-deleted) +* [git add-others](../git-add-others) +* [git add-ignored](../git-add-ignored) +* [git add-killed](../git-add-killed) +* [git add-modified](../git-add-modified) +* [git add-stage](../git-add-stage) (this alias) +* [git add-unmerged](../git-add-unmerged) + +Compare corresponding aliases for `edit-*`: + +* [git edit-cached](../git-edit-cached) +* [git edit-deleted](../git-edit-deleted) +* [git edit-others](../git-edit-others) +* [git edit-ignored](../git-edit-ignored) +* [git edit-killed](../git-edit-killed) +* [git edit-modified](../git-edit-modified) +* [git edit-stage](../git-edit-stage) +* [git edit-unmerged](../git-edit-unmerged) diff --git a/doc/git-add-unmerged/description.md b/doc/git-add-unmerged/description.md new file mode 100644 index 00000000..3958fdd7 --- /dev/null +++ b/doc/git-add-unmerged/description.md @@ -0,0 +1,29 @@ +Add unmerged files. + +Example: + +```shell +git add-unmerged +``` + +Compare: + +* [git add-cached](../git-add-cached) +* [git add-deleted](../git-add-deleted) +* [git add-others](../git-add-others) +* [git add-ignored](../git-add-ignored) +* [git add-killed](../git-add-killed) +* [git add-modified](../git-add-modified) +* [git add-stage](../git-add-stage) (this alias) +* [git add-unmerged](../git-add-unmerged) + +Compare corresponding aliases for `edit-*`: + +* [git edit-cached](../git-edit-cached) +* [git edit-deleted](../git-edit-deleted) +* [git edit-others](../git-edit-others) +* [git edit-ignored](../git-edit-ignored) +* [git edit-killed](../git-edit-killed) +* [git edit-modified](../git-edit-modified) +* [git edit-stage](../git-edit-stage) +* [git edit-unmerged](../git-edit-unmerged) diff --git a/doc/git-add/description.md b/doc/git-add/description.md new file mode 100644 index 00000000..f3cec69c --- /dev/null +++ b/doc/git-add/description.md @@ -0,0 +1,42 @@ +# git add + +## Aliases to add files + + +### Shortcuts + +* [git a](../git-a) = add +* [git aa](../git-aa) = add --all +* [git ap](../git-ap) = add --patch +* [git au](../git-au) = add --update + + +### Add all paths of the given type + +Git alias: + +```git +add-cached = !"f() { git ls-files --cached | sort -u ; }; git add `f`" +add-deleted = !"f() { git ls-files --deleted | sort -u ; }; git add `f`" +add-others = !"f() { git ls-files --others | sort -u ; }; git add `f`" +add-ignored = !"f() { git ls-files --ignored | sort -u ; }; git add `f`" +add-killed = !"f() { git ls-files --killed | sort -u ; }; git add `f`" +add-modified = !"f() { git ls-files --modified | sort -u ; }; git add `f`" +add-stage = !"f() { git ls-files --stage | cut -f2 | sort -u ; }; git add `f`" +add-unmerged = !"f() { git ls-files --unmerged | cut -f2 | sort -u ; }; git add `f`" +``` + +Example: + +```shell +git add-cached +git add-deleted +git add-others +git add-ignored +git add-killed +git add-modified +git add-stage +git add-unmerged +``` + +These aliases intentionally match the aliases [git edit-*](../git-edit). diff --git a/doc/git-alias/description.md b/doc/git-alias/description.md new file mode 100644 index 00000000..4102b46f --- /dev/null +++ b/doc/git-alias/description.md @@ -0,0 +1,7 @@ +Git alias help. + +Example: + +```shell +git alias +``` diff --git a/doc/git-aliases/description.md b/doc/git-aliases/description.md new file mode 100644 index 00000000..2bab211a --- /dev/null +++ b/doc/git-aliases/description.md @@ -0,0 +1,21 @@ +List Git aliases. + +Example: + +```shell +git aliases +``` + +This alias is because friendly wording is easier to remember. + +Our friendly wording for plurals: + +* [git aliases](../git-aliases) + +* [git branches](../git-branches) + +* [git stashes](../git-stashes) + +* [git tags](../git-tags) + +Thanks to . diff --git a/doc/git-ap/description.md b/doc/git-ap/description.md new file mode 100644 index 00000000..a24bbff6 --- /dev/null +++ b/doc/git-ap/description.md @@ -0,0 +1,9 @@ +Short for "git add --patch" (add by patch). + +Example: + +```shell +git ap +``` + +Show each change, and ask if we want to stage it. diff --git a/doc/git-archive/description.md b/doc/git-archive/description.md new file mode 100644 index 00000000..a410d136 --- /dev/null +++ b/doc/git-archive/description.md @@ -0,0 +1,10 @@ +Create an archive file of everything in the repo. + +Example: + +```shell +git archive +``` + +This archive can be useful for backups, disaster recovery, +legal auditing, or sending the repo as a file to someone. diff --git a/doc/git-assume-all/description.md b/doc/git-assume-all/description.md new file mode 100644 index 00000000..b313f602 --- /dev/null +++ b/doc/git-assume-all/description.md @@ -0,0 +1,9 @@ +Assume all files are unchanged. + +Example: + +```shell +git assume-all +``` + +To see how this works, see [`git assume-*` and `git unassume-`](../git-assume-and-git-unassume). diff --git a/doc/git-assume-and-git-unassume/description.md b/doc/git-assume-and-git-unassume/description.md new file mode 100644 index 00000000..efc6c668 --- /dev/null +++ b/doc/git-assume-and-git-unassume/description.md @@ -0,0 +1,50 @@ +# git assume-* & git unassume-* + +## Use update-index and assume-unchanged to skip commits + +Git alias: + +```git +assume = update-index --assume-unchanged +assume-all = "!git st -s | awk {'print $2'} | xargs git assume" +assumed = !"git ls-files -v | grep ^h | cut -c 3-" + +unassume = update-index --no-assume-unchanged +unassume-all = "!git assumed | xargs git update-index --no-assume-unchanged" +``` + +Sometimes we want to change a file in a repo, but never check in your edits. + +We can't use .gitignore because the file is tracked. We use update-index. + +If you interact with big corporate projects, such as projects in Subversion, +then you might run into the need to ignore certain files which are under +Subversion control, yet you need to modify them but not commit. +The assume-unchanged flag comes to the rescue. + +Suppose we want to edit the file "passwords.txt" +and also be sure that we never check it in. + +Example: + +```shell +git status +modified passwords.txt +modified foo.txt + +git assume passwords.txt +git status +modified foo.txt + +git assumed +passwords.txt + +git unassume passwords.txt +git status +modified passwords.txt +modified foo.txt +``` + +Thanks + +Thanks diff --git a/doc/git-assume/description.md b/doc/git-assume/description.md new file mode 100644 index 00000000..e5dcc404 --- /dev/null +++ b/doc/git-assume/description.md @@ -0,0 +1,9 @@ +Assume files are unchanged. + +Example: + +```shell +git assume +``` + +To see how this works, see [`git assume-*` and `git unassume-*`](../git-assume-and-git-unassume). diff --git a/doc/git-assumed/description.md b/doc/git-assumed/description.md new file mode 100644 index 00000000..38a4fa83 --- /dev/null +++ b/doc/git-assumed/description.md @@ -0,0 +1,9 @@ +Show which files are assumed. + +Example: + +```shell +git assumed +``` + +To see how this works, see [`git assume-*` and `git unassume-*`](../git-assume-and-git-unassume). diff --git a/doc/git-au/description.md b/doc/git-au/description.md new file mode 100644 index 00000000..4bc72f65 --- /dev/null +++ b/doc/git-au/description.md @@ -0,0 +1,26 @@ +Short for `git add --update`. + +Add just the files that are updated. + +Example: + +```shell +git au +``` + +### Documentation + +
+ +
-u, --update
+ +
+ +Update the index just where it already has an entry matching <pathspec>. This removes as well as modifies index entries to match the working tree, but adds no new files. + +If no <pathspec> is given when -u option is used, all tracked files in the entire working tree are updated (old versions of Git used to limit the update to the current +directory and its subdirectories). + +
+ +
diff --git a/doc/git-b/description.md b/doc/git-b/description.md new file mode 100644 index 00000000..ff37c61b --- /dev/null +++ b/doc/git-b/description.md @@ -0,0 +1,7 @@ +Short for `git branch`. + +Example: + +```shell +git b +``` diff --git a/doc/git-bed/description.md b/doc/git-bed/description.md new file mode 100644 index 00000000..4897eb5c --- /dev/null +++ b/doc/git-bed/description.md @@ -0,0 +1,9 @@ +Edit the description of a branch. + +Example: + +```shell +git bed +``` + +Compare [`git bsd`](../git-bsd) in order to show the branch description. diff --git a/doc/git-bm/description.md b/doc/git-bm/description.md new file mode 100644 index 00000000..0378b947 --- /dev/null +++ b/doc/git-bm/description.md @@ -0,0 +1,3 @@ +List branches whose tips are reachable from the specified commit (HEAD if not specified). + +Compare [`bnm`](../git-bnm). diff --git a/doc/git-bnm/description.md b/doc/git-bnm/description.md new file mode 100644 index 00000000..2738c0ca --- /dev/null +++ b/doc/git-bnm/description.md @@ -0,0 +1,3 @@ +List branches whose tips are not reachable from the specified commit (HEAD if not specified). + +Compare [`bm`](../git-bm). diff --git a/doc/git-branch-commit-first/description.md b/doc/git-branch-commit-first/description.md new file mode 100644 index 00000000..682c5d9d --- /dev/null +++ b/doc/git-branch-commit-first/description.md @@ -0,0 +1,39 @@ +Show a branch's first commit hash (or hashes). + +Syntax: + +```shell +git branch-commit-first [branch name [commit count]] +``` + +Options: + + * branch name: default is the current branch name. + + * commit count: default is 1 + +Example: show the current branch's first commit hash: + +```shell +git branch-commit-first +``` + +Example: show the "foo" branch's first commit hash: + +```shell +git branch-commit-first foo +``` + +Example: show the "foo" branch's first 3 commit hashes: + +```shell +git branch-commit-first foo 3 +``` + +Compare: + +* [git branch-commit-first](../git-branch-commit-first): show a branch's first commit hash (or hashes) +* [git branch-commit-last](../git-branch-commit-last): show a branch's last commit hash (or hashes) +* [git branch-commit-prev](../git-branch-commit-prev): show a branch's previous commit hash (or hashes) +* [git branch-commit-next](../git-branch-commit-next): show a branch's next commit hash (or hashes) + diff --git a/doc/git-branch-commit-last/description.md b/doc/git-branch-commit-last/description.md new file mode 100644 index 00000000..9f99e28c --- /dev/null +++ b/doc/git-branch-commit-last/description.md @@ -0,0 +1,38 @@ +Show a branch's last commit hash (or hashes). + +Syntax: + +```shell +git branch-commit-last [branch name [commit count]] +``` + +Options: + + * branch name: default is the current branch name. + + * commit count: default is 1 + +Example: show the current branch's last commit hash: + +```shell +git branch-commit-last +``` + +Example: show the "foo" branch's last commit hash: + +```shell +git branch-commit-last foo +``` + +Example: show the "foo" branch's last 3 commit hashes: + +```shell +git branch-commit-last foo 3 +``` + +Compare: + +* [git branch-commit-first](../git-branch-commit-first): show a branch's first commit hash (or hashes) +* [git branch-commit-last](../git-branch-commit-last): show a branch's last commit hash (or hashes) +* [git branch-commit-prev](../git-branch-commit-prev): show a branch's previous commit hash (or hashes) +* [git branch-commit-next](../git-branch-commit-next): show a branch's next commit hash (or hashes) diff --git a/doc/git-branch-commit-next/description.md b/doc/git-branch-commit-next/description.md new file mode 100644 index 00000000..ff3757c1 --- /dev/null +++ b/doc/git-branch-commit-next/description.md @@ -0,0 +1,38 @@ +Show a branch's next commit hash (or hashes). + +Syntax: + +```shell +git branch-commit-next [branch name [commit count]] +``` + +Options: + + * branch name: default is the current branch name. + + * commit count: default is 1 + +Example: show the current branch's next commit hash: + +```shell +git branch-commit-next +``` + +Example: show the "foo" branch's next commit hash: + +```shell +git branch-commit-next next +``` + +Example: show the "foo" branch's next 3 commit hashes: + +```shell +git branch-commit-next foo 3 +``` + +Compare: + +* [git branch-commit-first](../git-branch-commit-first): show a branch's first commit hash (or hashes) +* [git branch-commit-last](../git-branch-commit-last): show a branch's last commit hash (or hashes) +* [git branch-commit-prev](../git-branch-commit-prev): show a branch's previous commit hash (or hashes) +* [git branch-commit-next](../git-branch-commit-next): show a branch's next commit hash (or hashes) diff --git a/doc/git-branch-commit-prev/description.md b/doc/git-branch-commit-prev/description.md new file mode 100644 index 00000000..819c5da9 --- /dev/null +++ b/doc/git-branch-commit-prev/description.md @@ -0,0 +1,38 @@ +Show a branch's previous commit hash (or hashes) + +Syntax: + +```shell +git branch-commit-prev [branch name [commit count]] +``` + +Options: + + * branch name: default is the current branch name. + + * commit count: default is 1 + +Example: show the current branch's previous commit hash: + +```shell +git branch-commit-prev +``` + +Example: show the "foo" branch's previous commit hash: + +```shell +git branch-commit-prev previous +``` + +Example: show the "foo" branch's previous 3 commit hashes: + +```shell +git branch-commit-prev foo 3 +``` + +Compare: + +* [git branch-commit-first](../git-branch-commit-first): show a branch's first commit hash (or hashes) +* [git branch-commit-last](../git-branch-commit-last): show a branch's last commit hash (or hashes) +* [git branch-commit-prev](../git-branch-commit-prev): show a branch's previous commit hash (or hashes) +* [git branch-commit-next](../git-branch-commit-next): show a branch's next commit hash (or hashes) diff --git a/doc/git-branch-commit/description.md b/doc/git-branch-commit/description.md new file mode 100644 index 00000000..a453a166 --- /dev/null +++ b/doc/git-branch-commit/description.md @@ -0,0 +1,14 @@ +# git-branch-commit-* + +## Show a branch's commit hash via ordering + +* [git branch-commit-first](../git-branch-commit-first): show a branch's first commit hash (or hashes) +* [git branch-commit-last](../git-branch-commit-last): show a branch's last commit hash (or hashes) +* [git branch-commit-prev](../git-branch-commit-prev): show a branch's previous commit hash (or hashes) +* [git branch-commit-next](../git-branch-commit-next): show a branch's next commit hash (or hashes) + +Inspirations: + + * Email from Demian proposing these aliases + + * diff --git a/doc/git-branch/description.md b/doc/git-branch/description.md new file mode 100644 index 00000000..faf64ec1 --- /dev/null +++ b/doc/git-branch/description.md @@ -0,0 +1,38 @@ +# git branch + +## Aliases related to git branch + + +### Shortcuts + +* [git b](git-b) = branch +* [git bm](git-bm) = branch --merged +* [git bnm](git-bm) = branch --no-merged +* [git bed](git-bed) = branch --edit-description +* [git bsd](git-bsd) = branch --show-description (wishlist) + + +### Branch names + +* [git default-branch](git-default-branch) - Get the default branch name. +* [git current-branch](git-current-branch) - Get the current branch name. +* [git upstream-branch](git-upstream-branch) - Get the upstream branch name. +* [git topic-base-branch](git-topic-base-branch) - Get the topic base branch name. + + +### Branch commits + +* [git branch-commit-first](../git-branch-commit-first) - Show a branch's first commit hash (or hashes). +* [git branch-commit-last](../git-branch-commit-last) - Show a branch's last commit hash (or hashes). +* [git branch-commit-prev](../git-branch-commit-prev) - Show a branch's previous commit hash (or hashes). +* [git branch-commit-next](../git-branch-commit-next) - Show a branch's next commit hash (or hashes). + + +### Topic branches + +* [git topic-*](git-topic) - Read this first about topic branches. +* [git topic-base-branch](git-topic-base-branch) - Show the topic base branch name. +* [git topic-begin](git-topic-begin) - Start a new topic branch. +* [git topic-end](git-topic-end) - Finish the current topic branch. +* [git topic-sync](git-topic-sync) - Synchronize the current topic branch. +* [git topic-move](git-topic-move) - Rename the current topic branch. diff --git a/doc/git-branches/description.md b/doc/git-branches/description.md new file mode 100644 index 00000000..065e95ae --- /dev/null +++ b/doc/git-branches/description.md @@ -0,0 +1,15 @@ +List branches. + +This alias is because friendly wording is easier to remember. + +Our friendly wording for plurals: + +* [git aliases](../git-aliases) + +* [git branches](../git-branches) + +* [git stashes](../git-stashes) + +* [git tags](../git-tags) + +Thanks to . diff --git a/doc/git-bsd/description.md b/doc/git-bsd/description.md new file mode 100644 index 00000000..5f9a4843 --- /dev/null +++ b/doc/git-bsd/description.md @@ -0,0 +1,13 @@ +Show the description of a branch. + +Example: + +```shell +git bsd +This is an example branch +``` + +We advocate for Git authors to add this feature +in the future as `git --show-description` + +Compare [`git bed`](../git-bed) in order to edit the branch description. diff --git a/doc/git-bv/description.md b/doc/git-bv/description.md new file mode 100644 index 00000000..db5f277a --- /dev/null +++ b/doc/git-bv/description.md @@ -0,0 +1,17 @@ +List branch information with hash and subject. + +Example: + +```shell +git bv +``` + +When in list mode, then show the hash, the commit subject line, etc. + +This is identical to doing `git b -v`. + +Compare these: + +* [git b](../git-b) +* [git bv](../git-bv) (this alias) +* [git bvv](../git-bvv) diff --git a/doc/git-bvv/description.md b/doc/git-bvv/description.md new file mode 100644 index 00000000..d24942f0 --- /dev/null +++ b/doc/git-bvv/description.md @@ -0,0 +1,17 @@ +List branch information with hash and subject and upstream + +Example: + +```shell +git bvv +``` + +When in list mode, then show the hash, the commit subject line, the upstream branch, etc. + +This is identical to doing `git b -vv`. + +Compare: + +* [git b](../git-b) +* [git bv](../git-bv) +* [git bvv](../git-bvv) (this alias) diff --git a/doc/git-c/description.md b/doc/git-c/description.md new file mode 100644 index 00000000..38fe1559 --- /dev/null +++ b/doc/git-c/description.md @@ -0,0 +1,7 @@ +Short for "git commit". + +Example: + +```shell +git c +``` diff --git a/doc/git-ca/description.md b/doc/git-ca/description.md new file mode 100644 index 00000000..819368bd --- /dev/null +++ b/doc/git-ca/description.md @@ -0,0 +1,7 @@ +Amend the tip of the current branch; do not create a new commit. + +Example: + +```shell +git ca +``` diff --git a/doc/git-caa/description.md b/doc/git-caa/description.md new file mode 100644 index 00000000..5facbb97 --- /dev/null +++ b/doc/git-caa/description.md @@ -0,0 +1,7 @@ +Amend the tip of the current branch, automatically staging files that have been modified and deleted. + +Example: + +```shell +git caa +``` diff --git a/doc/git-caam/description.md b/doc/git-caam/description.md new file mode 100644 index 00000000..fb884115 --- /dev/null +++ b/doc/git-caam/description.md @@ -0,0 +1,7 @@ +Amend the tip of the current branch, staging files, and edit the message. + +Example: + +```shell +git caam +``` diff --git a/doc/git-caane/description.md b/doc/git-caane/description.md new file mode 100644 index 00000000..4339bbdf --- /dev/null +++ b/doc/git-caane/description.md @@ -0,0 +1,7 @@ +Amend the tip of the current branch, staging files, and do not edit the message. + +Example: + +```shell +git caane +``` diff --git a/doc/git-cam/description.md b/doc/git-cam/description.md new file mode 100644 index 00000000..a6506aa6 --- /dev/null +++ b/doc/git-cam/description.md @@ -0,0 +1,7 @@ +Amend the tip of the current branch; edit the message. + +Example: + +```shell +git cam +``` diff --git a/doc/git-cane/description.md b/doc/git-cane/description.md new file mode 100644 index 00000000..c1365f0f --- /dev/null +++ b/doc/git-cane/description.md @@ -0,0 +1,7 @@ +Amend the tip of the current branch, with no edit of the message. + +Example: + +```shell +git cane +``` diff --git a/doc/git-chart/description.md b/doc/git-chart/description.md new file mode 100644 index 00000000..12c0dbb2 --- /dev/null +++ b/doc/git-chart/description.md @@ -0,0 +1,47 @@ +Show highlights chart of activity per author. + +Example: + +```shell +git chart +..X..........X...2..12 alice@example.com +....2..2..13.......... bob@example.com +2.....1....11......... carol@example.com +..1............1..1... david@example.com +....1.......1.3.3.22.2 eve@example.com +``` + +The chart rows are the authors. + +The chart columns are the days. + +The chart column prints one character per day: + + * For 1-9 commits, show the number. + + * For 10 or more commits, show "X" as a visual indicator. + + * For no commits, show "." as a visual placeholder. + +The chart timeline adjusts the date range automatically: + + * The timeline starts with the date of the earliest commit. + + * The timeline stops with the date of the latest commit. + + * The intent is to show the most relevant information. + +The chart default is to look at the past 6 weeks; +this gives a good balance of recency and speed +for a team that's currently working on a repo, +and also gives a good balance of fitting within +one terminal window 80 character width. + +You can adjust how far back the chart looks, +by providing your own `--since` parameter. +For example if you want to chart an older repo, +that does not have any recent commits, then you +you must provide a longer `--since` parameter. + +TODO: sort the rows meaningfully, +such as alphabetically, or by count. diff --git a/doc/git-cherry-pick-merge/description.md b/doc/git-cherry-pick-merge/description.md new file mode 100644 index 00000000..5834e8f7 --- /dev/null +++ b/doc/git-cherry-pick-merge/description.md @@ -0,0 +1,9 @@ +Cherry pick a merge commit. + +Example: + +```shell +git cherry-pick-merge +``` + +Thanks to Cody Cutrer. diff --git a/doc/git-churn/description.md b/doc/git-churn/description.md new file mode 100644 index 00000000..84336035 --- /dev/null +++ b/doc/git-churn/description.md @@ -0,0 +1,61 @@ +Show log of files that have many changes. + +Show churn for whole repo: + +```shell +git churn +``` + +Show churn for specific directories: + +```shell +git churn app lib +``` + +Show churn for a time range: + +```shell +git churn --since=1-month-ago +``` + +These are all standard arguments to `git log`. + +It's possible to get valuable insight from history of a project not only +by viewing individual commits, but by analyzing sets of changes as a whole. + +For instance, `git churn` compiles stats about which files change the most. + +For example, to see where work on an app was focused on in the past month: + +```shell +git churn --since=1-month-ago app/ | tail +``` + +This can also highlight potential problems with technical debt in a project. +A specific file changing too often is generally a red flag, since it probably +means the file either needed to be frequently fixed for bugs, or the file +holds too much responsibility and should be split into smaller units. + +Similar methods of history analysis can be employed to see which people were +responsible recently for development of a certain part of the codebase. + +For instance, to see who contributed most to the API part of an application: + +```shell +git log --format='%an' --since=1-month-ago app/controllers/api/ | sort | uniq -c | sort -rn | head +109 Alice Anderson +13 Bob Brown +7 Carol Clark +``` + +Credit: + +* Written by [Corey Haines](http://coreyhaines.com/) + +* Scriptified by Gary Bernhardt + +* Obtained from + +* Comments by Mislav + +* Edited for GitAlias.com repo by Joel Parker Henderson diff --git a/doc/git-ci/description.md b/doc/git-ci/description.md new file mode 100644 index 00000000..3816f7f0 --- /dev/null +++ b/doc/git-ci/description.md @@ -0,0 +1,7 @@ +Commit interactively. + +Example: + +```shell +git ci +``` diff --git a/doc/git-cleaner/description.md b/doc/git-cleaner/description.md new file mode 100644 index 00000000..13a1d115 --- /dev/null +++ b/doc/git-cleaner/description.md @@ -0,0 +1,20 @@ +Clean a working tree using more powerful options. + +Example: + +```shell +git cleaner +``` + +This will remove untracked files from the working tree. + + +### Documentation of `git clean` flags + +
+
-d
+
Normally, when no <path> is specified, git clean will not recurse into untracked directories to avoid removing too much. Specify -d to have it recurse into such directories as well. If any paths are specified, -d is irrelevant; all untracked files matching the specified paths (with exceptions for nested git directories mentioned under --force) will be removed.
+
-f, --force
+
If the Git configuration variable clean.requireForce is not set to false, git clean will refuse to delete files or directories unless given -f or -i. Git will refuse to modify untracked nested git repositories (directories with a +.git subdirectory) unless a second -f is given.
+
diff --git a/doc/git-cleanest/description.md b/doc/git-cleanest/description.md new file mode 100644 index 00000000..bd7e4650 --- /dev/null +++ b/doc/git-cleanest/description.md @@ -0,0 +1,23 @@ +Clean a working tree using the most powerful options. + +Example: + +```shell +git cleanest +``` + +This will remove untracked files from the working tree. + + +### Documentation of `git clean` flags + +
+
-d
+
Normally, when no <path> is specified, git clean will not recurse into untracked directories to avoid removing too much. Specify -d to have it recurse into such directories as well. If any paths are specified, -d is irrelevant; all untracked files matching the specified paths (with exceptions for nested git directories mentioned under --force) will be removed.
+
-f, --force
+
If the Git configuration variable clean.requireForce is not set to false, git clean will refuse to delete files or directories unless given -f or -i. Git will refuse to modify untracked nested git repositories (directories with a +.git subdirectory) unless a second -f is given.
+
-x
+
Don't use the standard ignore rules (see gitignore(5)), but still use the ignore rules given with -e options from the command line. This allows removing all untracked files, including build products. This can be used (possibly in +conjunction with git restore or git reset) to create a pristine working directory to test a clean build.
+
diff --git a/doc/git-cleanout/description.md b/doc/git-cleanout/description.md new file mode 100644 index 00000000..4e0c6aff --- /dev/null +++ b/doc/git-cleanout/description.md @@ -0,0 +1,7 @@ +Clean a working tree using typical options then checkout. + +Example: + +```shell +git cleanout +``` diff --git a/doc/git-clone-lean/description.md b/doc/git-clone-lean/description.md new file mode 100644 index 00000000..d7f91db9 --- /dev/null +++ b/doc/git-clone-lean/description.md @@ -0,0 +1,37 @@ +Clone as lean as possible. + +Example: + +```shell +git clone-lean +``` + +This alias skips fetching unneeded objects from the server. + +This is good to checkout just one subdirectory. + +Command breakdown: + + * --depth 1 does a shallow clone and implies --single-branches + + * --filter=blob:none skips all blobs, but fetches all tree objects + + * --filter=tree:0 skips unneeded trees + + * --filter=combine:FILTER1+FILTER2 is the syntax to use multiple + filters at once; trying to pass --filter multiple times fails + with: "multiple filter-specs cannot be combined". + +This uses --filter=tree:0 added in Git 2.20 and --filter=combine +composite filter added in Git 2.24. + +The server should be configured with: + + git config --local uploadpack.allowfilter 1 + git config --local uploadpack.allowanysha1inwant 1 + +An extension was made to the Git remote protocol to support this +feature in v2.19.0 and actually skip fetching unneeded objects. +There was server support then, but it can be locally tested. + +Credit diff --git a/doc/git-cloner/description.md b/doc/git-cloner/description.md new file mode 100644 index 00000000..e20d313b --- /dev/null +++ b/doc/git-cloner/description.md @@ -0,0 +1,7 @@ +Clone a repository using our recommended way, i.e. recurse on all submodules. + +Example: + +```shell +git cloner +``` diff --git a/doc/git-cm/description.md b/doc/git-cm/description.md new file mode 100644 index 00000000..dc62a0e5 --- /dev/null +++ b/doc/git-cm/description.md @@ -0,0 +1,7 @@ +Commit with a message. + +Example: + +```shell +git cm +``` diff --git a/doc/git-co/description.md b/doc/git-co/description.md new file mode 100644 index 00000000..6f1dde38 --- /dev/null +++ b/doc/git-co/description.md @@ -0,0 +1,7 @@ +Checkout, i.e. update the working tree to match a branch or paths. + +Example: + +```shell +git co +``` diff --git a/doc/git-cob/description.md b/doc/git-cob/description.md new file mode 100644 index 00000000..773a277d --- /dev/null +++ b/doc/git-cob/description.md @@ -0,0 +1,7 @@ +Create a new branch from the current working tree, and switch to it. + +Example: + +```shell +git cob new-branch +``` diff --git a/doc/git-cog/description.md b/doc/git-cog/description.md new file mode 100644 index 00000000..e8f2d3f2 --- /dev/null +++ b/doc/git-cog/description.md @@ -0,0 +1,7 @@ +Checkout with guessing. + +Example: + +```shell +git cog +``` diff --git a/doc/git-commit-is-merge/description.md b/doc/git-commit-is-merge/description.md new file mode 100644 index 00000000..243cf139 --- /dev/null +++ b/doc/git-commit-is-merge/description.md @@ -0,0 +1,7 @@ +Is the commit a merge commit? If yes exit 0, else exit 1. + +Example: + +```shell +git commit-is-merge && do-something || do-something-else +``` diff --git a/doc/git-commit-message-key-lines/description.md b/doc/git-commit-message-key-lines/description.md new file mode 100644 index 00000000..31b5f0d9 --- /dev/null +++ b/doc/git-commit-message-key-lines/description.md @@ -0,0 +1,56 @@ +Show the commit's keyword-marker lines. + +Example: + +```shell +git commit-message-key-lines ce505d161fccdbc8d4bf12047846de7433ad6d04 +``` + +Show each line in the commit message that starts with optional +whitespace, then a keyword (i.e. alphanum and dash characters), +then a colon. The purpose is to help with analytics and reports. + +Example commit and message: + +```shell +commit ce505d161fccdbc8d4bf12047846de7433ad6d04 +Author: Alice Adams +Date: Tue May 28 11:53:47 2019 -0700 + + Add feature foo + + This commit does some good things. + + Time: 8 hours + Cost: 800 USD +``` + +Example command: + +```shell +git commit-message-key-lines ce505d161fccdbc8d4bf12047846de7433ad6d04 +``` + +Example output: + +```shell +Commit: ce505d161fccdbc8d4bf12047846de7433ad6d04 +Author: Alice Adams +Date: Tue May 28 11:53:47 2019 -0700 +Time: 8 hours +Cost: 800 USD + +The alias intentionally normalizes the output: + + * Start the output with "Commit: " so we know which commit. + + * Omit leading blanks i.e. print flush left. + + * After the colon, use one space, not a tab, or multiple spaces, etc. + +Known issues: + + * TODO: improve the keyword matcher so it requires the keyword to end + in an alphanum (not a dash), and also so the dash is a separator i.e. + the matcher does not accept a dash followed by another dash. + diff --git a/doc/git-commit-parents/description.md b/doc/git-commit-parents/description.md new file mode 100644 index 00000000..dde43fc9 --- /dev/null +++ b/doc/git-commit-parents/description.md @@ -0,0 +1,7 @@ +Show the commit's parents. + +Example: + +```shell +git commit-parents +``` diff --git a/doc/git-cong/description.md b/doc/git-cong/description.md new file mode 100644 index 00000000..edeffaa7 --- /dev/null +++ b/doc/git-cong/description.md @@ -0,0 +1,7 @@ +Checkout with no guessing. + +Example: + +```shell +git cong +``` diff --git a/doc/git-count/description.md b/doc/git-count/description.md new file mode 100644 index 00000000..e69de29b diff --git a/doc/git-cp/description.md b/doc/git-cp/description.md new file mode 100644 index 00000000..61729636 --- /dev/null +++ b/doc/git-cp/description.md @@ -0,0 +1,9 @@ +Cherry-pick, i.e. apply the changes introduced by some existing commits. + +Example: + +```shell +git cp +``` + +Cherry pick is useful for moving small chunks of code between branches. diff --git a/doc/git-cpa/description.md b/doc/git-cpa/description.md new file mode 100644 index 00000000..df8e9abf --- /dev/null +++ b/doc/git-cpa/description.md @@ -0,0 +1,7 @@ +Abort the cherry-pick process. + +Example: + +```shell +git cpa +``` diff --git a/doc/git-cpc/description.md b/doc/git-cpc/description.md new file mode 100644 index 00000000..57f7252a --- /dev/null +++ b/doc/git-cpc/description.md @@ -0,0 +1,7 @@ +Continue the cherry-pick process. + +Example: + +```shell +git cpc +``` diff --git a/doc/git-cpn/description.md b/doc/git-cpn/description.md new file mode 100644 index 00000000..03bae185 --- /dev/null +++ b/doc/git-cpn/description.md @@ -0,0 +1,7 @@ +Cherry-pick with no commit. + +Example: + +```shell +git cpn +``` diff --git a/doc/git-cpnx/description.md b/doc/git-cpnx/description.md new file mode 100644 index 00000000..50b939ed --- /dev/null +++ b/doc/git-cpnx/description.md @@ -0,0 +1,12 @@ +Cherry-pick with no commit and with explanation. + +Example: + +```shell +git cpnx +``` + +Cherry-pick with without making a commit. + +When when recording the commit, append a line +that says "(cherry picked from commit ...)" diff --git a/doc/git-current-branch/description.md b/doc/git-current-branch/description.md new file mode 100644 index 00000000..986d256f --- /dev/null +++ b/doc/git-current-branch/description.md @@ -0,0 +1,16 @@ +Get the branch name of the current branch. + +Example: + +```shell +git current-branch +main +``` + +Git 2.22.0+ has the equivalent command: + +```shell +git branch --show-current +``` + +Note: Git Alias has many aliases that get the branch name of the current branch. A project goal is to ensure these aliases work on older git versions. Therefore these aliases use `git current-branch` instead of `git branch --show-current`. If the two implementations ever differ, then the git built-in is correct, and Git Alias must be fixed. diff --git a/doc/git-cvs-e/description.md b/doc/git-cvs-e/description.md new file mode 100644 index 00000000..6e4a833d --- /dev/null +++ b/doc/git-cvs-e/description.md @@ -0,0 +1,7 @@ +CVS Export. + +Example: + +```shell +git cvs-e +``` diff --git a/doc/git-cvs-i/description.md b/doc/git-cvs-i/description.md new file mode 100644 index 00000000..295fd125 --- /dev/null +++ b/doc/git-cvs-i/description.md @@ -0,0 +1,7 @@ +CVS Import. + +Example: + +```shell +git cvs-i +``` diff --git a/doc/git-cvs/description.md b/doc/git-cvs/description.md new file mode 100644 index 00000000..84f88fb9 --- /dev/null +++ b/doc/git-cvs/description.md @@ -0,0 +1,17 @@ +# git cvs-* + +## Aliases for working with CVS version control + +Git alias: + +```git +cvs-i = cvsimport -k -a +cvs-e = cvsexportcommit -u -p +``` + +Example: + +```shell +git cvs-i +git cvs-e +``` diff --git a/doc/git-d/description.md b/doc/git-d/description.md new file mode 100644 index 00000000..01f80051 --- /dev/null +++ b/doc/git-d/description.md @@ -0,0 +1,7 @@ +Short for `git diff`. + +Example: + +```shell +git d +``` diff --git a/doc/git-dc/description.md b/doc/git-dc/description.md new file mode 100644 index 00000000..ccb79428 --- /dev/null +++ b/doc/git-dc/description.md @@ -0,0 +1,7 @@ +Diff in order to show changes not yet staged. + +Example: + +```shell +git dc +``` diff --git a/doc/git-dd/description.md b/doc/git-dd/description.md new file mode 100644 index 00000000..5f8066ee --- /dev/null +++ b/doc/git-dd/description.md @@ -0,0 +1,9 @@ +Diff deep - show changes with our preferred options. + +Example: + +```shell +git dd +``` + +Also aliased as `diff-deep`. diff --git a/doc/git-debug/description.md b/doc/git-debug/description.md new file mode 100644 index 00000000..f90442a4 --- /dev/null +++ b/doc/git-debug/description.md @@ -0,0 +1,14 @@ +Help debugging builtins. + +Example: + +```shell +git debug +``` + +When debugging builtins, we like to use `gdb` to analyze the runtime state. + +However, we have to disable the pager, and often we have to call +the program with arguments. + +If the program to debug is a builtin, then we use this alias. diff --git a/doc/git-default-branch/description.md b/doc/git-default-branch/description.md new file mode 100644 index 00000000..816939ce --- /dev/null +++ b/doc/git-default-branch/description.md @@ -0,0 +1,8 @@ +Get the default branch name. + +Example: + +```shell +git default-branch +main +``` diff --git a/doc/git-diff-all/description.md b/doc/git-diff-all/description.md new file mode 100644 index 00000000..c8c6bec0 --- /dev/null +++ b/doc/git-diff-all/description.md @@ -0,0 +1,7 @@ +For each diff, call difftool. + +Example: + +```shell +git diff-all +``` diff --git a/doc/git-diff-changes/description.md b/doc/git-diff-changes/description.md new file mode 100644 index 00000000..9eac83cc --- /dev/null +++ b/doc/git-diff-changes/description.md @@ -0,0 +1,7 @@ +Show diff of changes. + +Example: + +```shell +git diff-changes +``` diff --git a/doc/git-diff-chunk/description.md b/doc/git-diff-chunk/description.md new file mode 100644 index 00000000..a60b5ade --- /dev/null +++ b/doc/git-diff-chunk/description.md @@ -0,0 +1,19 @@ +Show the diff of one chunk. + +Example: + +```shell +git diff-chunk +``` + +Suppose we want to see just the differences of one chunk, +such as one function, in one file, in two different commits. + +This alias creates two temp files which contain only the chunk, +then does a typical git diff. + +Syntax: + +```shell +git funcdiff +``` diff --git a/doc/git-diff-deep/description.md b/doc/git-diff-deep/description.md new file mode 100644 index 00000000..c5b98df1 --- /dev/null +++ b/doc/git-diff-deep/description.md @@ -0,0 +1,7 @@ +Diff with deep information using our preferred options, a.k.a. `dd`. + +Example: + +```shell +git diff-deep +``` diff --git a/doc/git-diff-staged/description.md b/doc/git-diff-staged/description.md new file mode 100644 index 00000000..f5a7caa9 --- /dev/null +++ b/doc/git-diff-staged/description.md @@ -0,0 +1,7 @@ +Show diffs that are cached i.e. staged. + +Example: + +```shell +git diff-staged +``` diff --git a/doc/git-diff-stat/description.md b/doc/git-diff-stat/description.md new file mode 100644 index 00000000..1c4df5ba --- /dev/null +++ b/doc/git-diff-stat/description.md @@ -0,0 +1,7 @@ +Diff with stat. + +Example: + +```shell +git diff-stat +``` diff --git a/doc/git-diff/description.md b/doc/git-diff/description.md new file mode 100644 index 00000000..e9e17e20 --- /dev/null +++ b/doc/git-diff/description.md @@ -0,0 +1,24 @@ +# git diff-* + +## Show diff in various ways + +Git alias: + +```git +diff-all = !"for name in $(git diff --name-only $1); do git difftool $1 $name & done" +diff-changes = diff --name-status -r +diff-stat = diff --stat --ignore-space-change -r +diff-staged = diff --cached + +# Diff using our preferred options. A.k.a. `dd`. +diff-deep = diff --check --dirstat --find-copies --find-renames --histogram --color +``` + +Example: + +```shell +git diff-all +git diff-changes +git diff-stat +git diff-deep +``` diff --git a/doc/git-discard/description.md b/doc/git-discard/description.md new file mode 100644 index 00000000..7a2431c7 --- /dev/null +++ b/doc/git-discard/description.md @@ -0,0 +1,7 @@ +Discard changes in a file (or a list of files) in working tree. + +Example: + +```shell +git discard foo goo hoo +``` diff --git a/doc/git-ds/description.md b/doc/git-ds/description.md new file mode 100644 index 00000000..3a0d64dd --- /dev/null +++ b/doc/git-ds/description.md @@ -0,0 +1,7 @@ +Show changes about to be commited. + +Example: + +```shell +git ds +``` diff --git a/doc/git-dw/description.md b/doc/git-dw/description.md new file mode 100644 index 00000000..4e81dc6a --- /dev/null +++ b/doc/git-dw/description.md @@ -0,0 +1,7 @@ +Show changes by word, not line. + +Example: + +```shell +git dw +``` diff --git a/doc/git-dwd/description.md b/doc/git-dwd/description.md new file mode 100644 index 00000000..fb00ab34 --- /dev/null +++ b/doc/git-dwd/description.md @@ -0,0 +1,7 @@ +Show changes by word, not by line. + +Example: + +```shell +git dwd +``` diff --git a/doc/git-edit-cached/description.md b/doc/git-edit-cached/description.md new file mode 100644 index 00000000..2ae0a036 --- /dev/null +++ b/doc/git-edit-cached/description.md @@ -0,0 +1,29 @@ +Edit cached files. + +Example: + +```shell +git edit-cached +``` + +Compare: + +* [git edit-cached](../git-edit-cached) (this alias) +* [git edit-deleted](../git-edit-deleted) +* [git edit-others](../git-edit-others) +* [git edit-ignored](../git-edit-ignored) +* [git edit-killed](../git-edit-killed) +* [git edit-modified](../git-edit-modified) +* [git edit-stage](../git-edit-stage) +* [git edit-unmerged](../git-edit-unmerged) + +Compare corresponding aliases for add-*: + +* [git add-cached](../git-add-cached) +* [git add-deleted](../git-add-deleted) +* [git add-others](../git-add-others) +* [git add-ignored](../git-add-ignored) +* [git add-killed](../git-add-killed) +* [git add-modified](../git-add-modified) +* [git add-stage](../git-add-stage) +* [git add-unmerged](../git-add-unmerged) diff --git a/doc/git-edit-deleted/description.md b/doc/git-edit-deleted/description.md new file mode 100644 index 00000000..c17adcb4 --- /dev/null +++ b/doc/git-edit-deleted/description.md @@ -0,0 +1,29 @@ +Edit deleted files. + +Example: + +```shell +git edit-cached +``` + +Compare: + +* [git edit-cached](../git-edit-cached) +* [git edit-deleted](../git-edit-deleted) (this alias) +* [git edit-others](../git-edit-others) +* [git edit-ignored](../git-edit-ignored) +* [git edit-killed](../git-edit-killed) +* [git edit-modified](../git-edit-modified) +* [git edit-stage](../git-edit-stage) +* [git edit-unmerged](../git-edit-unmerged) + +Compare corresponding aliases for add-*: + +* [git add-cached](../git-add-cached) +* [git add-deleted](../git-add-deleted) +* [git add-others](../git-add-others) +* [git add-ignored](../git-add-ignored) +* [git add-killed](../git-add-killed) +* [git add-modified](../git-add-modified) +* [git add-stage](../git-add-stage) +* [git add-unmerged](../git-add-unmerged) diff --git a/doc/git-edit-ignored/description.md b/doc/git-edit-ignored/description.md new file mode 100644 index 00000000..09c8a7b9 --- /dev/null +++ b/doc/git-edit-ignored/description.md @@ -0,0 +1,29 @@ +Edit ignored files. + +Example: + +```shell +git edit-ignored +``` + +Compare: + +* [git edit-cached](../git-edit-cached) +* [git edit-deleted](../git-edit-deleted) +* [git edit-others](../git-edit-others) +* [git edit-ignored](../git-edit-ignored) (this alias) +* [git edit-killed](../git-edit-killed) +* [git edit-modified](../git-edit-modified) +* [git edit-stage](../git-edit-stage) +* [git edit-unmerged](../git-edit-unmerged) + +Compare corresponding aliases for add-*: + +* [git add-cached](../git-add-cached) +* [git add-deleted](../git-add-deleted) +* [git add-others](../git-add-others) +* [git add-ignored](../git-add-ignored) +* [git add-killed](../git-add-killed) +* [git add-modified](../git-add-modified) +* [git add-stage](../git-add-stage) +* [git add-unmerged](../git-add-unmerged) diff --git a/doc/git-edit-killed/description.md b/doc/git-edit-killed/description.md new file mode 100644 index 00000000..b3b8e100 --- /dev/null +++ b/doc/git-edit-killed/description.md @@ -0,0 +1,29 @@ +Edit killed files. + +Example: + +```shell +git edit-killed +``` + +Compare: + +* [git edit-cached](../git-edit-cached) +* [git edit-deleted](../git-edit-deleted) +* [git edit-others](../git-edit-others) +* [git edit-ignored](../git-edit-ignored) +* [git edit-killed](../git-edit-killed) (this alias) +* [git edit-modified](../git-edit-modified) +* [git edit-stage](../git-edit-stage) +* [git edit-unmerged](../git-edit-unmerged) + +Compare corresponding aliases for add-*: + +* [git add-cached](../git-add-cached) +* [git add-deleted](../git-add-deleted) +* [git add-others](../git-add-others) +* [git add-ignored](../git-add-ignored) +* [git add-killed](../git-add-killed) +* [git add-modified](../git-add-modified) +* [git add-stage](../git-add-stage) +* [git add-unmerged](../git-add-unmerged) diff --git a/doc/git-edit-modified/description.md b/doc/git-edit-modified/description.md new file mode 100644 index 00000000..e7185a91 --- /dev/null +++ b/doc/git-edit-modified/description.md @@ -0,0 +1,29 @@ +Edit modified files. + +Example: + +```shell +git edit-modified +``` + +Compare: + +* [git edit-cached](../git-edit-cached) +* [git edit-deleted](../git-edit-deleted) +* [git edit-others](../git-edit-others) +* [git edit-ignored](../git-edit-ignored) +* [git edit-killed](../git-edit-killed) +* [git edit-modified](../git-edit-modified) (this alias) +* [git edit-stage](../git-edit-stage) +* [git edit-unmerged](../git-edit-unmerged) + +Compare corresponding aliases for add-*: + +* [git add-cached](../git-add-cached) +* [git add-deleted](../git-add-deleted) +* [git add-others](../git-add-others) +* [git add-ignored](../git-add-ignored) +* [git add-killed](../git-add-killed) +* [git add-modified](../git-add-modified) +* [git add-stage](../git-add-stage) +* [git add-unmerged](../git-add-unmerged) diff --git a/doc/git-edit-others/description.md b/doc/git-edit-others/description.md new file mode 100644 index 00000000..da695a81 --- /dev/null +++ b/doc/git-edit-others/description.md @@ -0,0 +1,27 @@ +Edit other files. + +```shell +git edit-cached +``` + +Compare: + +* [git edit-cached](../git-edit-cached) +* [git edit-deleted](../git-edit-deleted) +* [git edit-others](../git-edit-others) (this alias) +* [git edit-ignored](../git-edit-ignored) +* [git edit-killed](../git-edit-killed) +* [git edit-modified](../git-edit-modified) +* [git edit-stage](../git-edit-stage) +* [git edit-unmerged](../git-edit-unmerged) + +Compare corresponding aliases for add-*: + +* [git add-cached](../git-add-cached) +* [git add-deleted](../git-add-deleted) +* [git add-others](../git-add-others) +* [git add-ignored](../git-add-ignored) +* [git add-killed](../git-add-killed) +* [git add-modified](../git-add-modified) +* [git add-stage](../git-add-stage) +* [git add-unmerged](../git-add-unmerged) diff --git a/doc/git-edit-stage/description.md b/doc/git-edit-stage/description.md new file mode 100644 index 00000000..2d1f381c --- /dev/null +++ b/doc/git-edit-stage/description.md @@ -0,0 +1,29 @@ +Edit stage files. + +Example: + +```shell +git edit-stage +``` + +Compare: + +* [git edit-cached](../git-edit-cached) +* [git edit-deleted](../git-edit-deleted) +* [git edit-others](../git-edit-others) +* [git edit-ignored](../git-edit-ignored) +* [git edit-killed](../git-edit-killed) +* [git edit-modified](../git-edit-modified) +* [git edit-stage](../git-edit-stage) (this alias) +* [git edit-unmerged](../git-edit-unmerged) + +Compare corresponding aliases for add-*: + +* [git add-cached](../git-add-cached) +* [git add-deleted](../git-add-deleted) +* [git add-others](../git-add-others) +* [git add-ignored](../git-add-ignored) +* [git add-killed](../git-add-killed) +* [git add-modified](../git-add-modified) +* [git add-stage](../git-add-stage) +* [git add-unmerged](../git-add-unmerged) diff --git a/doc/git-edit-unmerged/description.md b/doc/git-edit-unmerged/description.md new file mode 100644 index 00000000..84ee375b --- /dev/null +++ b/doc/git-edit-unmerged/description.md @@ -0,0 +1,29 @@ +Edit unmerged files. + +Example: + +```shell +git edit-cached +``` + +Compare: + +* [git edit-cached](../git-edit-cached) +* [git edit-deleted](../git-edit-deleted) +* [git edit-others](../git-edit-others) +* [git edit-ignored](../git-edit-ignored) +* [git edit-killed](../git-edit-killed) +* [git edit-modified](../git-edit-modified) +* [git edit-stage](../git-edit-stage) +* [git edit-unmerged](../git-edit-unmerged) (this alias) + +Compare corresponding aliases for add-*: + +* [git add-cached](../git-add-cached) +* [git add-deleted](../git-add-deleted) +* [git add-others](../git-add-others) +* [git add-ignored](../git-add-ignored) +* [git add-killed](../git-add-killed) +* [git add-modified](../git-add-modified) +* [git add-stage](../git-add-stage) +* [git add-unmerged](../git-add-unmerged) diff --git a/doc/git-edit/description.md b/doc/git-edit/description.md new file mode 100644 index 00000000..b30fc6d5 --- /dev/null +++ b/doc/git-edit/description.md @@ -0,0 +1,31 @@ +# git edit-* + +## Edit all files of a given type + +Git alias: + +```git +edit-cached = !"f() { git ls-files --cached | sort -u ; }; `git var GIT_EDITOR` `f`" +edit-deleted = !"f() { git ls-files --deleted | sort -u ; }; `git var GIT_EDITOR` `f`" +edit-others = !"f() { git ls-files --others | sort -u ; }; `git var GIT_EDITOR` `f`" +edit-ignored = !"f() { git ls-files --ignored | sort -u ; }; `git var GIT_EDITOR` `f`" +edit-killed = !"f() { git ls-files --killed | sort -u ; }; `git var GIT_EDITOR` `f`" +edit-modified = !"f() { git ls-files --modified | sort -u ; }; `git var GIT_EDITOR` `f`" +edit-stage = !"f() { git ls-files --stage | cut -f2 | sort -u ; }; `git var GIT_EDITOR` `f`" +edit-unmerged = !"f() { git ls-files --unmerged | cut -f2 | sort -u ; }; `git var GIT_EDITOR` `f`" +``` + +Example: + +```shell +git edit-cached +git edit-deleted +git edit-others +git edit-ignored +git edit-killed +git edit-modified +git edit-stage +git edit-unmerged +``` + +These aliases intentionally match the aliases [git add-*](../git-add). diff --git a/doc/git-exec/description.md b/doc/git-exec/description.md new file mode 100644 index 00000000..196a889c --- /dev/null +++ b/doc/git-exec/description.md @@ -0,0 +1,10 @@ +Execute a shell script. + +Example: + +```shell +git exec pwd +/home/alice/projects/example +``` + +Note: git always runs scripts in the top directory. diff --git a/doc/git-expunge/description.md b/doc/git-expunge/description.md new file mode 100644 index 00000000..984c8c9b --- /dev/null +++ b/doc/git-expunge/description.md @@ -0,0 +1,15 @@ +Delete a file everywhere. + +Example: + +```shell +git expunge file.txt +``` + +This command is typically for a serious problem, such as accidentally +committing a file of sensitive data, such as passwords or secrets or +confidential information. + +After you use this command, you will likely need to force push everything. + +See diff --git a/doc/git-f/description.md b/doc/git-f/description.md new file mode 100644 index 00000000..0a79b83f --- /dev/null +++ b/doc/git-f/description.md @@ -0,0 +1,7 @@ +Short for "git fetch". + +Example: + +```shell +git f +``` diff --git a/doc/git-fa/description.md b/doc/git-fa/description.md new file mode 100644 index 00000000..05426583 --- /dev/null +++ b/doc/git-fa/description.md @@ -0,0 +1,7 @@ +Fetch all remotes. + +Example: + +```shell +git fa +``` diff --git a/doc/git-fav/description.md b/doc/git-fav/description.md new file mode 100644 index 00000000..9ba42538 --- /dev/null +++ b/doc/git-fav/description.md @@ -0,0 +1,7 @@ +Fetch all remotes, with verbose output. + +Example: + +```shell +git fav +``` diff --git a/doc/git-fixup/description.md b/doc/git-fixup/description.md new file mode 100644 index 00000000..d4e479d1 --- /dev/null +++ b/doc/git-fixup/description.md @@ -0,0 +1,11 @@ +Fix a commit by amending it. + +Example: + +```shell +git fixup +``` + +See + +This alias is a slightly modified version. diff --git a/doc/git-g/description.md b/doc/git-g/description.md new file mode 100644 index 00000000..437f0928 --- /dev/null +++ b/doc/git-g/description.md @@ -0,0 +1,11 @@ +Short for "git grep". + +Example: + +```shell +git g +``` + +This will search for text. + +The term "grep" stands for "general regular expression parser". diff --git a/doc/git-get-git-put/description.md b/doc/git-get-git-put/description.md new file mode 100644 index 00000000..bb3d66fd --- /dev/null +++ b/doc/git-get-git-put/description.md @@ -0,0 +1,45 @@ +# git get & git put + +## Synchronize changes for the current branch + +Git alias: + +```git +get = !git fetch --prune && git pull --rebase && git submodule update --init --recursive +put = !git commit --all && git push +``` + +Example: + +```shell +git get +git put +``` + +Our workflow does these steps: + + * git get: fetch and prune, pull and rebase, then update submodules. + + * git put: commit all items, then push. + +If you want to preserve merges, then we recommend you set this: + +```shell +git config pull.rebase preserve +``` + +TODO: + + * Handle tags + + * Delete superfluous branches + + * Add error handing + +Compare: + +* [git get & git put](../git-get-git-put) (this page) + +* [git get](../git-get) + +* [git put](../git-put) diff --git a/doc/git-get/description.md b/doc/git-get/description.md new file mode 100644 index 00000000..3a74b520 --- /dev/null +++ b/doc/git-get/description.md @@ -0,0 +1,15 @@ +Get all changes for the current branch. + +Example: + +```shell +git get +``` + +Compare: + +* [git get & git put](../git-get-git-put) (describes both) + +* [git get](../git-get) (this alias) + +* [git put](../git-put) diff --git a/doc/git-gg/description.md b/doc/git-gg/description.md new file mode 100644 index 00000000..5c03c56f --- /dev/null +++ b/doc/git-gg/description.md @@ -0,0 +1,9 @@ +Grep group i.e. search with our preferred options. + +Example: + +```shell +git gg +``` + +Also aliased as [git grep-group](../git-grep-group). diff --git a/doc/git-gitk-conflict/description.md b/doc/git-gitk-conflict/description.md new file mode 100644 index 00000000..97505f8d --- /dev/null +++ b/doc/git-gitk-conflict/description.md @@ -0,0 +1,7 @@ +Use gitk tool to show conflicting merge. + +Example: + +```shell +git gitk-conflict +``` diff --git a/doc/git-gitk-history-all/description.md b/doc/git-gitk-history-all/description.md new file mode 100644 index 00000000..358156ff --- /dev/null +++ b/doc/git-gitk-history-all/description.md @@ -0,0 +1,9 @@ +Use gitk tool to show full history, including "deleted" branches and stashes. + +Example: + +```shell +git gitk-history-all +``` + +This will show full history, including "deleted" branches and stashes. diff --git a/doc/git-gitk/description.md b/doc/git-gitk/description.md new file mode 100644 index 00000000..1e677592 --- /dev/null +++ b/doc/git-gitk/description.md @@ -0,0 +1,6 @@ +# git gitk-* + +## Aliases related to the gitk tool + +* [git gitk-conflict](git-gitk-conflict) - Use gitk to show conflicting merge. +* [git gitk-history-all](git-gitk-history-all) - Use gitk to show full history. diff --git a/doc/git-gn/description.md b/doc/git-gn/description.md new file mode 100644 index 00000000..25b427bc --- /dev/null +++ b/doc/git-gn/description.md @@ -0,0 +1,9 @@ +Grep and show line number. + +Example: + +```shell +git gn +``` + +Same as `git grep --line-number`. diff --git a/doc/git-graphviz/description.md b/doc/git-graphviz/description.md new file mode 100644 index 00000000..a6eeb531 --- /dev/null +++ b/doc/git-graphviz/description.md @@ -0,0 +1,17 @@ +Use graphviz tool for display. + +Example: + +```shell +git graphviz +``` + +This produces output that can be displayed using dotty. + +Example: + +```shell +git graphviz HEAD~100..HEAD~60 | dotty /dev/stdin + +git graphviz --first-parent main | dotty /dev/stdin +``` diff --git a/doc/git-grep-ack/description.md b/doc/git-grep-ack/description.md new file mode 100644 index 00000000..08889fe5 --- /dev/null +++ b/doc/git-grep-ack/description.md @@ -0,0 +1,7 @@ +Find text with ack-like formatting. + +Example: + +```shell +git grep-ack +``` diff --git a/doc/git-grep-all/description.md b/doc/git-grep-all/description.md new file mode 100644 index 00000000..82555985 --- /dev/null +++ b/doc/git-grep-all/description.md @@ -0,0 +1,13 @@ +Find text in any commit ever. + +Syntax: + +```shell +git grep-all … +``` + +Example: + +```shell +git grep-all foo +``` diff --git a/doc/git-grep-group/description.md b/doc/git-grep-group/description.md new file mode 100644 index 00000000..e77437f1 --- /dev/null +++ b/doc/git-grep-group/description.md @@ -0,0 +1,13 @@ +Find text and group the output lines, a.k.a. `gg`. + +Syntax: + +```shell +git grep-group [options] +``` + +Example: + +```shell +git grep-group foo +``` diff --git a/doc/git-grep/description.md b/doc/git-grep/description.md new file mode 100644 index 00000000..48ff5615 --- /dev/null +++ b/doc/git-grep/description.md @@ -0,0 +1,28 @@ +# git grep-* + +## Grep helpers + +Git alias: + +```git +# Find text in any commit ever. +grep-all = !"f() { git rev-list --all | xargs git grep \"$@\"; }; f" + +# Find text and group the output lines. A.k.a. `gg`. +grep-group = grep --break --heading --line-number --color + +# Find text with ack-like formatting. +grep-ack = \ + -c color.grep.linenumber=\"bold yellow\" \ + -c color.grep.filename=\"bold green\" \ + -c color.grep.match=\"reverse yellow\" \ + grep --break --heading --line-number +``` + +Example: + +```shell +git grep-all +git grep-group +git grep-ack +``` diff --git a/doc/git-heads/description.md b/doc/git-heads/description.md new file mode 100644 index 00000000..a1621c88 --- /dev/null +++ b/doc/git-heads/description.md @@ -0,0 +1,9 @@ +Show log of heads. + +Example: + +```shell +git heads +``` + +Thanks to . diff --git a/doc/git-hew-dry-run/description.md b/doc/git-hew-dry-run/description.md new file mode 100644 index 00000000..e64309d5 --- /dev/null +++ b/doc/git-hew-dry-run/description.md @@ -0,0 +1,34 @@ +Delete all branches that have been merged into a commit (dry run). + +Syntax: + +```shell +hew-dry-run [] +``` + +Example with default branch name: + +```shell +git hew-dry-run +``` + +Example with specific branch name: + +```shell +git hew-dry-run main +``` + +Example with specific commit hash: + +```shell +git hew-dry-run 4677ad893ee038b113e22f6330da6ae710712f88 +``` + +Compare these: + +* [git hew](../git-hew) +* [git hew-dry-run](../git-hew-dry-run) +* [git hew-local](../git-hew-local) +* [git hew-local-dry-run](../git-hew-local-dry-run) +* [git hew-remote](../git-hew-remote) +* [git hew-remote-dry-run](../git-hew-remote-dry-run) diff --git a/doc/git-hew-local-dry-run/description.md b/doc/git-hew-local-dry-run/description.md new file mode 100644 index 00000000..b0ca3793 --- /dev/null +++ b/doc/git-hew-local-dry-run/description.md @@ -0,0 +1,38 @@ +Delete local branches that have been merged into a commit (dry run). + +Syntax: + +```shell +hew-local-dry-run [] +``` + +Example with the default branch name: + +```shell +git hew-local-dry-run +``` + +Example with a specific branch name: + +```shell +git hew-local-dry-run main +``` + +Example with a specific commmit hash: + +```shell +git hew-local-dry-run 4677ad893ee038b113e22f6330da6ae710712f88 +``` + +If a branch is provided, or commit is provided, then this alias will use it. + +Otherwise, this alias will use the current branch name. + +Compare these: + +* [git hew](../git-hew) +* [git hew-dry-run](../git-hew-dry-run) +* [git hew-local](../git-hew-local) +* [git hew-local-dry-run](../git-hew-local-dry-run) +* [git hew-remote](../git-hew-remote) +* [git hew-remote-dry-run](../git-hew-remote-dry-run) diff --git a/doc/git-hew-local/description.md b/doc/git-hew-local/description.md new file mode 100644 index 00000000..6a9245f6 --- /dev/null +++ b/doc/git-hew-local/description.md @@ -0,0 +1,38 @@ +Delete local branches that have been merged into a commit. + +Syntax: + +```shell +git hew-local [] +``` + +Example with the default branch name: + +```shell +git hew-local +``` + +Example with a specific branch name: + +```shell +git hew-local main +``` + +Example with a specific commmit hash: + +```shell +git hew-local 4677ad893ee038b113e22f6330da6ae710712f88 +``` + +If a branch is provided, or commit is provided, then this alias will use it. + +Otherwise, this alias will use the current branch name. + +Compare these: + +* [git hew](../git-hew) +* [git hew-dry-run](../git-hew-dry-run) +* [git hew-local](../git-hew-local) +* [git hew-local-dry-run](../git-hew-local-dry-run) +* [git hew-remote](../git-hew-remote) +* [git hew-remote-dry-run](../git-hew-remote-dry-run) diff --git a/doc/git-hew-remote-dry-run/description.md b/doc/git-hew-remote-dry-run/description.md new file mode 100644 index 00000000..3653ffb4 --- /dev/null +++ b/doc/git-hew-remote-dry-run/description.md @@ -0,0 +1,38 @@ +Delete remote branches that have been merged into an upstream commit (dry run). + +Syntax: + +```shell +git hew-remote-dry-run [] +``` + +Example with the default upstream branch name: + +```shell +git hew-remote-dry-run +``` + +Example with a specific upstream branch name: + +```shell +git hew-remote-dry-run main +``` + +Example with a specific upstream commit hash: + +```shell +git hew-remote-dry-run 4677ad893ee038b113e22f6330da6ae710712f88 +``` + +If a branch is provided, or a commit is provided, then this alias will use it. + +Otherwise, this alias will use the upstream branch name. + +Compare these: + +* [git hew](../git-hew) +* [git hew-dry-run](../git-hew-dry-run) +* [git hew-local](../git-hew-local) +* [git hew-local-dry-run](../git-hew-local-dry-run) +* [git hew-remote](../git-hew-remote) +* [git hew-remote-dry-run](../git-hew-remote-dry-run) diff --git a/doc/git-hew-remote/description.md b/doc/git-hew-remote/description.md new file mode 100644 index 00000000..4164f44c --- /dev/null +++ b/doc/git-hew-remote/description.md @@ -0,0 +1,38 @@ +Delete remote branches that have been merged into an upstream commit. + +Syntax: + +```shell +git hew-remote [] +``` + +Example with the default upstream branch name: + +```shell +git hew-remote +``` + +Example with a specific upstream branch name: + +```shell +git hew-remote main +``` + +Example with a specific upstream commit hash: + +```shell +git hew-remote 4677ad893ee038b113e22f6330da6ae710712f88 +``` + +If a branch is provided, or a commit is provided, then this alias will use it. + +Otherwise, this alias will use the upstream branch name. + +Compare these: + +* [git hew](../git-hew) +* [git hew-dry-run](../git-hew-dry-run) +* [git hew-local](../git-hew-local) +* [git hew-local-dry-run](../git-hew-local-dry-run) +* [git hew-remote](../git-hew-remote) +* [git hew-remote-dry-run](../git-hew-remote-dry-run) diff --git a/doc/git-hew/description.md b/doc/git-hew/description.md new file mode 100644 index 00000000..83a0ee88 --- /dev/null +++ b/doc/git-hew/description.md @@ -0,0 +1,34 @@ +Delete all branches that have been merged into a commit. + +Syntax: + +```shell +hew [] +``` + +Example with default branch name: + +```shell +git hew +``` + +Example with specific branch name: + +```shell +git hew main +``` + +Example with specific commit hash: + +```shell +git hew 4677ad893ee038b113e22f6330da6ae710712f88 +``` + +Compare these: + +* [git hew](../git-hew) +* [git hew-dry-run](../git-hew-dry-run) +* [git hew-local](../git-hew-local) +* [git hew-local-dry-run](../git-hew-local-dry-run) +* [git hew-remote](../git-hew-remote) +* [git hew-remote-dry-run](../git-hew-remote-dry-run) diff --git a/doc/git-ignore/description.md b/doc/git-ignore/description.md new file mode 100644 index 00000000..e483ad7a --- /dev/null +++ b/doc/git-ignore/description.md @@ -0,0 +1,7 @@ +Ignore all untracked files by appending them to `.gitignore`. + +Example: + +```shell +git ignore +``` diff --git a/doc/git-inbound/description.md b/doc/git-inbound/description.md new file mode 100644 index 00000000..3241aa9d --- /dev/null +++ b/doc/git-inbound/description.md @@ -0,0 +1,9 @@ +Show incoming changes compared to upstream. + +Example: + +```shell +git inbound +``` + +Compare [git outbound](../git-outbound). diff --git a/doc/git-init-empty/description.md b/doc/git-init-empty/description.md new file mode 100644 index 00000000..5faaa2f9 --- /dev/null +++ b/doc/git-init-empty/description.md @@ -0,0 +1,10 @@ +Initalize a repo with an empty rebaseable commit. + +Example: + +```shell +git init-empty +``` + +This initialization makes it easier to do later git rebase commands, +because it enables a rebase to go all the way back to the first commit. diff --git a/doc/git-initer/description.md b/doc/git-initer/description.md new file mode 100644 index 00000000..e805abf3 --- /dev/null +++ b/doc/git-initer/description.md @@ -0,0 +1,13 @@ +Initalize a repo using our recommended way i.e. with an empty rebaseable commit. + +Example: + +```shell +git initer +``` + +See [git init-empty](../git-init-empty). + +This initialization makes it easier to do later git rebase commands, +because it enables a rebase to go all the way back to the first commit. + diff --git a/doc/git-intercommit/description.md b/doc/git-intercommit/description.md new file mode 100644 index 00000000..d952ea34 --- /dev/null +++ b/doc/git-intercommit/description.md @@ -0,0 +1,11 @@ +Use interdiff to see patch modifications. + +Example: + +```shell +git intercommit +``` + +If upstream applied a slightly modified patch, and we want to see the +modifications, then we use the program `interdiff` of the patchutils package, +and call "interdiff" between commits. diff --git a/doc/git-issues/description.md b/doc/git-issues/description.md new file mode 100644 index 00000000..ca16e3ec --- /dev/null +++ b/doc/git-issues/description.md @@ -0,0 +1,25 @@ +List all issues mentioned in commit messages between range of commits. + +Example: + +```shell +git issues +``` + +You must adjust the alias regular expression `\\\"ISSUE-[0-9]\\+\\\"` +to be a regular expression that matches your issue tracking system. + +For Jira it should be as simple as putting your project name in place of `ISSUE`. + +Best used with tags: + +```shell +git issues v1.0..v1.1 +``` + +This alias will work with any valid commit range: + +```shell +git issues main..HEAD +``` + diff --git a/doc/git-l/description.md b/doc/git-l/description.md new file mode 100644 index 00000000..f8f37792 --- /dev/null +++ b/doc/git-l/description.md @@ -0,0 +1,7 @@ +Short for `git log`. + +Example: + +```shell +git l +``` diff --git a/doc/git-last-tag/description.md b/doc/git-last-tag/description.md new file mode 100644 index 00000000..e7c9c8a9 --- /dev/null +++ b/doc/git-last-tag/description.md @@ -0,0 +1,17 @@ +Show the last tag in the current branch. + +Example: + +```shell +git last-tag +``` + + +### Documentation for `git describe` + +
+
--tags
+
Instead of using only the annotated tags, use any tag found in refs/tags namespace. This option enables matching a lightweight (non-annotated) tag.
+
--abbrev=<n>
+
Instead of using the default 7 hexadecimal digits as the abbreviated object name, use <n> digits, or as many digits as needed to form a unique object name. An <n> of 0 will suppress long format, only showing the closest tag.
+
diff --git a/doc/git-last-tagged/description.md b/doc/git-last-tagged/description.md new file mode 100644 index 00000000..5685b7fc --- /dev/null +++ b/doc/git-last-tagged/description.md @@ -0,0 +1,7 @@ +Show the last annotated tag in all branches. + +Example: + +```shell +git last-tagged +``` diff --git a/doc/git-lfp/description.md b/doc/git-lfp/description.md new file mode 100644 index 00000000..aaaacd74 --- /dev/null +++ b/doc/git-lfp/description.md @@ -0,0 +1,9 @@ +Log with first parent. + +Example: + +```shell +git lfp +``` + +This alias can be useful for teamwork for a branch that only accepts pull requests. diff --git a/doc/git-lg/description.md b/doc/git-lg/description.md new file mode 100644 index 00000000..b0ead96d --- /dev/null +++ b/doc/git-lg/description.md @@ -0,0 +1,7 @@ +Log with a text-based graphical representation of the commit history. + +Example: + +```shell +git lg +``` diff --git a/doc/git-ll/description.md b/doc/git-ll/description.md new file mode 100644 index 00000000..c1c58bad --- /dev/null +++ b/doc/git-ll/description.md @@ -0,0 +1,31 @@ +Log list - Show log list with our preferred options and short information. + +Example: + +```shell +git ll +* 2021-01-01 a1b2c3d - Add feature foo [Alice Adams] N +… +``` + +### Compare + +Compare the alias [git ll](../git-ll) a.k.a. [git log-list](../git-log-list) which is using: + + * Short date format using YYYY-MM-DD (no time, no zone) + + * Short hash commit format using abbreviated hexadecimal (not full hexadecimal) + + * Short author field using name (no email address) and signature mark + + * Short layout without columns + +And the alias [git lll](../git-lll) a.k.a. [git log-list-long](../git-log-list-long) which is using: + + * Long date format using iso8601 strict YYYY-MM-DDTHH:MM:SS+HH:MM + + * Long hash commit format using full hexadecimal displayed as name-rev + + * Long author field using name and email address and signature mark + + * Long layout with columns diff --git a/doc/git-lll/description.md b/doc/git-lll/description.md new file mode 100644 index 00000000..ceead905 --- /dev/null +++ b/doc/git-lll/description.md @@ -0,0 +1,31 @@ +Log list long - Show log list with our preferred options and long information. + +Example: + +```shell +git lll +* 2021-01-01T00:00:00+00:00 remotes/origin/main Add feature foo Alice Adams N +… +``` + +### Compare + +Compare the alias [git ll](../git-ll) a.k.a. [git log-list](../git-log-list) which is using: + + * Short date format using YYYY-MM-DD (no time, no zone) + + * Short hash commit format using abbreviated hexadecimal (not full hexadecimal) + + * Short author field using name (no email address) and signature mark + + * Short layout without columns + +And the alias [git lll](../git-lll) a.k.a. [git log-list-long](../git-log-list-long) which is using: + + * Long date format using iso8601 strict YYYY-MM-DDTHH:MM:SS+HH:MM + + * Long hash commit format using full hexadecimal displayed as name-rev + + * Long author field using name and email address and signature mark + + * Long layout with columns diff --git a/doc/git-lo/description.md b/doc/git-lo/description.md new file mode 100644 index 00000000..c481a5d3 --- /dev/null +++ b/doc/git-lo/description.md @@ -0,0 +1,7 @@ +Log with one line per item. + +Example: + +```shell +git lo +``` diff --git a/doc/git-log-1-day/description.md b/doc/git-log-1-day/description.md new file mode 100644 index 00000000..00500032 --- /dev/null +++ b/doc/git-log-1-day/description.md @@ -0,0 +1,31 @@ +Show log with the recent day. + +Example: + +```shell +git log-1-day +``` + +## # Compare: Show log with the recent hour, day, week, month, year + +Git alias: + +```git +log-1-hour = log --since=1-hour-ago +log-1-day = log --since=1-day-ago +log-1-week = log --since=1-week-ago +log-1-month = log --since=1-month-ago +log-1-year = log --since=1-year-ago +``` + +## # Compare: Show log with my own recent hour, day, week, month, year + +Git alias: + +```git +log-my-hour = log --author $(git config user.email) --since=1-hour-ago +log-my-day = log --author $(git config user.email) --since=1-day-ago +log-my-week = log --author $(git config user.email) --since=1-week-ago +log-my-month = log --author $(git config user.email) --since=1-month-ago +log-my-year = log --author $(git config user.email) --since=1-year-ago +``` diff --git a/doc/git-log-1-hour/description.md b/doc/git-log-1-hour/description.md new file mode 100644 index 00000000..49f75a58 --- /dev/null +++ b/doc/git-log-1-hour/description.md @@ -0,0 +1,31 @@ +Show log with the recent hour. + +Example: + +```shell +git log-1-hour +``` + +### Compare: Show log with the recent hour, day, week, month, year + +Git alias: + +```git +log-1-hour = log --since=1-hour-ago +log-1-day = log --since=1-day-ago +log-1-week = log --since=1-week-ago +log-1-month = log --since=1-month-ago +log-1-year = log --since=1-year-ago +``` + +### Compare: Show log with my own recent hour, day, week, month, year + +Git alias: + +```git +log-my-hour = log --author $(git config user.email) --since=1-hour-ago +log-my-day = log --author $(git config user.email) --since=1-day-ago +log-my-week = log --author $(git config user.email) --since=1-week-ago +log-my-month = log --author $(git config user.email) --since=1-month-ago +log-my-year = log --author $(git config user.email) --since=1-year-ago +``` diff --git a/doc/git-log-1-month/description.md b/doc/git-log-1-month/description.md new file mode 100644 index 00000000..7287f088 --- /dev/null +++ b/doc/git-log-1-month/description.md @@ -0,0 +1,31 @@ +Show log with the recent month. + +Example: + +```shell +git log-1-month +``` + +### Compare: Show log with the recent hour, day, week, month, year + +Git alias: + +```git +log-1-hour = log --since=1-hour-ago +log-1-day = log --since=1-day-ago +log-1-week = log --since=1-week-ago +log-1-month = log --since=1-month-ago +log-1-year = log --since=1-year-ago +``` + +### Compare: Show log with my own recent hour, day, week, month, year + +Git alias: + +```git +log-my-hour = log --author $(git config user.email) --since=1-hour-ago +log-my-day = log --author $(git config user.email) --since=1-day-ago +log-my-week = log --author $(git config user.email) --since=1-week-ago +log-my-month = log --author $(git config user.email) --since=1-month-ago +log-my-year = log --author $(git config user.email) --since=1-year-ago +``` diff --git a/doc/git-log-1-week/description.md b/doc/git-log-1-week/description.md new file mode 100644 index 00000000..01eeb055 --- /dev/null +++ b/doc/git-log-1-week/description.md @@ -0,0 +1,31 @@ +Show log with the recent week. + +Example: + +```shell +git log-1-week +``` + +### Compare: Show log with the recent hour, day, week, month, year + +Git alias: + +```git +log-1-hour = log --since=1-hour-ago +log-1-day = log --since=1-day-ago +log-1-week = log --since=1-week-ago +log-1-month = log --since=1-month-ago +log-1-year = log --since=1-year-ago +``` + +### Compare: Show log with my own recent hour, day, week, month, year + +Git alias: + +```git +log-my-hour = log --author $(git config user.email) --since=1-hour-ago +log-my-day = log --author $(git config user.email) --since=1-day-ago +log-my-week = log --author $(git config user.email) --since=1-week-ago +log-my-month = log --author $(git config user.email) --since=1-month-ago +log-my-year = log --author $(git config user.email) --since=1-year-ago +``` diff --git a/doc/git-log-1-year/description.md b/doc/git-log-1-year/description.md new file mode 100644 index 00000000..289a626c --- /dev/null +++ b/doc/git-log-1-year/description.md @@ -0,0 +1,31 @@ +Show log with the recent year. + +Example: + +```shell +git log-1-year +``` + +### Compare: Show log with the recent hour, day, week, month, year + +Git alias: + +```git +log-1-hour = log --since=1-hour-ago +log-1-day = log --since=1-day-ago +log-1-week = log --since=1-week-ago +log-1-month = log --since=1-month-ago +log-1-year = log --since=1-year-ago +``` + +### Compare: Show log with my own recent hour, day, week, month, year + +Git alias: + +```git +log-my-hour = log --author $(git config user.email) --since=1-hour-ago +log-my-day = log --author $(git config user.email) --since=1-day-ago +log-my-week = log --author $(git config user.email) --since=1-week-ago +log-my-month = log --author $(git config user.email) --since=1-month-ago +log-my-year = log --author $(git config user.email) --since=1-year-ago +``` diff --git a/doc/git-log-date-first/description.md b/doc/git-log-date-first/description.md new file mode 100644 index 00000000..c731d9e1 --- /dev/null +++ b/doc/git-log-date-first/description.md @@ -0,0 +1,10 @@ +Show the date of the earliest commit, in strict ISO 8601 format. + +Example: + +```shell +git log-date-first +``` + +Compare [git log-date-last](../git-log-date-last). + diff --git a/doc/git-log-date-last/description.md b/doc/git-log-date-last/description.md new file mode 100644 index 00000000..e5a0286c --- /dev/null +++ b/doc/git-log-date-last/description.md @@ -0,0 +1,9 @@ +Show the date of the latest commit, in strict ISO 8601 format. + +Example: + +```shell +git log-date-last +``` + +Compare [git log-date-first](../git-log-date-first). diff --git a/doc/git-log-fetched/description.md b/doc/git-log-fetched/description.md new file mode 100644 index 00000000..6695ec0b --- /dev/null +++ b/doc/git-log-fetched/description.md @@ -0,0 +1,9 @@ +Show log of fetched commits vs. origin/main. + +Example: + +```shell +git log-fetched +``` + + diff --git a/doc/git-log-fresh/description.md b/doc/git-log-fresh/description.md new file mode 100644 index 00000000..07c60962 --- /dev/null +++ b/doc/git-log-fresh/description.md @@ -0,0 +1,7 @@ +Show log of new commits after you fetched, with stats, excluding merges. + +Example: + +```shell +git log-fresh +``` diff --git a/doc/git-log-graph/description.md b/doc/git-log-graph/description.md new file mode 100644 index 00000000..1333ed77 --- /dev/null +++ b/doc/git-log-graph/description.md @@ -0,0 +1 @@ +TODO diff --git a/doc/git-log-list-long/description.md b/doc/git-log-list-long/description.md new file mode 100644 index 00000000..92a89156 --- /dev/null +++ b/doc/git-log-list-long/description.md @@ -0,0 +1,32 @@ +Show log list with our preferred options and long information. + +Example: + +```shell +git log-list-long +* 2021-01-01T00:00:00+00:00 remotes/origin/main Add feature foo Alice Adams N +… +``` + + +### Compare + +Compare the alias [git ll](../git-ll) a.k.a. [git log-list](../git-log-list) which is using: + + * Short date format using YYYY-MM-DD (no time, no zone) + + * Short hash commit format using abbreviated hexadecimal (not full hexadecimal) + + * Short author field using name (no email address) and signature mark + + * Short layout without columns + +And the alias [git lll](../git-lll) a.k.a. [git log-list-long](../git-log-list-long) which is using: + + * Long date format using iso8601 strict YYYY-MM-DDTHH:MM:SS+HH:MM + + * Long hash commit format using full hexadecimal displayed as name-rev + + * Long author field using name and email address and signature mark + + * Long layout with columns diff --git a/doc/git-log-list/description.md b/doc/git-log-list/description.md new file mode 100644 index 00000000..ed5de9ed --- /dev/null +++ b/doc/git-log-list/description.md @@ -0,0 +1,32 @@ +Show log list with our preferred options and short information. + +Example: + +```shell +git log-list +* 2021-01-01 a1b2c3d - Add feature foo [Alice Adams] N +… +``` + + +### Compare + +Compare the alias [git ll](../git-ll) a.k.a. [git log-list](../git-log-list) which is using: + + * Short date format using YYYY-MM-DD (no time, no zone) + + * Short hash commit format using abbreviated hexadecimal (not full hexadecimal) + + * Short author field using name (no email address) and signature mark + + * Short layout without columns + +And the alias [git lll](../git-lll) a.k.a. [git log-list-long](../git-log-list-long) which is using: + + * Long date format using iso8601 strict YYYY-MM-DDTHH:MM:SS+HH:MM + + * Long hash commit format using full hexadecimal displayed as name-rev + + * Long author field using name and email address and signature mark + + * Long layout with columns diff --git a/doc/git-log-local/description.md b/doc/git-log-local/description.md new file mode 100644 index 00000000..cf873b4c --- /dev/null +++ b/doc/git-log-local/description.md @@ -0,0 +1 @@ + diff --git a/doc/git-log-my-day/description.md b/doc/git-log-my-day/description.md new file mode 100644 index 00000000..6ffa471f --- /dev/null +++ b/doc/git-log-my-day/description.md @@ -0,0 +1,31 @@ +Show log with my own recent day. + +Example: + +```shell +git log-my-day +``` + +### Compare: Show log with the recent hour, day, week, month, year + +Git alias: + +```git +log-1-hour = log --since=1-hour-ago +log-1-day = log --since=1-day-ago +log-1-week = log --since=1-week-ago +log-1-month = log --since=1-month-ago +log-1-year = log --since=1-year-ago +``` + +### Compare: Show log with my own recent hour, day, week, month, year + +Git alias: + +```git +log-my-hour = log --author $(git config user.email) --since=1-hour-ago +log-my-day = log --author $(git config user.email) --since=1-day-ago +log-my-week = log --author $(git config user.email) --since=1-week-ago +log-my-month = log --author $(git config user.email) --since=1-month-ago +log-my-year = log --author $(git config user.email) --since=1-year-ago +``` diff --git a/doc/git-log-my-hour/description.md b/doc/git-log-my-hour/description.md new file mode 100644 index 00000000..c2f51acf --- /dev/null +++ b/doc/git-log-my-hour/description.md @@ -0,0 +1,31 @@ +Show log with my own recent hour. + +Example: + +```shell +git log-my-hour +``` + +### Compare: Show log with the recent hour, day, week, month, year + +Git alias: + +```git +log-1-hour = log --since=1-hour-ago +log-1-day = log --since=1-day-ago +log-1-week = log --since=1-week-ago +log-1-month = log --since=1-month-ago +log-1-year = log --since=1-year-ago +``` + +### Compare: Show log with my own recent hour, day, week, month, year + +Git alias: + +```git +log-my-hour = log --author $(git config user.email) --since=1-hour-ago +log-my-day = log --author $(git config user.email) --since=1-day-ago +log-my-week = log --author $(git config user.email) --since=1-week-ago +log-my-month = log --author $(git config user.email) --since=1-month-ago +log-my-year = log --author $(git config user.email) --since=1-year-ago +``` diff --git a/doc/git-log-my-month/description.md b/doc/git-log-my-month/description.md new file mode 100644 index 00000000..a45a2c50 --- /dev/null +++ b/doc/git-log-my-month/description.md @@ -0,0 +1,31 @@ +Show log with my own recent month. + +Example: + +```shell +git log-my-month +``` + +### Compare: Show log with the recent hour, day, week, month, year + +Git alias: + +```git +log-1-hour = log --since=1-hour-ago +log-1-day = log --since=1-day-ago +log-1-week = log --since=1-week-ago +log-1-month = log --since=1-month-ago +log-1-year = log --since=1-year-ago +``` + +### Compare: Show log with my own recent hour, day, week, month, year + +Git alias: + +```git +log-my-hour = log --author $(git config user.email) --since=1-hour-ago +log-my-day = log --author $(git config user.email) --since=1-day-ago +log-my-week = log --author $(git config user.email) --since=1-week-ago +log-my-month = log --author $(git config user.email) --since=1-month-ago +log-my-year = log --author $(git config user.email) --since=1-year-ago +``` diff --git a/doc/git-log-my-week/description.md b/doc/git-log-my-week/description.md new file mode 100644 index 00000000..d1fa524d --- /dev/null +++ b/doc/git-log-my-week/description.md @@ -0,0 +1,31 @@ +Show log with my own recent week. + +Example: + +```shell +git log-my-week +``` + +### Compare: Show log with the recent hour, day, week, month, year + +Git alias: + +```git +log-1-hour = log --since=1-hour-ago +log-1-day = log --since=1-day-ago +log-1-week = log --since=1-week-ago +log-1-month = log --since=1-month-ago +log-1-year = log --since=1-year-ago +``` + +### Compare: Show log with my own recent hour, day, week, month, year + +Git alias: + +```git +log-my-hour = log --author $(git config user.email) --since=1-hour-ago +log-my-day = log --author $(git config user.email) --since=1-day-ago +log-my-week = log --author $(git config user.email) --since=1-week-ago +log-my-month = log --author $(git config user.email) --since=1-month-ago +log-my-year = log --author $(git config user.email) --since=1-year-ago +``` diff --git a/doc/git-log-my-year/description.md b/doc/git-log-my-year/description.md new file mode 100644 index 00000000..adbe0880 --- /dev/null +++ b/doc/git-log-my-year/description.md @@ -0,0 +1,31 @@ +Show log with my own recent year. + +Example: + +```shell +git log-my-year +``` + +### Compare: Show log with the recent hour, day, week, month, year + +Git alias: + +```git +log-1-hour = log --since=1-hour-ago +log-1-day = log --since=1-day-ago +log-1-week = log --since=1-week-ago +log-1-month = log --since=1-month-ago +log-1-year = log --since=1-year-ago +``` + +### Compare: Show log with my own recent hour, day, week, month, year + +Git alias: + +```git +log-my-hour = log --author $(git config user.email) --since=1-hour-ago +log-my-day = log --author $(git config user.email) --since=1-day-ago +log-my-week = log --author $(git config user.email) --since=1-week-ago +log-my-month = log --author $(git config user.email) --since=1-month-ago +log-my-year = log --author $(git config user.email) --since=1-year-ago +``` diff --git a/doc/git-log-my/description.md b/doc/git-log-my/description.md new file mode 100644 index 00000000..fb287742 --- /dev/null +++ b/doc/git-log-my/description.md @@ -0,0 +1,7 @@ +Show log for my own commits by my own user email. + +Example: + +```shell +git log-my +``` diff --git a/doc/git-log-of-count-and-day-of-week/description.md b/doc/git-log-of-count-and-day-of-week/description.md new file mode 100644 index 00000000..fe9c4236 --- /dev/null +++ b/doc/git-log-of-count-and-day-of-week/description.md @@ -0,0 +1,9 @@ +Show log with count and day of week. + +Example: + +```shell +git log-of-count-and-day-of-week +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-count-and-day/description.md b/doc/git-log-of-count-and-day/description.md new file mode 100644 index 00000000..debea983 --- /dev/null +++ b/doc/git-log-of-count-and-day/description.md @@ -0,0 +1,9 @@ +Show log with count and day. + +Example: + +```shell +git log-of-count-and-day +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-count-and-email/description.md b/doc/git-log-of-count-and-email/description.md new file mode 100644 index 00000000..fd944280 --- /dev/null +++ b/doc/git-log-of-count-and-email/description.md @@ -0,0 +1,9 @@ +Show log with count and email. + +Example: + +```shell +git log-of-count-and-email +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-count-and-format-with-date/description.md b/doc/git-log-of-count-and-format-with-date/description.md new file mode 100644 index 00000000..862060a7 --- /dev/null +++ b/doc/git-log-of-count-and-format-with-date/description.md @@ -0,0 +1,9 @@ +Show log with count and custom format string with date. + +Example: + +```shell +git log-of-count-and-format-with-date +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-count-and-format/description.md b/doc/git-log-of-count-and-format/description.md new file mode 100644 index 00000000..2dd85b61 --- /dev/null +++ b/doc/git-log-of-count-and-format/description.md @@ -0,0 +1,9 @@ +Show a count of log entries and a custom format string. + +Example: + +```shell +git log-of-count-and-format +``` + +Compare [git log-of-format-and-count](../git-log-of-format-and-count). diff --git a/doc/git-log-of-count-and-hour-of-day/description.md b/doc/git-log-of-count-and-hour-of-day/description.md new file mode 100644 index 00000000..a51fd3c9 --- /dev/null +++ b/doc/git-log-of-count-and-hour-of-day/description.md @@ -0,0 +1,9 @@ +Show log with count and hour of day. + +Example: + +```shell +git-log-of-count-and-hour-of-day +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-count-and-hour/description.md b/doc/git-log-of-count-and-hour/description.md new file mode 100644 index 00000000..efa3047b --- /dev/null +++ b/doc/git-log-of-count-and-hour/description.md @@ -0,0 +1,9 @@ +Show log with count and hour. + +Example: + +```shell +git-log-of-count-and-hour +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-count-and-month/description.md b/doc/git-log-of-count-and-month/description.md new file mode 100644 index 00000000..7827091b --- /dev/null +++ b/doc/git-log-of-count-and-month/description.md @@ -0,0 +1,9 @@ +Show log with count and month. + +Example: + +```shell +git-log-of-count-and-month +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-count-and-week-of-year/description.md b/doc/git-log-of-count-and-week-of-year/description.md new file mode 100644 index 00000000..e3091848 --- /dev/null +++ b/doc/git-log-of-count-and-week-of-year/description.md @@ -0,0 +1,9 @@ +Show log with count and week of year. + +Example: + +```shell +git-log-of-count-and-week-of-year +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-count-and-week/description.md b/doc/git-log-of-count-and-week/description.md new file mode 100644 index 00000000..4b85efa8 --- /dev/null +++ b/doc/git-log-of-count-and-week/description.md @@ -0,0 +1,9 @@ +Show log with count and week. + +Example: + +```shell +git-log-of-count-and-week +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-count-and-year/description.md b/doc/git-log-of-count-and-year/description.md new file mode 100644 index 00000000..3490eb45 --- /dev/null +++ b/doc/git-log-of-count-and-year/description.md @@ -0,0 +1,9 @@ +Show log with count and year. + +Example: + +```shell +git-log-of-count-and-year +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-day-and-count/description.md b/doc/git-log-of-day-and-count/description.md new file mode 100644 index 00000000..724d27f3 --- /dev/null +++ b/doc/git-log-of-day-and-count/description.md @@ -0,0 +1,9 @@ +Show log with day and count. + +Example: + +```shell +git-log-of-day-and-count +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-day-of-week-and-count/description.md b/doc/git-log-of-day-of-week-and-count/description.md new file mode 100644 index 00000000..b29016ea --- /dev/null +++ b/doc/git-log-of-day-of-week-and-count/description.md @@ -0,0 +1,9 @@ +Show log with day of week and count. + +Example: + +```shell +git-log-of-day-of-week-and-count +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-email-and-count/description.md b/doc/git-log-of-email-and-count/description.md new file mode 100644 index 00000000..391f5568 --- /dev/null +++ b/doc/git-log-of-email-and-count/description.md @@ -0,0 +1,9 @@ +Show log with email and count. + +Example: + +```shell +git-log-of-email-and-count +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-format-and-count-with-date/description.md b/doc/git-log-of-format-and-count-with-date/description.md new file mode 100644 index 00000000..2d51e6df --- /dev/null +++ b/doc/git-log-of-format-and-count-with-date/description.md @@ -0,0 +1,9 @@ +Show log with a custom format string and a count and a date. + +Example: + +```shell +git-log-of-format-and-count-with-date +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-format-and-count/description.md b/doc/git-log-of-format-and-count/description.md new file mode 100644 index 00000000..ee602ba6 --- /dev/null +++ b/doc/git-log-of-format-and-count/description.md @@ -0,0 +1,9 @@ +Show log with a custom format string and count. + +Example: + +```shell +git log-of-format-and-count +``` + +Compare [git log-of-count-and-format](../git-log-of-count-and-format). diff --git a/doc/git-log-of-hour-and-count/description.md b/doc/git-log-of-hour-and-count/description.md new file mode 100644 index 00000000..0c8f7d50 --- /dev/null +++ b/doc/git-log-of-hour-and-count/description.md @@ -0,0 +1,9 @@ +Show log with hour and count. + +Example: + +```shell +git-log-of-hour-and-count +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-hour-of-day-and-count/description.md b/doc/git-log-of-hour-of-day-and-count/description.md new file mode 100644 index 00000000..d0c3400c --- /dev/null +++ b/doc/git-log-of-hour-of-day-and-count/description.md @@ -0,0 +1,9 @@ +Show log with hour of day and count. + +Example: + +```shell +git-log-of-hour-of-day-and-count +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-month-and-count/description.md b/doc/git-log-of-month-and-count/description.md new file mode 100644 index 00000000..74aa71b7 --- /dev/null +++ b/doc/git-log-of-month-and-count/description.md @@ -0,0 +1,9 @@ +Show log with month and count. + +Example: + +```shell +git-log-of-month-and-count +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-week-and-count/description.md b/doc/git-log-of-week-and-count/description.md new file mode 100644 index 00000000..21765d7a --- /dev/null +++ b/doc/git-log-of-week-and-count/description.md @@ -0,0 +1,9 @@ +Show log with week and count. + +Example: + +```shell +git-log-of-week-and-count +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-week-of-year-and-count/description.md b/doc/git-log-of-week-of-year-and-count/description.md new file mode 100644 index 00000000..bb2a35dc --- /dev/null +++ b/doc/git-log-of-week-of-year-and-count/description.md @@ -0,0 +1,9 @@ +Show log with week of year and count. + +Example: + +```shell +git-log-of-week-of-year-and-count +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of-year-and-count/description.md b/doc/git-log-of-year-and-count/description.md new file mode 100644 index 00000000..99827e96 --- /dev/null +++ b/doc/git-log-of-year-and-count/description.md @@ -0,0 +1,9 @@ +Show log with year and count. + +Example: + +```shell +git-log-of-year-and-count +``` + +Compare [`git log-of-*`](../git-log-of). diff --git a/doc/git-log-of/description.md b/doc/git-log-of/description.md new file mode 100644 index 00000000..3f8bc0bb --- /dev/null +++ b/doc/git-log-of/description.md @@ -0,0 +1,212 @@ +# git log-of-* + +## Show log entries using a count and a custom format string + + +## # Show a specific format string and its number of log entries + +Git alias: + +```git +log-of-format-and-count = "!f() { format=\"$1\"; shift; git log $@ --format=oneline --format="$format" | awk '{a[$0]++}END{for(i in a){print i, a[i], int((a[i]/NR)*100) \"%\"}}' | sort; }; f" + +log-of-count-and-format = "!f() { format=\"$1\"; shift; git log $@ --format=oneline --format="$format" | awk '{a[$0]++}END{for(i in a){print a[i], int((a[i]/NR)*100) \"%\", i}}' | sort -nr; }; f" +``` + +Example: + +```shell +git log-of-format-and-count + +git log-of-count-and-format +``` + + +## # Show the number of log entries by a specific format string and date format string + +Git alias: + +```git +log-of-format-and-count-with-date = "!f() { format=\"$1\"; shift; date_format=\"$1\"; shift; git log $@ --format=oneline --format=\"$format\" --date=format:\"$date_format\" | awk '{a[$0]++}END{for(i in a){print i, a[i], int((a[i]/NR)*100) \"%\"}}' | sort -r; }; f" + +log-of-count-and-format-with-date = "!f() { format=\"$1\"; shift; date_format=\"$1\"; shift; git log $@ --format=oneline --format=\"$format\" --date=format:\"$date_format\" | awk '{a[$0]++}END{for(i in a){print a[i], int((a[i]/NR)*100) \"%\", i}}' | sort -nr; }; f" +``` + +Example: + +```shell +git log-of-format-and-count-with-date + +git log-of-count-and-format-with-date +``` + + +## # Show the number of log items by email + +Git alias: + +```git +log-of-email-and-count = "!f() { git log-of-format-and-count \"%aE\" $@; }; f" + +log-of-count-and-email = "!f() { git log-of-count-and-format \"%aE\" $@; }; f" +``` + +Example: + +```shell +git log-of-email-and-count + +git log-of-count-and-email +``` + + +## # Show the number of log items by hour + +Git alias: + +```git +log-of-hour-and-count = "!f() { git log-of-format-and-count-with-date \"%ad\" \"%Y-%m-%dT%H\" $@ ; }; f" + +log-of-count-and-hour = "!f() { git log-of-count-and-format-with-date \"%ad\" \"%Y-%m-%dT%H\" $@ ; }; f" +``` + +Example: + +```shell +git log-of-hour-and-count + +git log-of-count-and-hour +``` + + +## # Show the number of log items by day + +Git alias: + +```git +log-of-day-and-count = "!f() { git log-of-format-and-count-with-date \"%ad\" \"%Y-%m-%d\" $@ ; }; f" + +log-of-count-and-day = "!f() { git log-of-count-and-format-with-date \"%ad\" \"%Y-%m-%d\" $@ ; }; f" +``` + +Example: + +```shell +git log-of-day-and-count + +git log-of-count-and-day +``` + + +## # Show the number of log items by week + +Git alias: + +```git +log-of-week-and-count = "!f() { git log-of-format-and-count-with-date \"%ad\" \"%Y#%V\" $@; }; f" + +log-of-count-and-week = "!f() { git log-of-count-and-format-with-date \"%ad\" \"%Y#%V\" $@; }; f" +``` + +Example: + +```shell +git log-of-week-and-count + +git log-of-count-and-week +``` + + +## # Show the number of log items by month + +Git alias: + +```git +log-of-month-and-count = "!f() { git log-of-format-and-count-with-date \"%ad\" \"%Y-%m\" $@ ; }; f" + +log-of-count-and-month = "!f() { git log-of-count-and-format-with-date \"%ad\" \"%Y-%m\" $@ ; }; f" +``` + +Example: + +```shell +git log-of-month-and-count + +git log-of-count-and-month +``` + + +## # Show the number of log items by year + +Git alias: + +```git +log-of-year-and-count = "!f() { git log-of-format-and-count-with-date \"%ad\" \"%Y\" $@ ; }; f" + +log-of-count-and-year = "!f() { git log-of-count-and-format-with-date \"%ad\" \"%Y\" $@ ; }; f" +``` + +Example: + +```shell +git log-of-year-and-count + +git log-of-count-and-year +``` + + +## # Show the number of log items by hour of day + +Git alias: + +```git +log-of-hour-of-day-and-count = "!f() { git log-of-format-and-count-with-date \"%ad\" \"%H\" $@; }; f" + +log-of-count-and-hour-of-day = "!f() { git log-of-count-and-format-with-date \"%ad\" \"%H\" $@; }; f" +``` + +Example: + +```shell +git log-of-hour-of-day-and-count + +git log-of-count-and-hour-of-day +``` + + +## # Show the number of log items by day of week + +Git alias: + +```git +log-of-day-of-week-and-count = "!f() { git log-of-format-and-count-with-date \"%ad\" \"%u\" $@; }; f" + +log-of-count-and-day-of-week = "!f() { git log-of-count-and-format-with-date \"%ad\" \"%u\" $@; }; f" +``` + +Example: + +```shell +git log-of-day-of-week-and-count + +git log-of-count-and-day-of-week +``` + + +## # Show the number of log items by week of year + +Git alias: + +```git +log-of-week-of-year-and-count = "!f() { git log-of-format-and-count-with-date \"%ad\" \"%V\" $@; }; f" + +log-of-count-and-week-of-year = "!f() { git log-of-count-and-format-with-date \"%ad\" \"%V\" $@; }; f" +``` + +Example: + +```shell +git log-of-week-of-year-and-count + +git log-of-count-and-week-of-year +``` diff --git a/doc/git-log-refs/description.md b/doc/git-log-refs/description.md new file mode 100644 index 00000000..c5762db4 --- /dev/null +++ b/doc/git-log-refs/description.md @@ -0,0 +1,7 @@ +Show log with commits that are referred by some branch or tag. + +Example: + +```shell +git log-refs +``` diff --git a/doc/git-log-timeline/description.md b/doc/git-log-timeline/description.md new file mode 100644 index 00000000..1333ed77 --- /dev/null +++ b/doc/git-log-timeline/description.md @@ -0,0 +1 @@ +TODO diff --git a/doc/git-log/description.md b/doc/git-log/description.md new file mode 100644 index 00000000..d72e1731 --- /dev/null +++ b/doc/git-log/description.md @@ -0,0 +1,94 @@ +# git log + +## Log helpers + +Git alias: + +```git +# Show log list in our preferred format for our key performance indicators. A.k.a. `ll`. +# +# * Short date format using YYYY-MM-DD (no time, no zone) +# * Short hash commit format using abbreviated hexadecimal (not full hexadecimal) +# * Short author field using name (no email address) and signature mark +# * Short layout without columns +# +log-list = log --graph --topo-order --date=short --abbrev-commit --decorate --all --boundary --pretty=format:'%Cblue%ad %C(auto)%h%Creset -%C(auto)%d%Creset %s %Cblue[%aN]%Creset %Cblue%G?%Creset' + +# Show log list in our preferred format for our key performance indicators, with long items. A.k.a. `lll`. +# +# * Long date format using iso8601 strict YYYY-MM-DDTHH:MM:SS+HH:MM +# * Long hash commit format using full hexadecimal displayed as name-rev +# * Long author field using name and email address and signature mark +# * Long layout with columns +# +log-list-long = log --graph --topo-order --date=iso8601-strict --no-abbrev-commit --decorate --all --boundary --pretty=format:'%Cblue%ad %C(auto)%h%Creset -%C(auto)%d%Creset %s %Cblue[%aN <%aE>]%Creset %Cblue%G?%Creset' + +# Show log with dates in our local timezone +log-local = log --date=local + +# Show log as a graph +log-graph = log --graph --all --oneline --decorate + +# TODO +log-refs = log --all --graph --decorate --oneline --simplify-by-decoration --no-merges +log-timeline = log --format='%h %an %ar - %s' +log-local = log --oneline origin..HEAD +log-fetched = log --oneline HEAD..origin/main +``` + +Example: + +```shell +git log-list +git log-list-long +git log-local +git log-graph +git log-refs +git log-timeline +git log-local +git log-fetched +``` + + +### Show log with the recent hour, day, week, month, year + +Git alias: + +```git +log-1-hour = log --since=1-hour-ago +log-1-day = log --since=1-day-ago +log-1-week = log --since=1-week-ago +log-1-month = log --since=1-month-ago +log-1-year = log --since=1-year-ago + +Example: + +```shell +git log-1-hour +git log-1-day +git log-1-week +git log-1-month +git log-1-year +``` + +### Show log with my own recent hour, day, week, month, year + +Git alias: + +```git +log-my-hour = log --author $(git config user.email) --since=1-hour-ago +log-my-day = log --author $(git config user.email) --since=1-day-ago +log-my-week = log --author $(git config user.email) --since=1-week-ago +log-my-month = log --author $(git config user.email) --since=1-month-ago +log-my-year = log --author $(git config user.email) --since=1-year-ago +``` + +Example: + +```shell +git log-my-hour +git log-my-day +git log-my-week +git log-my-month +git log-my-year +``` diff --git a/doc/git-lor/description.md b/doc/git-lor/description.md new file mode 100644 index 00000000..b6f18ca5 --- /dev/null +++ b/doc/git-lor/description.md @@ -0,0 +1,7 @@ +Log with one line per item, in reverse order i.e. recent items first. + +Example: + +```shell +git lor +``` diff --git a/doc/git-lp/description.md b/doc/git-lp/description.md new file mode 100644 index 00000000..19c0343e --- /dev/null +++ b/doc/git-lp/description.md @@ -0,0 +1,7 @@ +Log with patch generation. + +Example: + +```shell +git lp +``` diff --git a/doc/git-ls/description.md b/doc/git-ls/description.md new file mode 100644 index 00000000..11cf1abe --- /dev/null +++ b/doc/git-ls/description.md @@ -0,0 +1,7 @@ +List files in the index and the working tree; like Unix `ls` command. + +Example: + +```shell +git ls +``` diff --git a/doc/git-lsd/description.md b/doc/git-lsd/description.md new file mode 100644 index 00000000..f68cea23 --- /dev/null +++ b/doc/git-lsd/description.md @@ -0,0 +1,7 @@ +List files and show debug information. + +Example: + +```shell +git lsd +``` diff --git a/doc/git-lsfn/description.md b/doc/git-lsfn/description.md new file mode 100644 index 00000000..4132f5bc --- /dev/null +++ b/doc/git-lsfn/description.md @@ -0,0 +1,7 @@ +List files and show full name. + +Example: + +```shell +git lsfn +``` diff --git a/doc/git-lsio/description.md b/doc/git-lsio/description.md new file mode 100644 index 00000000..c3f032aa --- /dev/null +++ b/doc/git-lsio/description.md @@ -0,0 +1,31 @@ +List files that Git is ignoring. + +Example: + +```shell +git lsio +``` + +### Documentation for `git ls-files` + +
+ +
-i, --ignored
+ +
+Show only ignored files in the output. … +
+ +
-o, --others
+ +
+Show other (i.e. untracked) files in the output. +
+ +
--exclude-standard
+ +
+Add the standard Git exclusions … +
+ +
diff --git a/doc/git-lto/description.md b/doc/git-lto/description.md new file mode 100644 index 00000000..b097ac1c --- /dev/null +++ b/doc/git-lto/description.md @@ -0,0 +1,9 @@ +Log with items appearing in topological order. + +Example: + +```shell +git lto +``` + +Topological order means that descendant commits are shown before their parents. diff --git a/doc/git-m/description.md b/doc/git-m/description.md new file mode 100644 index 00000000..6387e986 --- /dev/null +++ b/doc/git-m/description.md @@ -0,0 +1,7 @@ +Short for "git merge". + +Example: + +```shell +git m +``` diff --git a/doc/git-ma/description.md b/doc/git-ma/description.md new file mode 100644 index 00000000..dbc54ba0 --- /dev/null +++ b/doc/git-ma/description.md @@ -0,0 +1,7 @@ +Merge abort i.e. abort the merge process. + +Example: + +```shell +git ma +``` diff --git a/doc/git-mainly/description.md b/doc/git-mainly/description.md new file mode 100644 index 00000000..db2bec3e --- /dev/null +++ b/doc/git-mainly/description.md @@ -0,0 +1,11 @@ +Make local like main. + +Example: + +```shell +git mainly +``` + +Do everything we can to make the local repo like the main branch. + + diff --git a/doc/git-mc/description.md b/doc/git-mc/description.md new file mode 100644 index 00000000..d4182af3 --- /dev/null +++ b/doc/git-mc/description.md @@ -0,0 +1,7 @@ +Merge continue i.e. continue the merge process. + +Example: + +```shell +git mc +``` diff --git a/doc/git-merge-safe/description.md b/doc/git-merge-safe/description.md new file mode 100644 index 00000000..339e2a39 --- /dev/null +++ b/doc/git-merge-safe/description.md @@ -0,0 +1,33 @@ +Join two or more development histories together safely. + +Example: + +```shell +git merge-safe +``` + +### Documentation for `git-merge` + +
+ +
--no-commit
+ +
+Perform the merge and stop just before creating a merge commit, +to give the user a chance to inspect and further tweak the merge +result before committing. + +Note that fast-forward updates do not create a merge commit and +therefore there is no way to stop those merges with --no-commit. +Thus, if you want to ensure your branch is not changed or updated +by the merge command, use --no-commit --no-ff. +
+ +
--no-ff
+ +
+Create a merge commit in all cases, even when the merge could +instead be resolved as a fast-forward. +
+ +
diff --git a/doc/git-merge-span-diff/description.md b/doc/git-merge-span-diff/description.md new file mode 100644 index 00000000..58efdd8e --- /dev/null +++ b/doc/git-merge-span-diff/description.md @@ -0,0 +1,14 @@ +Show the changes that were introduced by a merge. + +Example: + +```shell +git merge-span-diff +``` + +Compare: + +* [git merge-span](../git-merge-span) (summary) +* [git merge-span-log](../git-merge-span-log) +* [git merge-span-diff](../git-merge-span-diff) (this alias) +* [git merge-span-difftool](../git-merge-span-difftool) diff --git a/doc/git-merge-span-difftool/description.md b/doc/git-merge-span-difftool/description.md new file mode 100644 index 00000000..5c37e775 --- /dev/null +++ b/doc/git-merge-span-difftool/description.md @@ -0,0 +1,14 @@ +Show the changes that were introduced by a merge, in your difftool. + +Example: + +```shell +git merge-span-difftool +``` + +Compare: + +* [git merge-span](../git-merge-span) (summary) +* [git merge-span-log](../git-merge-span-log) +* [git merge-span-diff](../git-merge-span-diff) +* [git merge-span-difftool](../git-merge-span-difftool) (this alias) diff --git a/doc/git-merge-span-log/description.md b/doc/git-merge-span-log/description.md new file mode 100644 index 00000000..ecf0ccdd --- /dev/null +++ b/doc/git-merge-span-log/description.md @@ -0,0 +1,14 @@ +Find the commits that were introduced by a merge. + +Example: + +```shell +git merge-span-log +``` + +Compare: + +* [git merge-span](../git-merge-span) (summary) +* [git merge-span-log](../git-merge-span-log) (this alias) +* [git merge-span-diff](../git-merge-span-diff) +* [git merge-span-difftool](../git-merge-span-difftool) diff --git a/doc/git-merge-span/description.md b/doc/git-merge-span/description.md new file mode 100644 index 00000000..1ddacbc1 --- /dev/null +++ b/doc/git-merge-span/description.md @@ -0,0 +1,17 @@ +Merge span aliases. + +Example: + +```shell +git merge-span +git merge-span-log +git merge-span-diff +git merge-span-difftool +``` + +Compare: + +* [git merge-span](../git-merge-span) (this page) +* [git merge-span-log](../git-merge-span-log) +* [git merge-span-diff](../git-merge-span-diff) +* [git merge-span-difftool](../git-merge-span-difftool) diff --git a/doc/git-mncnf/description.md b/doc/git-mncnf/description.md new file mode 100644 index 00000000..00a9034d --- /dev/null +++ b/doc/git-mncnf/description.md @@ -0,0 +1,9 @@ +Merge with no autocommit, and with no fast-forward. + +Example: + +```shell +git mncnf +``` + +This does a merge, but without autocommit, and with a commit even if the merge resolves as a fast-forward. diff --git a/doc/git-move-alias/description.md b/doc/git-move-alias/description.md new file mode 100644 index 00000000..95fd8e6d --- /dev/null +++ b/doc/git-move-alias/description.md @@ -0,0 +1,8 @@ +Rename an existing Git alias. + +Example: + +```shell +git move-alias --local foo bar +git move-alias --global foo bar +``` diff --git a/doc/git-o/description.md b/doc/git-o/description.md new file mode 100644 index 00000000..5f54ddd8 --- /dev/null +++ b/doc/git-o/description.md @@ -0,0 +1,7 @@ +Short for "git checkout". + +Example: + +```shell +git o +``` diff --git a/doc/git-optimizer/description.md b/doc/git-optimizer/description.md new file mode 100644 index 00000000..2ee222eb --- /dev/null +++ b/doc/git-optimizer/description.md @@ -0,0 +1,21 @@ +Optimize a repo our preferred way i.e. by pruning and repacking. + + +Example: + +```shell +git optimizer +``` + +The purpose of this command is to do everything possible +to optimize the repository. + +This command takes a long time to run, perhaps even overnight. + +This command calls our other aliases: + + * [git pruner](../git-pruner) + + * [git repacker](../git-repacker) + +This command also calls `git prune-packed`. This step may be unnecessary. diff --git a/doc/git-orphans/description.md b/doc/git-orphans/description.md new file mode 100644 index 00000000..07acbb20 --- /dev/null +++ b/doc/git-orphans/description.md @@ -0,0 +1,15 @@ +Find all objects that aren't referenced by any other object. + +Example: + +```shell +git orphans +``` + +To help an orphan, we can create a new branch with the orphan's commit hash, +then merge it into our current branch: + +```shell +git branch foo +git merge foo +``` diff --git a/doc/git-ours-git-theirs/description.md b/doc/git-ours-git-theirs/description.md new file mode 100644 index 00000000..2659ab62 --- /dev/null +++ b/doc/git-ours-git-theirs/description.md @@ -0,0 +1,28 @@ +# git ours & git theirs + +## Easy merging when you know which files you want + +Git alias: + +```git +ours = !"f() { git checkout --ours $@ && git add $@; }; f" +theirs = !"f() { git checkout --theirs $@ && git add $@; }; f" +``` + +Example: + +```shell +git ours +git theirs +``` + +Sometimes during a merge you want to take a file from one side wholesale. + +The following aliases expose the "ours" and "theirs" options which let you +pick a file(s) from the current branch or the merged branch respectively. + +Compare: + +* [git ours](../git-ours) - Checkout our version of a file and add it + +* [git theirs](../git-theirs) - Checkout their version of a file and add it diff --git a/doc/git-ours/description.md b/doc/git-ours/description.md new file mode 100644 index 00000000..d37fc38f --- /dev/null +++ b/doc/git-ours/description.md @@ -0,0 +1,15 @@ +Checkout our version of a file and add it. + +Example: + +```shell +git ours +``` + +Compare: + +* [git ours & git theirs](../git-ours-git-theirs) (describes both) + +* [git ours](../git-ours) (this alias) + +* [git theirs](../git-theirs) diff --git a/doc/git-outbound/description.md b/doc/git-outbound/description.md new file mode 100644 index 00000000..ed3c8588 --- /dev/null +++ b/doc/git-outbound/description.md @@ -0,0 +1,9 @@ +Show outgoing changes compared to upstream. + +Example: + +```shell +git outbound +``` + +Compare [git inbound](../git-inbound). diff --git a/doc/git-p/description.md b/doc/git-p/description.md new file mode 100644 index 00000000..66faba04 --- /dev/null +++ b/doc/git-p/description.md @@ -0,0 +1,7 @@ +Short for `git pull`. + +Example: + +```shell +git p +``` diff --git a/doc/git-panic/description.md b/doc/git-panic/description.md new file mode 100644 index 00000000..3cb6a18c --- /dev/null +++ b/doc/git-panic/description.md @@ -0,0 +1,9 @@ +When you're a little worried that the world is coming to an end. + +Example: + +```shell +git panic +``` + +This alias creates an archive of the entire repo. diff --git a/doc/git-pf/description.md b/doc/git-pf/description.md new file mode 100644 index 00000000..9728263f --- /dev/null +++ b/doc/git-pf/description.md @@ -0,0 +1,7 @@ +Pull if a merge can be resolved as a fast-forward, otherwise fail. + +Example: + +```shell +git pf +``` diff --git a/doc/git-pr/description.md b/doc/git-pr/description.md new file mode 100644 index 00000000..3db5d554 --- /dev/null +++ b/doc/git-pr/description.md @@ -0,0 +1,47 @@ +Pull with rebase i.e. provide a cleaner, linear, bisectable history. + +Example: + +```shell +git pr +``` + +To automatically do "pull --rebase" everywhere: + +```shell +git config --global pull.rebase true +``` + +To automatically do "pull --rebase" for any branch based on +the branch "main": + +```shell +git config branch.main.rebase true +``` + +To automatically do "pull --rebase" for any newly-created branches: + +```shell +git config --global branch.autosetuprebase always +``` + +To integrate changes between branches, you can merge or rebase. + +When we use "git pull", then git does a fetch then a merge. + +If we've made changes locally and someone else has pushed changes +to our git host then git will automatically merge these together +and create a merge commit that looks like this in the history: + +```shell +12345678 - Merge branch 'foo' of bar into main +``` + +When we use "git pull --rebase", then git does a fetch then a rebase. + +A rebase resets the HEAD of your local branch to be the same as +the remote HEAD, then replays your local commits back into repo. + +This means you don't get any noisy merge messages in your history. + +This gives us a linear history, and also helps with git bisect. diff --git a/doc/git-prp/description.md b/doc/git-prp/description.md new file mode 100644 index 00000000..42cc670a --- /dev/null +++ b/doc/git-prp/description.md @@ -0,0 +1,45 @@ +Pull with rebase preserve of merge commits. + +Example: + +```shell +git prp +``` + +See + +You should only rebase if you know (in a sort of general sense) +what you are doing, and if you do know what you are doing, then you +would probably prefer a merge-preserving rebase as a general rule. + +Although by the time you've decided that rebasing is a good idea, +you will probably find that a history that has its own embedded +branch-and-merge-points is not necessarily the correct "final +rewritten history". + +That is, if it's appropriate to do a rebase at all, it's at least fairly +likely that the history to be rebased is itself linear, so that the +preserve-vs-flatten question is moot anyway. + +See + +While preserving merges is probably generally superior, in at least a +few ways, to discarding them when rebasing, the fact is that rebase +cannot preserve them. The only thing it can do, once some commits +have been copied to new commits, is re-perform them. This can have new +and/or different merge conflicts, vs the last time the merge was done. +You should also pay close attention to the restrictions on merge +preservation in the git rebase documentation. + +Without getting into a lot of detail, it always seems to me that most +commit graph subsets that "should be" rebased, rarely have any +internal merges. If such a graph subset has a single final merge, you +can simply strip away that merge (with git reset) before rebasing, +and re-do that single merge manually at the end. (In fact, git rebase +normally drops merge commits entirely, so you don't have to run the git +reset itself in some cases. The one where you do have to run it is when +the merge is into the branch onto which you intend to rebase. This is +where git pull actually does the right thing when it uses +`git rebase -p`, except that it fails to check for, and warn about, +internal merges, which are sort of warning signs that rebasing might +not be a good idea. diff --git a/doc/git-pruner/description.md b/doc/git-pruner/description.md new file mode 100644 index 00000000..61986097 --- /dev/null +++ b/doc/git-pruner/description.md @@ -0,0 +1,13 @@ +Prune using our recommnded way i.e. prune everything unreachable now. + +Example: + +```shell +git pruner +``` + +This command takes a long time to run, perhaps even overnight. + +This is useful for removing unreachable objects from all places. + +By [CodeGnome](http://www.codegnome.com/) diff --git a/doc/git-publish-git-unpublish/description.md b/doc/git-publish-git-unpublish/description.md new file mode 100644 index 00000000..9942543a --- /dev/null +++ b/doc/git-publish-git-unpublish/description.md @@ -0,0 +1,8 @@ +# git publish & git unpublish + +## Publish/unpublish the current branch + +Compare: + +* [git publish](../git-publish) +* [git unpublish](../git-unpublish) diff --git a/doc/git-publish/description.md b/doc/git-publish/description.md new file mode 100644 index 00000000..608db27c --- /dev/null +++ b/doc/git-publish/description.md @@ -0,0 +1,18 @@ +Publish the current branch. + +Publish the current branch by pushing upstream to origin, +and setting the current branch to track the upstream branch. + +Example: + +```shell +git publish +``` + +Compare: + +* [git publish & git unpublish](../git-publish-git-unpublish) (describes both) + +* [git publish](../git-publish) (this alias) + +* [git unpublish](../git-unpublish) diff --git a/doc/git-pull1/description.md b/doc/git-pull1/description.md new file mode 100644 index 00000000..1420e2fd --- /dev/null +++ b/doc/git-pull1/description.md @@ -0,0 +1,9 @@ +Pull just the one current branch. + +Example: + +```shell +git pull1 +``` + +Compare [git push1](../git-push1). diff --git a/doc/git-push1/description.md b/doc/git-push1/description.md new file mode 100644 index 00000000..81bfb563 --- /dev/null +++ b/doc/git-push1/description.md @@ -0,0 +1,9 @@ +Push just the one current branch. + +Example: + +```shell +git push1 +``` + +Compare [git pull1](../git-pull1). diff --git a/doc/git-pushy/description.md b/doc/git-pushy/description.md new file mode 100644 index 00000000..6c6e113d --- /dev/null +++ b/doc/git-pushy/description.md @@ -0,0 +1,14 @@ +Push with force and lease. + +Push with force and lease, which means that you're pushing in order +to forcefully overwrite the remote, and you want a safety check first: +git checks you're current with remote, and only then allows the push. + +We name this `pushy` because its dsagreeably aggressive (in general) +or overly assertive (in general), yet still better than just --force. + +Example: + +````shell +git pushy +``` diff --git a/doc/git-put/description.md b/doc/git-put/description.md new file mode 100644 index 00000000..cfd65d3e --- /dev/null +++ b/doc/git-put/description.md @@ -0,0 +1,12 @@ +Put all changes for the current branch. + +Example: + +```shell +git put +``` + +Compare: +* [git get & git put](../git-get-git-put) (describes both) +* [git get](../git-get) +* [git put](../git-put) (this alias) diff --git a/doc/git-rb/description.md b/doc/git-rb/description.md new file mode 100644 index 00000000..7114088d --- /dev/null +++ b/doc/git-rb/description.md @@ -0,0 +1,7 @@ +Short for "git rebase". + +Example: + +```shell +git rb +``` diff --git a/doc/git-rba/description.md b/doc/git-rba/description.md new file mode 100644 index 00000000..28d7eed1 --- /dev/null +++ b/doc/git-rba/description.md @@ -0,0 +1,7 @@ +Rebase abort i.e. abort the rebase process. + +Example: + +```shell +git rba +``` diff --git a/doc/git-rbc/description.md b/doc/git-rbc/description.md new file mode 100644 index 00000000..49a918da --- /dev/null +++ b/doc/git-rbc/description.md @@ -0,0 +1,9 @@ +Rebase continue i.e. continue the rebase process. + +Example: + +```shell +git rbc +``` + +Continue after resolving a conflict and updating the index. diff --git a/doc/git-rbi/description.md b/doc/git-rbi/description.md new file mode 100644 index 00000000..0f125618 --- /dev/null +++ b/doc/git-rbi/description.md @@ -0,0 +1,7 @@ +Rebase interactive i.e. do a rebase with prompts. + +Example: + +```shell +git rbi +``` diff --git a/doc/git-rbiu/description.md b/doc/git-rbiu/description.md new file mode 100644 index 00000000..ac8d251e --- /dev/null +++ b/doc/git-rbiu/description.md @@ -0,0 +1,42 @@ +Rebase interactive on unpushed commits. + +Example: + +```shell +git rbiu +``` + +Before we push our local changes, we may want to do some cleanup, +to improve our commit messages or squash related commits together. + +Let's say I've pushed two commits that are related to a new feature and +I have another where I made a spelling mistake in the commit message. + +When I run "git rbiu" I get dropped into my editor with this: + +```shell +pick 7f06d36 foo +pick ad544d0 goo +pick de3083a hoo +``` + +Let's say I want to squash the "foo" and "goo" commits together, +and also change "hoo" to say "whatever". To do these, I change "pick" +to say "s" for squash; this tells git to squash the two together; +I also edit "hoo" to rename it to "whatever". + +I make the file look like this: + +```shell +pick 7f06d36 foo +s ad544d0 goo +r de3083a whatever + +This gives me two new commit messages to edit, which I update. + +Now when I push the remote repo host receives two commits: + +```shell +3400455 - foo +5dae0a0 - whatever +``` diff --git a/doc/git-rbs/description.md b/doc/git-rbs/description.md new file mode 100644 index 00000000..7aa41326 --- /dev/null +++ b/doc/git-rbs/description.md @@ -0,0 +1,7 @@ +Rebase skip i.e. restart the rebase process by skipping the current patch. + +Example: + +```shell +git rbs +``` diff --git a/doc/git-rebase-branch/description.md b/doc/git-rebase-branch/description.md new file mode 100644 index 00000000..3ce1a245 --- /dev/null +++ b/doc/git-rebase-branch/description.md @@ -0,0 +1,7 @@ +Interactively rebase all the commits on the current branch. + +Example: + +```shell +git rebase-branch +``` diff --git a/doc/git-rebase-interactive-branch/description.md b/doc/git-rebase-interactive-branch/description.md new file mode 100644 index 00000000..eeacc863 --- /dev/null +++ b/doc/git-rebase-interactive-branch/description.md @@ -0,0 +1,7 @@ +Rebase interactive on all the commits on the current branch. + +Example: + +```shell +git rebase-interactive-branch +``` diff --git a/doc/git-rebase-recent/description.md b/doc/git-rebase-recent/description.md new file mode 100644 index 00000000..79f1f367 --- /dev/null +++ b/doc/git-rebase-recent/description.md @@ -0,0 +1,9 @@ +Rebase recent commits with interactive. + +Example: + +```shell +git rebase-recent +``` + +Thanks to jtolds on stackoverflow. diff --git a/doc/git-refs-by-date/description.md b/doc/git-refs-by-date/description.md new file mode 100644 index 00000000..15512cfe --- /dev/null +++ b/doc/git-refs-by-date/description.md @@ -0,0 +1,9 @@ +Show refs sorted by date for branches. + +Example: + +```shell +git refs-by-date +``` + +This alias can be useful for spring cleaning. diff --git a/doc/git-reincarnate/description.md b/doc/git-reincarnate/description.md new file mode 100644 index 00000000..448beb43 --- /dev/null +++ b/doc/git-reincarnate/description.md @@ -0,0 +1,14 @@ +Delete a branch then create it anew. + +Example: + +```shell +git reincarnate +``` + +This can useful if you have, for example, a development branch and +a main branch, and they are accidentally out of sync, and you want +to nuke the development branch, and start over with a fresh branch. + +This implementation calls the `publish` and `unpublish` aliases, +and uses the `main` branch name; you could/should customize these. diff --git a/doc/git-remote-ref/description.md b/doc/git-remote-ref/description.md new file mode 100644 index 00000000..7411eab8 --- /dev/null +++ b/doc/git-remote-ref/description.md @@ -0,0 +1,7 @@ +Example: + +```shell +git remote-ref +``` + +Thanks to jtolds on stackoverflow diff --git a/doc/git-remotes-prune/description.md b/doc/git-remotes-prune/description.md new file mode 100644 index 00000000..996439f2 --- /dev/null +++ b/doc/git-remotes-prune/description.md @@ -0,0 +1,12 @@ +For each remote branch, prune it. + +Example: + +```shell +git remotes-prune +``` + +There's no way to tell `git remote update` to prune stale branches, +and `git remote prune` does not currently understand `--all`. + +So this shell command gets all remotes, and for each one, prunes it. diff --git a/doc/git-remotes-push/description.md b/doc/git-remotes-push/description.md new file mode 100644 index 00000000..45da7e03 --- /dev/null +++ b/doc/git-remotes-push/description.md @@ -0,0 +1,7 @@ +For each remote branch, push it. + +Example: + +```shell +git remotes-push +``` diff --git a/doc/git-repacker/description.md b/doc/git-repacker/description.md new file mode 100644 index 00000000..b42b488b --- /dev/null +++ b/doc/git-repacker/description.md @@ -0,0 +1,36 @@ +Repack a repo using our recommended way i.e. as Linus Torvalds describes. + +Example: + +```shell +git repacker +``` + +This command takes a long time to run, perhaps even overnight. + +It does the equivalent of "git gc --aggressive" +but done *properly*, which is to do something like: + +```shell +git repack -a -d --depth=250 --window=250 +``` + +The depth setting is about how deep the delta chains can be; +make them longer for old history - it's worth the space overhead. + +The window setting is about how big an object window we want +each delta candidate to scan. + +And here, you might well want to add the "-f" flag (which is +the "drop all old deltas", since you now are actually trying +to make sure that this one actually finds good candidates. + +And then it's going to take forever and a day (ie a "do it overnight" +thing). But the end result is that everybody downstream from that +repository will get much better packs, without having to spend any effort +on it themselves. + +http://metalinguist.wordpress.com/2007/12/06/the-woes-of-git-gc-aggressive-and-how-git-deltas-work/ + +We also add the --window-memory limit of 1 gig, which helps protect +us from a window that has very large objects such as binary blobs. diff --git a/doc/git-reset-commit-hard-clean/description.md b/doc/git-reset-commit-hard-clean/description.md new file mode 100644 index 00000000..98d111a9 --- /dev/null +++ b/doc/git-reset-commit-hard-clean/description.md @@ -0,0 +1,12 @@ +Move backwards on the commit chain. + +Example: + +```shell +git reset-commit-hard-clean +``` + +See how to use this alias and related ones: + +* [git reset-*](../git-reset) +* [git undo-*](../git-undo) diff --git a/doc/git-reset-commit-hard/description.md b/doc/git-reset-commit-hard/description.md new file mode 100644 index 00000000..587cf3e6 --- /dev/null +++ b/doc/git-reset-commit-hard/description.md @@ -0,0 +1,12 @@ +Move backwards on the commit chain. + +Example: + +```shell +git reset-commit-hard +``` + +See how to use this alias and related ones: + +* [git reset-*](../git-reset) +* [git undo-*](../git-undo) diff --git a/doc/git-reset-commit/description.md b/doc/git-reset-commit/description.md new file mode 100644 index 00000000..59b7876e --- /dev/null +++ b/doc/git-reset-commit/description.md @@ -0,0 +1,12 @@ +Move backwards on the commit chain. + +Example: + +```shell +git reset-commit +``` + +See how to use this alias and related ones: + +* [git reset-*](../git-reset) +* [git undo-*](../git-undo) diff --git a/doc/git-reset-to-pristine/description.md b/doc/git-reset-to-pristine/description.md new file mode 100644 index 00000000..672c3b12 --- /dev/null +++ b/doc/git-reset-to-pristine/description.md @@ -0,0 +1,12 @@ +Reset commits and clean all differences + +Example: + +```shell +git reset-to-pristine +``` + +See how to use this alias and related ones: + +* [git reset-*](../git-reset) +* [git undo-*](../git-undo) diff --git a/doc/git-reset-to-upstream/description.md b/doc/git-reset-to-upstream/description.md new file mode 100644 index 00000000..dacba99d --- /dev/null +++ b/doc/git-reset-to-upstream/description.md @@ -0,0 +1,12 @@ +Reset commits back to the upstream branch. + +Example: + +```shell +git reset-to-upstream +``` + +See how to use this alias and related ones: + +* [git reset-*](../git-reset) +* [git undo-*](../git-undo) diff --git a/doc/git-reset/description.md b/doc/git-reset/description.md new file mode 100644 index 00000000..f77e2881 --- /dev/null +++ b/doc/git-reset/description.md @@ -0,0 +1,28 @@ +# git reset-* + +## Move backwards on the commit chain + +Git alias: + +```git +reset-commit = reset --soft HEAD~1 +reset-commit-hard = reset --hard HEAD~1 +reset-commit-hard-clean = !git reset --hard HEAD~1 && git clean -df +reset-to-pristine = !git reset --hard && git clean -dffx +reset-to-upstream = !git reset --hard $(git upstream-branch) +``` + +Example: + +```shell +git reset-commit +git reset-commit-hard +git reset-commit-hard-clean +git reset-to-pristine +git reset-to-upstrea +``` + +These aliases are intentionally identical to the [git undo-*](../git-undo) aliases. + +This is because, in our experience, novices tend to prefer the word "undo" +whereas experts tend to prefer the word "reset". diff --git a/doc/git-rev-list-all-objects-by-size-and-name/description.md b/doc/git-rev-list-all-objects-by-size-and-name/description.md new file mode 100644 index 00000000..29225eb2 --- /dev/null +++ b/doc/git-rev-list-all-objects-by-size-and-name/description.md @@ -0,0 +1,9 @@ +List all objects by size in bytes and file name. + +Example: + +```shell +git rev-list-all-objects-by-size-and-name +``` + +By [raphinesse](https://stackoverflow.com/users/380229/raphinesse) diff --git a/doc/git-rev-list-all-objects-by-size/description.md b/doc/git-rev-list-all-objects-by-size/description.md new file mode 100644 index 00000000..c51a1ce7 --- /dev/null +++ b/doc/git-rev-list-all-objects-by-size/description.md @@ -0,0 +1,9 @@ +List all blobs by size in bytes. + +Example: + +```shell +git rev-list-all-objects-by-size +``` + +By [CodeGnome](http://www.codegnome.com/) diff --git a/doc/git-rl/description.md b/doc/git-rl/description.md new file mode 100644 index 00000000..4ce83c72 --- /dev/null +++ b/doc/git-rl/description.md @@ -0,0 +1,9 @@ +Short for "git reflog". + +Example: + +```shell +git rl +``` + +Reflog is a reference log that manages when tips of branches are updated. diff --git a/doc/git-rr/description.md b/doc/git-rr/description.md new file mode 100644 index 00000000..b2fcf2c5 --- /dev/null +++ b/doc/git-rr/description.md @@ -0,0 +1,7 @@ +Short for "git remote". + +Example: + +```shell +git rr +``` diff --git a/doc/git-rrp/description.md b/doc/git-rrp/description.md new file mode 100644 index 00000000..845039ef --- /dev/null +++ b/doc/git-rrp/description.md @@ -0,0 +1,7 @@ +Remote prune i.e. delete all stale remote-tracking branches under . + +Example: + +```shell +git rrp +``` diff --git a/doc/git-rrs/description.md b/doc/git-rrs/description.md new file mode 100644 index 00000000..3d8fd4c7 --- /dev/null +++ b/doc/git-rrs/description.md @@ -0,0 +1,7 @@ +Remote show i.e. give information about the remote . + +Example: + +```shell +git rrs +``` diff --git a/doc/git-rru/description.md b/doc/git-rru/description.md new file mode 100644 index 00000000..a75c6ed1 --- /dev/null +++ b/doc/git-rru/description.md @@ -0,0 +1,7 @@ +remote update i.e. fetch updates for a named set of remotes in the repository as defined by remotes. + +Example: + +```shell +git rru +``` diff --git a/doc/git-rv/description.md b/doc/git-rv/description.md new file mode 100644 index 00000000..fca50024 --- /dev/null +++ b/doc/git-rv/description.md @@ -0,0 +1,9 @@ +Short for "git revert". + +Example: + +```shell +git rv +``` + +Revert will undo the changes from some existing commits. diff --git a/doc/git-rvnc/description.md b/doc/git-rvnc/description.md new file mode 100644 index 00000000..739641b1 --- /dev/null +++ b/doc/git-rvnc/description.md @@ -0,0 +1,10 @@ +Revert with no commit i.e. without autocommit. + +Example: + +```shell +git rvnc +``` + +This can be useful when you're reverting more than one +commits' effect to your index in a row. diff --git a/doc/git-s/description.md b/doc/git-s/description.md new file mode 100644 index 00000000..a9988983 --- /dev/null +++ b/doc/git-s/description.md @@ -0,0 +1,7 @@ +Short for "git status". + +Example: + +```shell +git s +``` diff --git a/doc/git-sb/description.md b/doc/git-sb/description.md new file mode 100644 index 00000000..72466549 --- /dev/null +++ b/doc/git-sb/description.md @@ -0,0 +1,7 @@ +Short for "git show-branch" i.e. print a list of branches and their commits. + +Example: + +```shell +git sb +``` diff --git a/doc/git-sbdo/description.md b/doc/git-sbdo/description.md new file mode 100644 index 00000000..82b73c2f --- /dev/null +++ b/doc/git-sbdo/description.md @@ -0,0 +1,7 @@ +Show branch list with date order + +Example: + +```shell +git sbdo +``` diff --git a/doc/git-sbto/description.md b/doc/git-sbto/description.md new file mode 100644 index 00000000..90c5285e --- /dev/null +++ b/doc/git-sbto/description.md @@ -0,0 +1,7 @@ +Show branch list with topological order + +Example: + +```shell +git sbto +``` diff --git a/doc/git-search-commits/description.md b/doc/git-search-commits/description.md new file mode 100644 index 00000000..03cddd1e --- /dev/null +++ b/doc/git-search-commits/description.md @@ -0,0 +1,27 @@ +Search for a given string in all patches and print commit messages. + +Example: + +```shell +git search-commits +``` + +Example: search for any commit that adds or removes string "foobar": + +```shell +git search-commits foobar +``` + +Example: search commits for string "foobar" in directory "src/lib": + +```shell +git search-commits foobar src/lib +``` + +Example: search commits for "foobar", print full diff of commit with 1 line context: + +```shell +git search-commits foobar --pickaxe-all -U1 src/lib +``` + +Posted by Mikko Rantalainen on StackOverflow. diff --git a/doc/git-serve/description.md b/doc/git-serve/description.md new file mode 100644 index 00000000..b7d3d628 --- /dev/null +++ b/doc/git-serve/description.md @@ -0,0 +1,9 @@ +Serve the local directory by starting a Git server daemon. + +Example: + +```shell +git serve +``` + +Serve the local directory by starting a git server daemon, so others can pull/push from my machine. diff --git a/doc/git-show-unreachable/description.md b/doc/git-show-unreachable/description.md new file mode 100644 index 00000000..fa0311d8 --- /dev/null +++ b/doc/git-show-unreachable/description.md @@ -0,0 +1,9 @@ +Show logs of unreachable commits. + +Example: + +```shell +git show-unreachable +``` + +This can be useful, for example, when recovering contents of dropped stashes or reset commits. diff --git a/doc/git-sm/description.md b/doc/git-sm/description.md new file mode 100644 index 00000000..bf39e7a3 --- /dev/null +++ b/doc/git-sm/description.md @@ -0,0 +1,9 @@ +Short for "git submodule". + +Example: + +```shell +git sm +``` + +Submodule enables foreign repositories to be embedded within a dedicated subdirectory of the source tree. diff --git a/doc/git-sma/description.md b/doc/git-sma/description.md new file mode 100644 index 00000000..3c0a957d --- /dev/null +++ b/doc/git-sma/description.md @@ -0,0 +1,7 @@ +Submodule add i.e. add a submodule to this repo. + +Example: + +```shell +git sma foo +``` diff --git a/doc/git-smi/description.md b/doc/git-smi/description.md new file mode 100644 index 00000000..9ff514e1 --- /dev/null +++ b/doc/git-smi/description.md @@ -0,0 +1,7 @@ +Submodule init i.e. initialize a submodule in this repo. + +Example: + +```shell +git smi foo +``` diff --git a/doc/git-sms/description.md b/doc/git-sms/description.md new file mode 100644 index 00000000..2e4206ac --- /dev/null +++ b/doc/git-sms/description.md @@ -0,0 +1,7 @@ +Submodule sync i.e. synchronize a submodule in this repo. + +Example: + +```shell +git sms foo +``` diff --git a/doc/git-smu/description.md b/doc/git-smu/description.md new file mode 100644 index 00000000..64438ea7 --- /dev/null +++ b/doc/git-smu/description.md @@ -0,0 +1,7 @@ +Submodule update i.e. update a submodule in this repo. + +Example: + +```shell +git smu foo +``` diff --git a/doc/git-smui/description.md b/doc/git-smui/description.md new file mode 100644 index 00000000..83f1f299 --- /dev/null +++ b/doc/git-smui/description.md @@ -0,0 +1,7 @@ +Submodule update with initialize. + +Example: + +```shell +git smui foo +``` diff --git a/doc/git-smuir/description.md b/doc/git-smuir/description.md new file mode 100644 index 00000000..55fe3c62 --- /dev/null +++ b/doc/git-smuir/description.md @@ -0,0 +1,9 @@ +Submodule update with initialize and recursive; this is useful to bring a submodule fully up to date. + +Example: + +```shell +git smuir foo +``` + +This can be useful to bring a submodule fully up to date. diff --git a/doc/git-snapshot/description.md b/doc/git-snapshot/description.md new file mode 100644 index 00000000..df814820 --- /dev/null +++ b/doc/git-snapshot/description.md @@ -0,0 +1,28 @@ +Take a snapshot of your current working tree. + +Example: + +```shell +git snapshot +``` + +Take a snapshot of your current working tree without removing changes. + +This is handy for refactoring where you can't quite fit what you've done +into a commit but daren't stray too far from now without a backup. + +Running this … + +```shell +git snapshot +``` + +… creates this stash: + +```shell +stash@{0}: On feature/handy-git-tricks: snapshot: Mon Apr 8 12:39:06 BST 2013 +``` + +… and seemingly no changes to your working tree. + +From diff --git a/doc/git-ss/description.md b/doc/git-ss/description.md new file mode 100644 index 00000000..0f4e741e --- /dev/null +++ b/doc/git-ss/description.md @@ -0,0 +1,7 @@ +Status with short format. + +Example: + +```shell +git ss +``` diff --git a/doc/git-ssb/description.md b/doc/git-ssb/description.md new file mode 100644 index 00000000..9e4d2274 --- /dev/null +++ b/doc/git-ssb/description.md @@ -0,0 +1,7 @@ +Status with short format and branch info. + +Example: + +```shell +git ssb +``` diff --git a/doc/git-stashes/description.md b/doc/git-stashes/description.md new file mode 100644 index 00000000..0b8a3f57 --- /dev/null +++ b/doc/git-stashes/description.md @@ -0,0 +1,17 @@ +List stashes. + +Example: + +```shell +git stashes +``` + +This alias is because friendly wording is easier to remember. + +Our friendly wording for plurals: +* [git aliases](../git-aliases) +* [git branches](../git-branches) +* [git stashes](../git-stashes) +* [git tags](../git-tags) + +Thanks to . diff --git a/doc/git-submodule/description.md b/doc/git-submodule/description.md new file mode 100644 index 00000000..8ba106b3 --- /dev/null +++ b/doc/git-submodule/description.md @@ -0,0 +1,14 @@ +# git submodule + +## Aliases related to git submodule + + +### Shortcuts + +* [git sm](git-sm) = submodule +* [git smi](git-smi) = submodule init +* [git sma](git-sma) = submodule add +* [git sms](git-sms) = submodule sync +* [git smu](git-smu) = submodule update +* [git smui](git-smui) = submodule update --init +* [git smuir](git-smuir) = submodule update --init --recursive diff --git a/doc/git-summary/description.md b/doc/git-summary/description.md new file mode 100644 index 00000000..ad316f21 --- /dev/null +++ b/doc/git-summary/description.md @@ -0,0 +1,70 @@ +Show a summary of overview metrics. + +Example: + +```shell +git summary + +Summary of this branch... +main +2016-06-17T22:05:43-04:00 first commit timestamp +2022-01-10T19:41:43+00:00 last commit timestamp + +Summary of counts... +330 commit count +112 date count +0 tag count +31 author count +22 committer count +1 local branch count +3 remote branch count + +Summary of this directory... +~gitalias/gitalias +315 file count via git ls-files +4921 file count via find command +41912 disk usage + +Most-active authors, with commit count and %... +246 74% joel@joelparkerhenderson.com +19 5% phd@phdru.name +13 3% alice@example.com + +Most-active dates, with commit count and %... +16 4% 2019-01-16 +14 4% 2016-06-19 +10 3% 2019-07-03 + +Most-active files, with churn count +211 gitalias.txt +78 README.md +4 doc/install/install.md +``` + +Summary of the branch: + + * First commit timestamp + * Last commit timestamp + +Summary of the counts: + + * Commit count + * Date count + * Tag count + * Author count + * Committer count + * Local branch count + * Remote branch count + +Summary of the directory: + + * Directory path + * File count via git ls-files + * File count via find command + * Disk usage + +Summary of activity: + + * Most-active authors + * Most-active dates + * Most-active files diff --git a/doc/git-svn-b/description.md b/doc/git-svn-b/description.md new file mode 100644 index 00000000..15750bd8 --- /dev/null +++ b/doc/git-svn-b/description.md @@ -0,0 +1,7 @@ +Subversion branch. + +Example: + +```shell +git svn-b +``` diff --git a/doc/git-svn-c/description.md b/doc/git-svn-c/description.md new file mode 100644 index 00000000..a9a22b79 --- /dev/null +++ b/doc/git-svn-c/description.md @@ -0,0 +1,7 @@ +Subversion commit. + +Example: + +```shell +git svn-c +``` diff --git a/doc/git-svn-cp/description.md b/doc/git-svn-cp/description.md new file mode 100644 index 00000000..11b47455 --- /dev/null +++ b/doc/git-svn-cp/description.md @@ -0,0 +1,7 @@ +Subversion cherry pick. + +Example: + +```shell +git svn-cp +``` diff --git a/doc/git-svn-m/description.md b/doc/git-svn-m/description.md new file mode 100644 index 00000000..e7afdbcc --- /dev/null +++ b/doc/git-svn-m/description.md @@ -0,0 +1,7 @@ +Subversion merge. + +Example: + +```shell +git svn-m +``` diff --git a/doc/git-svn/description.md b/doc/git-svn/description.md new file mode 100644 index 00000000..642572e2 --- /dev/null +++ b/doc/git-svn/description.md @@ -0,0 +1,21 @@ +# git svn-* + +## Subversion version control helpers + +Git alias: + +```git +svn-b = svn branch +svn-m = merge --squash +svn-c = svn dcommit +svn-cp = !GIT_EDITOR='sed -i /^git-svn-id:/d' git cherry-pick --edit +``` + +Example: + +```shell +git svn-b +git svn-m +git svn-c +git svn-cp +``` diff --git a/doc/git-tags/description.md b/doc/git-tags/description.md new file mode 100644 index 00000000..652de8b8 --- /dev/null +++ b/doc/git-tags/description.md @@ -0,0 +1,21 @@ +List tags. + +Example: + +```shell +git tags +``` + +This alias is because friendly wording is easier to remember. + +Our friendly wording for plurals: + +* [git aliases](../git-aliases) + +* [git branches](../git-branches) + +* [git stashes](../git-stashes) + +* [git tags](../git-tags) + +Thanks diff --git a/doc/git-theirs/description.md b/doc/git-theirs/description.md new file mode 100644 index 00000000..3485c38d --- /dev/null +++ b/doc/git-theirs/description.md @@ -0,0 +1,15 @@ +Checkout their version of a file and add it. + +Example: + +```shell +git theirs +``` + +Compare: + +* [git ours & git theirs](../git-ours-git-theirs) (describes both) + +* [git ours](../git-ours) + +* [git theirs](../git-theirs) (this alias) diff --git a/doc/git-top/description.md b/doc/git-top/description.md new file mode 100644 index 00000000..fb8b937b --- /dev/null +++ b/doc/git-top/description.md @@ -0,0 +1,8 @@ +Get the top level directory name. + +Example: + +```shell +git top +/home/alice/projects/example +``` diff --git a/doc/git-topic-base-branch/description.md b/doc/git-topic-base-branch/description.md new file mode 100644 index 00000000..c0e8f293 --- /dev/null +++ b/doc/git-topic-base-branch/description.md @@ -0,0 +1,49 @@ +Show the project base topic branch name. + +Example: + +``` +git topic-base-branch +main +``` + +Customize this alias as you like for your own workflow. + +When we do topic branches, we use a base topic branch, +and use it to create new topic branches, and also use +it to receive changes from completed topic branches. + +The base topic branch defaults to the repo default branch, +such as the "main" branch; this makes it easy to use topic +branching in many popular git repos that use the "main" branch +for trunk-based development and integration of pull requests. + +Some teams prefer to have a specific base topic branch that +is different than the repo default branch, typically in order +to do various integration tests and/or release processes. + +For example, some teams prefer to have a branch named "topic" +or "development" or "integration", in order to do continuous +integration tests and continuous delivery release processes. + +You can customize the base topic branch name by using `git config`. + +You can customize it for your local repo, or your own user's global +configuration, or your system configuration, by using `git config`: + +```shell +git config --local init.topicBaseBranchName "foo" + +git config --global init.topicBaseBranchName "foo" + +git config --system init.topicBaseBranchName "foo" +``` + +Example: + +``` +git config init.topicBaseBranchName "foo" +git topic-base-branch +foo +``` + diff --git a/doc/git-topic-begin/description.md b/doc/git-topic-begin/description.md new file mode 100644 index 00000000..655d69d3 --- /dev/null +++ b/doc/git-topic-begin/description.md @@ -0,0 +1,27 @@ +Start a new topic branch. + +Example: + +```shell +git topic-begin add-feature-foo +``` + +Customize this alias as you like for your own workflow. + +We use this alias to begin work on a new feature, +new task, new fix, new refactor, new optimization, etc. + +Our workflow does these steps: + + 1. Update the base topic branch. + + 2. Create a new topic branch based on the topic base branch name, + + 3. Push the new topic branch, so team members can see it. + +If you use a sharing site such a GitHub, and use typical settings, +then this implementation makes your branch visible to collaborators. + +Many teams share branches before they are fully ready, to help +the team provide feedback on the work-in-progress, and also to +run any automatic tests to verify the branch runs successfully. diff --git a/doc/git-topic-end/description.md b/doc/git-topic-end/description.md new file mode 100644 index 00000000..12875ccf --- /dev/null +++ b/doc/git-topic-end/description.md @@ -0,0 +1,34 @@ +Finish the current topic branch. + +Example: + +```shell +git topic-end +``` + +Customize this alias as you like for your own workflow. + +This must be the current branch. + +We use this alias to complete work on a new feature, +new task, new fix, new refactor, new optimization, etc. + +Our workflow does these steps: + + 1. Push the topic branch. + + 2. Delete the topic branch locally. + + 3. Delete the topic branch remotely. + +If you use a sharing site such a GitHub, and use typical settings, +then this implementation deletes your branch for the site. + +Many teams choose to delete topic branches when they are finished, +to keep the repositories clean and with a smaller number of branches. + +If git says "unable to push to unqualified destination" then it means +that the remote branch doesn't exist, so git is unable to delete it; +that message is typically ok because it means that someone else has +already deleted the branch. To synchronize your branch list, you can +use "git fetch --prune". diff --git a/doc/git-topic-move/description.md b/doc/git-topic-move/description.md new file mode 100644 index 00000000..5d08cc21 --- /dev/null +++ b/doc/git-topic-move/description.md @@ -0,0 +1,15 @@ +Rename the current topic branch. + +Example: + +```shell +git topic-move foo +``` + +Customize this alias as you like for your own workflow. + +Our workflow does these steps: + + 1. Move the local branch. + + 2. Move the remote branch by pushing to origin. diff --git a/doc/git-topic-sync/description.md b/doc/git-topic-sync/description.md new file mode 100644 index 00000000..2e6f821f --- /dev/null +++ b/doc/git-topic-sync/description.md @@ -0,0 +1,19 @@ +Synchronize the current topic branch by doing updates. + +Example: + +```shell +git topic-sync +``` + +Customize this alias as you like for your own workflow. + +Our workflow does these steps: + + 1. Pull any changes. + + 2. Push any changes. + +If you use any kind of testing framework, or test driven development, +then it can be wise to test your topic immediately after running this, +to ensure that any available updates are successfully integrated. diff --git a/doc/git-topic/description.md b/doc/git-topic/description.md new file mode 100644 index 00000000..f7d65a18 --- /dev/null +++ b/doc/git-topic/description.md @@ -0,0 +1,61 @@ +# git topic-* + +## Topic branch aliases + +* [git topic-base-branch](../git-topic-base-branch) + +* [git topic-begin](../git-topic-begin) + +* [git topic-end](../git-topic-end) + +* [git topic-sync](../git-topic-sync) + +* [git topic-move](../git-topic-move) + +These aliases are simple starting points for a simple topic flow. + +Lots of people have lots of ideas about how to do various git flows. + +Some people like to use a topic branch for a new feature, or a +hotfix patch, or refactoring work, or some spike research, etc. + +Show your project's topic base branch name: + +```shell +git topic-base-branch +``` + +Begin your topic work by creating a new topic branch: + +```shell +git topic-begin +``` + +End your topic work by finishing your existing topic branch: + +```shell +git topic-end +``` + +Optional: synchronize your topic work, which pushes and pulls: + +```shell +git topic-sync +``` + +Optional: move your topic branch name i.e. rename your topic branch: + +```shell +git topic-move +``` + +Ideas for your own alias customizations: + + * Notify your team, such as by sending an email, posting to chat, etc. + + * Trigger testing of the new topic branch to ensure all tests succeed. + + * Update your project management software with the new topic name. + +Customize these aliases as you like for your own workflow. + diff --git a/doc/git-track-all-remote-branches/description.md b/doc/git-track-all-remote-branches/description.md new file mode 100644 index 00000000..e86f9107 --- /dev/null +++ b/doc/git-track-all-remote-branches/description.md @@ -0,0 +1,11 @@ +Track all remote branches that aren't already being tracked. + +Example: + +```shell +git track-all-remote-branches +``` + +This alias is a bit hacky because of the parsing; +we welcome better code that works using more-specific +git commands. diff --git a/doc/git-track/description.md b/doc/git-track/description.md new file mode 100644 index 00000000..37b9c622 --- /dev/null +++ b/doc/git-track/description.md @@ -0,0 +1,9 @@ +Start tracking a branch, with default parameters, and showing the command. + +Example: + +```shell +git track +``` + +Compare [git untrack](../git-untrack). diff --git a/doc/git-unadd/description.md b/doc/git-unadd/description.md new file mode 100644 index 00000000..165aa448 --- /dev/null +++ b/doc/git-unadd/description.md @@ -0,0 +1,7 @@ +Reset something that's been added. + +Example: + +```shell +git unadd +``` diff --git a/doc/git-unassume-all/description.md b/doc/git-unassume-all/description.md new file mode 100644 index 00000000..28d9144b --- /dev/null +++ b/doc/git-unassume-all/description.md @@ -0,0 +1,9 @@ +Unassume all files. + +Example: + +```shell +git unassume-all +``` + +To see how this works, see [git assume-* & git unassume-*](../git-assume-and-git-unassume) diff --git a/doc/git-unassume/description.md b/doc/git-unassume/description.md new file mode 100644 index 00000000..1ffa3ec7 --- /dev/null +++ b/doc/git-unassume/description.md @@ -0,0 +1,9 @@ +Unassume files. + +Example: + +```shell +git unassumed +``` + +To see how this works, see [git assume-* & git unassume-*](../git-assume-and-git-unassume) diff --git a/doc/git-uncommit/description.md b/doc/git-uncommit/description.md new file mode 100644 index 00000000..919d3f7f --- /dev/null +++ b/doc/git-uncommit/description.md @@ -0,0 +1,7 @@ +Reset one commit. + +Example: + +```shell +git uncommit +``` diff --git a/doc/git-undo-commit-hard-clean/description.md b/doc/git-undo-commit-hard-clean/description.md new file mode 100644 index 00000000..414a3012 --- /dev/null +++ b/doc/git-undo-commit-hard-clean/description.md @@ -0,0 +1,12 @@ +Undo a commit with a hard reset and a clean. + +Example: + +```shell +git undo-commit-hard-clean +``` + +See how to use this alias and related ones: + +* [git undo-*](../git-undo) +* [git reset-*](../git-reset) diff --git a/doc/git-undo-commit-hard/description.md b/doc/git-undo-commit-hard/description.md new file mode 100644 index 00000000..f503b563 --- /dev/null +++ b/doc/git-undo-commit-hard/description.md @@ -0,0 +1,12 @@ +Undo a commit with a hard reset. + +Example: + +```shell +git undo-commit-hard +``` + +See how to use this alias and related ones: + +* [git undo-*](../git-undo) +* [git reset-*](../git-reset) diff --git a/doc/git-undo-commit/description.md b/doc/git-undo-commit/description.md new file mode 100644 index 00000000..858e25fc --- /dev/null +++ b/doc/git-undo-commit/description.md @@ -0,0 +1,12 @@ +Undo a commit with a soft reset. + +Example: + +```shell +git undo-commit +``` + +See how to use this alias and related ones: + +* [git undo-*](../git-undo) +* [git reset-*](../git-reset) diff --git a/doc/git-undo-to-pristine/description.md b/doc/git-undo-to-pristine/description.md new file mode 100644 index 00000000..720a39fc --- /dev/null +++ b/doc/git-undo-to-pristine/description.md @@ -0,0 +1,12 @@ +Undo commits and clean all differences. + +Example: + +```shell +git undo-to-pristine +``` + +See how to use this alias and related ones: + +* [git undo-*](../git-undo) +* [git reset-*](../git-reset) diff --git a/doc/git-undo-to-upstream/description.md b/doc/git-undo-to-upstream/description.md new file mode 100644 index 00000000..c0fe426d --- /dev/null +++ b/doc/git-undo-to-upstream/description.md @@ -0,0 +1,12 @@ +Undo commits back to the upstream branch. + +Example: + +```shell +git undo-to-upstream +``` + +See how to use this alias and related ones: + +* [git undo-*](../git-undo) +* [git reset-*](../git-reset) diff --git a/doc/git-undo/description.md b/doc/git-undo/description.md new file mode 100644 index 00000000..c6edc559 --- /dev/null +++ b/doc/git-undo/description.md @@ -0,0 +1,28 @@ +# git undo-* + +## Move backwards on the commit chain + +Git alias: + +```git +undo-commit = reset --soft HEAD~1 +undo-commit-hard = reset --hard HEAD~1 +undo-commit-hard-clean = !git reset --hard HEAD~1 && git clean -df +undo-to-pristine = !git reset --hard && git clean -dffx +undo-to-upstream = !git reset --hard $(git upstream-branch) +``` + +Example: + +```shell +git undo-commit +git undo-commit-hard +git undo-commit-hard-clean +git undo-to-pristine +git undo-to-upstream +``` + +These aliases are intentionally identical to the [git reset-*](../git-reset) aliases. + +This is because, in our experience, novices tend to prefer the word "undo" +whereas experts tend to prefer the word "reset". diff --git a/doc/git-unpublish/description.md b/doc/git-unpublish/description.md new file mode 100644 index 00000000..5c7f29d0 --- /dev/null +++ b/doc/git-unpublish/description.md @@ -0,0 +1,18 @@ +Unpublish the current branch. + +Unpublish the current branch by deleting the +remote version of the current branch. + +Example: + +```shell +git unpublish +``` + +Compare: + +* [git publish & git unpublish](../git-publish-git-unpublish) (describes both) + +* [git publish](../git-publish) + +* [git unpublish](../git-unpublish) (this alias) diff --git a/doc/git-untrack/description.md b/doc/git-untrack/description.md new file mode 100644 index 00000000..8a80e37b --- /dev/null +++ b/doc/git-untrack/description.md @@ -0,0 +1,9 @@ +Stop tracking a branch, with default parameters, and show the command. + +Example: + +```shell +git untrack +``` + +Compare [git track](../git-track). diff --git a/doc/git-unwip/description.md b/doc/git-unwip/description.md new file mode 100644 index 00000000..4e59805a --- /dev/null +++ b/doc/git-unwip/description.md @@ -0,0 +1,15 @@ +Alias for uncommit "work in progress". + +Example: + +```shell +git unwip +``` + +Compare: + +* [git wip & git unwip](../git-wip-git-unwip) (overview) + +* [git wip](../git-wip) + +* [git unwip](../git-unwip) (this alias) diff --git a/doc/git-upstream-branch/description.md b/doc/git-upstream-branch/description.md new file mode 100644 index 00000000..8dcea9f8 --- /dev/null +++ b/doc/git-upstream-branch/description.md @@ -0,0 +1,14 @@ +Get the upstream branch name. + +Example: + +```shell +git upstream-branch +origin/main +``` + +Compare: + +* [git current-branch](../git-current-branch) - Get the current branch name + +* [git upstream-branch](../git-upstream-branch) - Get the upstream branch name (this alias) diff --git a/doc/git-w/description.md b/doc/git-w/description.md new file mode 100644 index 00000000..045d323d --- /dev/null +++ b/doc/git-w/description.md @@ -0,0 +1,7 @@ +Short for "git whatchanged". + +Example: + +```shell +git w +``` diff --git a/doc/git-whatis/description.md b/doc/git-whatis/description.md new file mode 100644 index 00000000..580a27ef --- /dev/null +++ b/doc/git-whatis/description.md @@ -0,0 +1,7 @@ +Given a git object, try to show it briefly. + +Example: + +```shell +git whatis +``` diff --git a/doc/git-who/description.md b/doc/git-who/description.md new file mode 100644 index 00000000..40bc0b32 --- /dev/null +++ b/doc/git-who/description.md @@ -0,0 +1,7 @@ +Show a short log of who has contributed commits, in descending order. + +Example: + +```shell +git who +``` diff --git a/doc/git-whois/description.md b/doc/git-whois/description.md new file mode 100644 index 00000000..557195fd --- /dev/null +++ b/doc/git-whois/description.md @@ -0,0 +1,8 @@ +Given a string for an author, try to figure out full name and email. + +Example: + +```shell +git whois alice +Alice Adams +``` diff --git a/doc/git-wip-git-unwip/description.md b/doc/git-wip-git-unwip/description.md new file mode 100644 index 00000000..fc6f2928 --- /dev/null +++ b/doc/git-wip-git-unwip/description.md @@ -0,0 +1,30 @@ +# git wip & git unwip + +## Aliases for "work in progress" + + +Git alias: + +```git +wip = !"git add --all; git ls-files --deleted -z | xargs -0 git rm; git commit --message=wip" + +unwip = !"git log -n 1 | grep -q -c wip && git reset HEAD~1" +``` + +Example: + +```shell +git wip + +git unwip +``` + +The wip alias is a quick way to add all new and modified files to the index, +while also cleaning the index from the files removed from the working tree. +This cleaning will facilitate a rebase, because there won't be any conflict +due to an "unclean" working directory (not in sync with the index). + +The unwip alias is a quick way to restore deleted files to the working tree. + +From and VonC on stackoverflow. + diff --git a/doc/git-wip/description.md b/doc/git-wip/description.md new file mode 100644 index 00000000..23027c88 --- /dev/null +++ b/doc/git-wip/description.md @@ -0,0 +1,15 @@ +Alias for commit "work in progress". + +Example: + +```shell +git wip +``` + +Compare: + +* [git wip & git unwip](../git-wip-git-unwip) (overview) + +* [git wip](../git-wip) (this alias) + +* [git unwip](../git-unwip)