|
|
|
GIT-CFLAGS
|
|
|
|
GIT-VERSION-FILE
|
|
|
|
git
|
|
|
|
git-add
|
git-add --interactive
A script to be driven when the user says "git add --interactive"
is introduced.
When it is run, first it runs its internal 'status' command to
show the current status, and then goes into its internactive
command loop.
The command loop shows the list of subcommands available, and
gives a prompt "What now> ". In general, when the prompt ends
with a single '>', you can pick only one of the choices given
and type return, like this:
*** Commands ***
1: status 2: update 3: revert 4: add untracked
5: patch 6: diff 7: quit 8: help
What now> 1
You also could say "s" or "sta" or "status" above as long as the
choice is unique.
The main command loop has 6 subcommands (plus help and quit).
* 'status' shows the change between HEAD and index (i.e. what
will be committed if you say "git commit"), and between index
and working tree files (i.e. what you could stage further
before "git commit" using "git-add") for each path. A sample
output looks like this:
staged unstaged path
1: binary nothing foo.png
2: +403/-35 +1/-1 git-add--interactive.perl
It shows that foo.png has differences from HEAD (but that is
binary so line count cannot be shown) and there is no
difference between indexed copy and the working tree
version (if the working tree version were also different,
'binary' would have been shown in place of 'nothing'). The
other file, git-add--interactive.perl, has 403 lines added
and 35 lines deleted if you commit what is in the index, but
working tree file has further modifications (one addition and
one deletion).
* 'update' shows the status information and gives prompt
"Update>>". When the prompt ends with double '>>', you can
make more than one selection, concatenated with whitespace or
comma. Also you can say ranges. E.g. "2-5 7,9" to choose
2,3,4,5,7,9 from the list. You can say '*' to choose
everything.
What you chose are then highlighted with '*', like this:
staged unstaged path
1: binary nothing foo.png
* 2: +403/-35 +1/-1 git-add--interactive.perl
To remove selection, prefix the input with - like this:
Update>> -2
After making the selection, answer with an empty line to
stage the contents of working tree files for selected paths
in the index.
* 'revert' has a very similar UI to 'update', and the staged
information for selected paths are reverted to that of the
HEAD version. Reverting new paths makes them untracked.
* 'add untracked' has a very similar UI to 'update' and
'revert', and lets you add untracked paths to the index.
* 'patch' lets you choose one path out of 'status' like
selection. After choosing the path, it presents diff between
the index and the working tree file and asks you if you want
to stage the change of each hunk. You can say:
y - add the change from that hunk to index
n - do not add the change from that hunk to index
a - add the change from that hunk and all the rest to index
d - do not the change from that hunk nor any of the rest to index
j - do not decide on this hunk now, and view the next
undecided hunk
J - do not decide on this hunk now, and view the next hunk
k - do not decide on this hunk now, and view the previous
undecided hunk
K - do not decide on this hunk now, and view the previous hunk
After deciding the fate for all hunks, if there is any hunk
that was chosen, the index is updated with the selected hunks.
* 'diff' lets you review what will be committed (i.e. between
HEAD and index).
This is still rough, but does everything except a few things I
think are needed.
* 'patch' should be able to allow splitting a hunk into
multiple hunks.
* 'patch' does not adjust the line offsets @@ -k,l +m,n @@
in the hunk header. This does not have major problem in
practice, but it _should_ do the adjustment.
* It does not have any explicit support for a merge in
progress; it may not work at all.
Signed-off-by: Junio C Hamano <junkio@cox.net>
18 years ago
|
|
|
git-add--interactive
|
|
|
|
git-am
|
|
|
|
git-annotate
|
|
|
|
git-apply
|
|
|
|
git-applymbox
|
|
|
|
git-applypatch
|
|
|
|
git-archimport
|
Add git-archive
git-archive is a command to make TAR and ZIP archives of a git tree.
It helps prevent a proliferation of git-{format}-tree commands.
Instead of directly calling git-{tar,zip}-tree command, it defines
a very simple API, that archiver should implement and register in
"git-archive.c". This API is made up by 2 functions whose prototype
is defined in "archive.h" file.
- The first one is used to parse 'extra' parameters which have
signification only for the specific archiver. That would allow
different archive backends to have different kind of options.
- The second one is used to ask to an archive backend to build
the archive given some already resolved parameters.
The main reason for making this API is to avoid using
git-{tar,zip}-tree commands, hence making them useless. Maybe it's
time for them to die ?
It also implements remote operations by defining a very simple
protocol: it first sends the name of the specific uploader followed
the repository name (git-upload-tar git://example.org/repo.git).
Then it sends options. It's done by sending a sequence of one
argument per packet, with prefix "argument ", followed by a flush.
The remote protocol is implemented in "git-archive.c" for client
side and is triggered by "--remote=<repo>" option. For example,
to fetch a TAR archive in a remote repo, you can issue:
$ git archive --format=tar --remote=git://xxx/yyy/zzz.git HEAD
We choose to not make a new command "git-fetch-archive" for example,
avoind one more GIT command which should be nice for users (less
commands to remember, keeps existing --remote option).
Signed-off-by: Franck Bui-Huu <vagabon.xyz@gmail.com>
Acked-by: Rene Scharfe <rene.scharfe@lsrfire.ath.cx>
Signed-off-by: Junio C Hamano <junkio@cox.net>
19 years ago
|
|
|
git-archive
|
|
|
|
git-bisect
|
|
|
|
git-blame
|
|
|
|
git-branch
|
|
|
|
git-cat-file
|
|
|
|
git-check-ref-format
|
|
|
|
git-checkout
|
|
|
|
git-checkout-index
|
|
|
|
git-cherry
|
|
|
|
git-cherry-pick
|
|
|
|
git-clean
|
|
|
|
git-clone
|
|
|
|
git-commit
|
|
|
|
git-commit-tree
|
|
|
|
git-config
|
|
|
|
git-convert-objects
|
|
|
|
git-count-objects
|
|
|
|
git-cvsexportcommit
|
|
|
|
git-cvsimport
|
|
|
|
git-cvsserver
|
|
|
|
git-daemon
|
|
|
|
git-diff
|
|
|
|
git-diff-files
|
|
|
|
git-diff-index
|
|
|
|
git-diff-tree
|
|
|
|
git-describe
|
|
|
|
git-fast-import
|
|
|
|
git-fetch
|
|
|
|
git-fetch-pack
|
|
|
|
git-findtags
|
|
|
|
git-fmt-merge-msg
|
|
|
|
git-for-each-ref
|
|
|
|
git-format-patch
|
|
|
|
git-fsck
|
|
|
|
git-fsck-objects
|
|
|
|
git-gc
|
|
|
|
git-get-tar-commit-id
|
|
|
|
git-grep
|
|
|
|
git-hash-object
|
|
|
|
git-http-fetch
|
|
|
|
git-http-push
|
|
|
|
git-imap-send
|
|
|
|
git-index-pack
|
|
|
|
git-init
|
|
|
|
git-init-db
|
|
|
|
git-instaweb
|
|
|
|
git-local-fetch
|
|
|
|
git-log
|
|
|
|
git-lost-found
|
|
|
|
git-ls-files
|
|
|
|
git-ls-remote
|
|
|
|
git-ls-tree
|
|
|
|
git-mailinfo
|
|
|
|
git-mailsplit
|
|
|
|
git-merge
|
|
|
|
git-merge-base
|
|
|
|
git-merge-index
|
|
|
|
git-merge-file
|
|
|
|
git-merge-tree
|
|
|
|
git-merge-octopus
|
|
|
|
git-merge-one-file
|
|
|
|
git-merge-ours
|
|
|
|
git-merge-recursive
|
|
|
|
git-merge-resolve
|
|
|
|
git-merge-stupid
|
|
|
|
git-mktag
|
|
|
|
git-mktree
|
|
|
|
git-name-rev
|
|
|
|
git-mv
|
|
|
|
git-pack-redundant
|
|
|
|
git-pack-objects
|
|
|
|
git-pack-refs
|
|
|
|
git-parse-remote
|
|
|
|
git-patch-id
|
|
|
|
git-peek-remote
|
|
|
|
git-prune
|
|
|
|
git-prune-packed
|
|
|
|
git-pull
|
|
|
|
git-push
|
|
|
|
git-quiltimport
|
|
|
|
git-read-tree
|
|
|
|
git-rebase
|
|
|
|
git-receive-pack
|
|
|
|
git-reflog
|
|
|
|
git-relink
|
|
|
|
git-remote
|
|
|
|
git-repack
|
|
|
|
git-repo-config
|
|
|
|
git-request-pull
|
|
|
|
git-rerere
|
|
|
|
git-reset
|
|
|
|
git-rev-list
|
|
|
|
git-rev-parse
|
|
|
|
git-revert
|
|
|
|
git-rm
|
|
|
|
git-runstatus
|
|
|
|
git-send-email
|
|
|
|
git-send-pack
|
|
|
|
git-sh-setup
|
|
|
|
git-shell
|
|
|
|
git-shortlog
|
|
|
|
git-show
|
|
|
|
git-show-branch
|
|
|
|
git-show-index
|
|
|
|
git-show-ref
|
|
|
|
git-ssh-fetch
|
|
|
|
git-ssh-pull
|
|
|
|
git-ssh-push
|
|
|
|
git-ssh-upload
|
|
|
|
git-status
|
|
|
|
git-stripspace
|
|
|
|
git-svn
|
|
|
|
git-svnimport
|
|
|
|
git-symbolic-ref
|
|
|
|
git-tag
|
|
|
|
git-tar-tree
|
|
|
|
git-unpack-file
|
|
|
|
git-unpack-objects
|
|
|
|
git-update-index
|
|
|
|
git-update-ref
|
|
|
|
git-update-server-info
|
|
|
|
git-upload-archive
|
|
|
|
git-upload-pack
|
|
|
|
git-var
|
|
|
|
git-verify-pack
|
|
|
|
git-verify-tag
|
|
|
|
git-whatchanged
|
|
|
|
git-write-tree
|
|
|
|
git-core-*/?*
|
|
|
|
gitweb/gitweb.cgi
|
|
|
|
test-date
|
|
|
|
test-delta
|
|
|
|
test-dump-cache-tree
|
|
|
|
common-cmds.h
|
|
|
|
*.tar.gz
|
|
|
|
*.dsc
|
|
|
|
*.deb
|
|
|
|
git-core.spec
|
|
|
|
*.exe
|
|
|
|
*.[ao]
|
|
|
|
*.py[co]
|
|
|
|
config.mak
|
|
|
|
autom4te.cache
|
|
|
|
config.cache
|
|
|
|
config.log
|
|
|
|
config.status
|
|
|
|
config.mak.autogen
|
|
|
|
config.mak.append
|
|
|
|
configure
|