summaryrefslogtreecommitdiff
path: root/git-pull-script
Commit message (Collapse)AuthorAgeFilesLines
* Big tool rename.Junio C Hamano2005-09-071-44/+0
| | | | | | | | | | | | | | | | | | | As promised, this is the "big tool rename" patch. The primary differences since 0.99.6 are: (1) git-*-script are no more. The commands installed do not have any such suffix so users do not have to remember if something is implemented as a shell script or not. (2) Many command names with 'cache' in them are renamed with 'index' if that is what they mean. There are backward compatibility symblic links so that you and Porcelains can keep using the old names, but the backward compatibility support is expected to be removed in the near future. Signed-off-by: Junio C Hamano <junkio@cox.net>
* Fix pulling into the same branch.Junio C Hamano2005-08-261-1/+19
| | | | | | | | | | | | | | | | | | | | | When the "git pull" command updates the branch head you are currently on, before doing anything else, first update your index file and the working tree contents to that of the new branch head. Otherwise, the later resolving steps would think your index file is attempting to revert the change between the original head commit and the updated head commit. It uses two-tree fast-forward form of "read-tree -m -u" to prevent losing whatever local changes you may have in the working tree to do this update. I think this would at least make things safer (a lot safer), and prevent mistakes. Also "git fetch" command is forbidden from fetching and fast forwarding the current branch head unless --update-head-ok flag is given. "git pull" passes the flag when it internally calls "git fetch". Signed-off-by: Junio C Hamano <junkio@cox.net>
* [PATCH] Use git-octopus when pulling more than one heads.Junio C Hamano2005-08-241-2/+12
| | | | | | With this, you can finally say "git pull jgarzik sil24 pdc2027x". Signed-off-by: Junio C Hamano <junkio@cox.net>
* [PATCH] Retire git-parse-remote.Junio C Hamano2005-08-241-5/+9
| | | | | | | | | | | Update git-pull to match updated git-fetch and allow pull to fetch from multiple remote references. There is no support for resolving more than two heads, which will be done with "git octopus". Update "git ls-remote" to use git-parse-remote-script. Signed-off-by: Junio C Hamano <junkio@cox.net>
* [PATCH] fetch/pull: short-hand notation for remote repositories.Junio C Hamano2005-07-161-16/+3
| | | | | | | | | | | | | | | | Since pull and fetch are done often against the same remote repository repeatedly, keeping the URL to pull from along with the name of the head to use in $GIT_DIR/branches/$name makes a lot of sense. Adopt that convention from Cogito, and try to be compatible when possible; storing a partial URL and completing it with a trailing path may not be understood by Cogito. While we are at it, fix pulling a tag. Earlier, we updated only refs/tags/$tag without updating FETCH_HEAD, and called resolve-script using a stale (or absent) FETCH_HEAD. Signed-off-by: Junio C Hamano <junkio@cox.net> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
* Make "git resolve" take the merge message in $3Linus Torvalds2005-07-081-1/+1
| | | | | | | It used to do "Merge $3" as the message, but that ends up being inconvenient, and much more easily done inside git-pull-script instead. This makes the third argument to "git resolve" much easier to explain.
* Add "git-sh-setup-script" for common git shell script setupLinus Torvalds2005-07-081-3/+2
| | | | | | | | | | 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.
* Duh. Fix transposed characters in git-pull-scriptLinus Torvalds2005-06-281-1/+1
| | | | I'd stupidly only tested the non-branch-name version.
* Teach git-pull-script about pulling tagsLinus Torvalds2005-06-271-2/+7
|
* Clean up different special *HEAD handlingLinus Torvalds2005-06-211-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | 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.
* Make default merge messages denser.Linus Torvalds2005-06-081-3/+1
| | | | | In particular, make them readable on one line since that's what all the tools like git-shortlog and gitk end up showing.
* Make fetch/pull scripts terminate cleanly on errorsLinus Torvalds2005-06-061-1/+1
| | | | Don't continue with a merge if the fetch failed.
* git-pull-script: pretty-print the merge head informationLinus Torvalds2005-05-251-3/+12
| | | | | | This also drops the common ".git" part from the end of the repo name, and if a non-default head reference is given, makes a nicer commit message about it.
* Split up git-pull-script into separate "fetch" and "merge" phases.Linus Torvalds2005-05-221-33/+1
| | | | | This allows you to just fetch stuff first, inspect it, and then resolve the merge separately if everything looks good.
* Introduce GIT_DIR environment variable.Junio C Hamano2005-05-091-5/+11
| | | | | | | | | | | | | | | | | | 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>
* Add http and local transport support for git-pull-script.Junio C Hamano2005-05-061-6/+31
| | | | Signed-off-by: Junio C Hamano <junkio@cox.net>
* Split "git-pull-script" into two partsLinus Torvalds2005-05-051-45/+1
| | | | | | | | 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.
* git-pull-script: do the diffstat also for the fast-forward caseLinus Torvalds2005-05-051-0/+1
| | | | This way you always see what the state change was.
* Teach "git-pull-script" about alternate HEAD's to pull..Linus Torvalds2005-05-041-2/+3
| | | | People are already starting to use a multi-head model.
* git-pull-script: add a final "diffstat" to show the result of the merge.Linus Torvalds2005-05-041-0/+1
| | | | This is useful to verify that you got the right thing.
* Update the merge scripts for the big git rename.Linus Torvalds2005-04-291-11/+11
| | | | | Let's see what else I forgot..
* [PATCH] GIT: Honour SHA1_FILE_DIRECTORY env var in git-pull-scriptRene Scharfe2005-04-291-1/+1
| | | | | | | | | | | | | If you set SHA1_FILE_DIRECTORY to something else than .git/objects git-pull-script will store the fetched files in a location the rest of the tools does not expect. git-prune-script also ignores this setting, but I think this is good, because pruning a shared tree to fit a single project means throwing away a lot of useful data. :-) Signed-off-by: Rene Scharfe <rene.scharfe@lsrfire.ath.cx> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
* git-pull-script: do automatic mergesLinus Torvalds2005-04-261-3/+11
| | | | | | | | When the trivial "read-tree" merge fails, fall back on the (equally trivial) automatic merge script instead of forcing the user to do it by hand. When _that_ fails, you get to do a manual merge.
* Update "git-pull-script" to use "read-tree -m" forLinus Torvalds2005-04-191-2/+2
| | | | | | | | | reading a single tree too. That should speed up a trivial merge noticeably. Also, don't bother reading back the tree we just wrote when we committed a real merge. It had better be the same one we still have..
* Make git-pull-script do the right thing for symlinked HEAD's.Linus Torvalds2005-04-191-1/+3
| | | | | Also exit gracefully if the HEAD pull failed, rather than use a possibly stale MERGE_HEAD.
* [PATCH] Do not let rsync obliterate .git/object symbolic link.Junio C Hamano2005-04-181-1/+1
| | | | | Signed-off-by: Junio C Hamano <junkio@cox.net> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
* Add "update-cache --refresh" to git-pull-script to make sureLinus Torvalds2005-04-181-2/+2
| | | | | | out index is all ready to go after a pull. Noted by Russell King
* Add the simple scripts I used to do a merge with content conflicts.Linus Torvalds2005-04-181-0/+46
They sure as hell aren't perfect, but they allow you to do: ./git-pull-script {other-git-directory} to do the initial merge, and if that had content clashes, you do merge-cache ./git-merge-one-file-script -a which tries to auto-merge. When/if the auto-merge fails, it will leave the last file in your working directory, and you can edit it and then when you're happy you can do "update-cache filename" on it. Re-do the merge-cache thing until there are no files left to be merged, and now you can write the tree and commit: write-tree commit-tree .... -p $(cat .git/HEAD) -p $(cat .git/MERGE_HEAD) and you're done.