Skip to content

Instantly share code, notes, and snippets.

Created October 29, 2008 20:26
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save anonymous/20818 to your computer and use it in GitHub Desktop.
Save anonymous/20818 to your computer and use it in GitHub Desktop.
GIT command line revamp
=======================
This design document is designed for review and critique over planned
direction for changing the command set used by git, rather than
reviewing and critiquing individual changes.
In general, old commands will be grandfathered for a year or longer,
and all plumbing commands will still work as originally designed.
Please bear in mind when critiquing that each of these changes might
themselves have a progressive implementation, for instance the new
behaviour being optional initially.
Please try to be positive with your comments; let's try to come up
with solutions and not argue about the details of the solutions
presented until those details are submitted. In particular, critical
comments that do not acknowledge the presence of a problem are
worthless at this stage.
Add/rm/reset/checkout/revert
----------------------------
Many find these confusing.
* 'git stage' would do what 'git add' does now.
* 'git unstage' would do what 'git reset --' does now
* 'git status' would encourage the user to use
'git diff --staged' to see staged changes as a patch
* 'git commit' with no changes should give useful information about
using 'git stage', 'git commit -a' or 'git commit filename ...'
* 'git add' and 'git rm': no change
* 'git update-index' considered plumbing, not changed
* 'git revert' deprecated in favour of 'git cherry-pick --revert'
* 'git undo' would do what 'git checkout HEAD --' does now
* 'git checkout branch' would, if there is a remote branch called
'branch' on exactly one remote, do what
'git checkout -b branch thatremote/branch' does now. If it is
ambiguous, it would be an error, forcing the explicit notation.
* 'git branch --switch' : alternative to checkout
Push/pull
---------
These commands are asymmetric, and this seems mostly historical.
* 'git push --matching' does what 'git push' does today (without
explicit configuration)
* 'git push' does what
'git push origin $(git symbolic-ref HEAD | sed "s!refs/heads/!!")'
does today. ie, it only pushes the current branch.
* 'git pull' behaviour unchanged
* 'git push' to checked out branch of non-bare repository not
allowed without special configuration. Configuration available
that allows working directory to be updated, known caveats
notwithstanding. Ideally, it would refuse only in situations
where a broken working copy would be left (because you couldn't
fix it), and work when it can be known to be safe.
Informational
-------------
* 'git branch' should default to '--color=auto -v'
* 'git tag -l' should show more information
Working with patches
--------------------
* 'git send-email' should prompt for all SMTP-related information
about sending e-mail when it is running with no configuration.
Because these days /usr/lib/sendmail is rarely configured
correctly.
* other git send-email functionality which has bitten people -
particularly building the recipient list - should prompt for
confirmation until configured to be automatic.
* 'git am -3' the default; with global option to make it not the
default for those that prefer the speed of -2
Submodules
----------
* submodules should be able to refer to symbolic ref names, svn
style - in the .gitmodules file. The actual commit used is still
recorded in the index.
* when switching branches, if the checked out revision of a submodule
changes, then it should be switched as well
* 'git submodule update' should be able to be triggered when
switching branches (but not be the default behaviour)
Others
------
* 'git export' command that does what
'git archive -–format=tar –-prefix=dir | tar x' does now
* conflicted merges should point the user immediately to
'git mergetool' and mention you need to use 'git stage' to mark
resolved files and 'git commit' when done.
* 'git init --server' (or similar) should do everything required for
exporting::
----
chmod -R a+rX
touch git-daemon-export-ok
git gc
git update-server-info
chmod u+x .git/hooks/post-update
git config core.sharedrepository=1
----
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment