summaryrefslogtreecommitdiff
path: root/git-resolve-script
Commit message (Collapse)AuthorAgeFilesLines
* Add "git-sh-setup-script" for common git shell script setupLinus Torvalds2005-07-081-9/+5
| | | | | | | | | | It sets up the normal git environment variables and a few helper functions (currently just "die()"), and returns ok if it all looks like a git archive. So use it something like . git-sh-setup-script || die "Not a git archive" to make the rest of the git scripts more careful and readable.
* Clean up different special *HEAD handlingLinus Torvalds2005-06-211-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | We codify the following different heads (in addition to the main "HEAD", which points to the current branch, of course): - FETCH_HEAD Populated by "git fetch" - ORIG_HEAD The old HEAD before a "git pull/resolve" (successful or not) - LAST_MERGE The HEAD we're currently merging in "git pull/resolve" - MERGE_HEAD The previous head of a unresolved "git pull", which gets committed by a "git commit" after manually resolving the result We used to have "MERGE_HEAD" be populated directly by the fetch, and we removed ORIG_HEAD and LAST_MERGE too aggressively.
* [PATCH] git-resolve-script: Add LAST_MERGE and use git-rev-parseDan Holmsand2005-06-201-9/+15
| | | | | | | | | | | Make git-resolve-script only write MERGE_HEAD if a merge actually occurred. All merge failures leave ORIG_HEAD and LAST_MERGE behind (instead of ORIG_HEAD and MERGE_HEAD). Use git-rev-parse to expand arguments (and check for bad ones). Signed-off-by: Dan Holmsand <holmsand@gmail.com> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
* Clean up MERGE_HEAD and ORIG_HEAD also for the trivial fast-forward merges.Linus Torvalds2005-06-191-1/+3
| | | | Otherwise you'll be bitten by a stale MERGE_HEAD like Jeff was..
* Trivial git script fixupsLinus Torvalds2005-06-141-0/+0
| | | | | | | Fix permissions, and add trivial "reset" and "add" scripts. The "reset" script just resets the index back to head, while the "add" script is just a crutch for people used to do "cvs add".
* Make "git commit" work correctly in the presense of a manual mergeLinus Torvalds2005-06-081-1/+2
| | | | | | This has gotten only very light testing, but something like this is clearly necessary and did the right thing for the one case I threw at it.
* Make default merge messages denser.Linus Torvalds2005-06-081-2/+1
| | | | | In particular, make them readable on one line since that's what all the tools like git-shortlog and gitk end up showing.
* git-resolve-script: stop when the automated merge failsLinus Torvalds2005-06-061-1/+5
| | | | | No point in doing a tree write that will just throw confusing messages on the screen.
* git-resolve-script: don't wait for three seconds any moreLinus Torvalds2005-06-061-3/+0
| | | | | We used to overwrite peoples dirty state. We don't any more. So don't print the scary message and don't delay, just do the update already.
* More work on merging with git-read-tree..Linus Torvalds2005-06-051-4/+2
| | | | | | | | | Add a "-u" flag to update the tree as a result of a merge. Right now this code is way too anal about things, and fails merges it shouldn't, but let me fix up the different cases and this will allow for much smoother merging even in the presense of dirty data in the working tree.
* git-read-tree: be a lot more careful about merging dirty treesLinus Torvalds2005-06-051-2/+3
| | | | | | | | We don't want to overwrite state that we haven't committed yet when merging, so it's better to make git-read-tree fail than end up with a merge tree that ends up not having the dirty changes. Update git-resolve-script to fail cleanly when git-read-tree fails.
* git-resolve-script: use "git-apply --stat" instead of diffstatLinus Torvalds2005-05-301-2/+2
| | | | Not everybody necessarily even has diffstat installed.
* [PATCH] optimize git-resolve-scriptJeff Garzik2005-05-251-2/+2
| | | | | This change was suggested for my git-switch-tree script, and the same issues apply to core git's git-resolve-script as well.
* Introduce GIT_DIR environment variable.Junio C Hamano2005-05-091-5/+10
| | | | | | | | | | | | | | | | | | During the mailing list discussion on renaming GIT_ environment variables, people felt that having one environment that lets the user (or Porcelain) specify both SHA1_FILE_DIRECTORY (now GIT_OBJECT_DIRECTORY) and GIT_INDEX_FILE for the default layout would be handy. This change introduces GIT_DIR environment variable, from which the defaults for GIT_INDEX_FILE and GIT_OBJECT_DIRECTORY are derived. When GIT_DIR is not defined, it defaults to ".git". GIT_INDEX_FILE defaults to "$GIT_DIR/index" and GIT_OBJECT_DIRECTORY defaults to "$GIT_DIR/objects". Special thanks for ideas and discussions go to Petr Baudis and Daniel Barkalow. Bugs are mine ;-) Signed-off-by: Junio C Hamano <junkio@cox.net>
* Fix git-resolve-script.Linus Torvalds2005-05-051-1/+1
| | | | | | I'd stupidly forgotten one merge_head -> merge conversion, and all my tests were for the fast-forward case that never triggered the bug.
* Split "git-pull-script" into two partsLinus Torvalds2005-05-051-0/+56
Separate out the merge resolve from the actual getting of the data. Also, update the resolve phase to take advantage of the fact that we don't need to do the commit->tree object lookup by hand, since all the actors involved happily just act on a commit object these days.