* git push refspec problem @ 2007-11-07 15:01 James 2007-11-07 15:11 ` Johannes Schindelin 0 siblings, 1 reply; 10+ messages in thread From: James @ 2007-11-07 15:01 UTC (permalink / raw) To: git Hi, I'm trying to set up my git configuration file in one of my projects so that I can do a simple "git push" to update my project on the git server. Currently, I run the following command to push my updates (and it works just fine): git push james@my.server.com:~/scm/git/project.git/ In my .git/config file, I've added a line for push, as follows: [remote "origin"] url = git://my.server.com/project.git fetch = +refs/heads/*:refs/remotes/origin/* push = ssh://james@my.server.com/home/james/scm/git/ project.git/ When I run a "git push", it comes back with this error: fatal: remote part of refspec is not a valid name in ssh://james@my.server.com/home/james/scm/git/project.git/ I've looked at this git push documentation: http://www.kernel.org/pub/software/scm/git/docs/git-push.html and it seems like my refspec is indeed correct. (or so I thought ;)) Any ideas on what I'm doing wrong? Thanks! .james ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: git push refspec problem 2007-11-07 15:01 git push refspec problem James @ 2007-11-07 15:11 ` Johannes Schindelin 2007-11-07 15:20 ` Pierre Habouzit 2007-11-07 15:22 ` Johannes Gilger 0 siblings, 2 replies; 10+ messages in thread From: Johannes Schindelin @ 2007-11-07 15:11 UTC (permalink / raw) To: James; +Cc: git Hi, On Wed, 7 Nov 2007, James wrote: > fetch = +refs/heads/*:refs/remotes/origin/* This is a refspec. > push = ssh://james@my.server.com/home/james/scm/git/project.git/ This is a URL. It does not specify any refs. But "push =" expects a URL. You probably want to setup a different remote if you want to push to a different URL than you are fetching from. Hth, Dscho ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: git push refspec problem 2007-11-07 15:11 ` Johannes Schindelin @ 2007-11-07 15:20 ` Pierre Habouzit 2007-11-07 15:23 ` James 2007-11-07 15:22 ` Johannes Gilger 1 sibling, 1 reply; 10+ messages in thread From: Pierre Habouzit @ 2007-11-07 15:20 UTC (permalink / raw) To: Johannes Schindelin; +Cc: James, git [-- Attachment #1: Type: text/plain, Size: 853 bytes --] On Wed, Nov 07, 2007 at 03:11:46PM +0000, Johannes Schindelin wrote: > Hi, > > On Wed, 7 Nov 2007, James wrote: > > > fetch = +refs/heads/*:refs/remotes/origin/* > > This is a refspec. > > > push = ssh://james@my.server.com/home/james/scm/git/project.git/ > > This is a URL. It does not specify any refs. But "push =" expects a URL. > > You probably want to setup a different remote if you want to push to a > different URL than you are fetching from. Oh, there is no way to pull through git:// and push to ssh:// perfectly knowint it's the same physical repository so that the fetch doesn't have the ssh-handhshake-overhead ? -- ·O· Pierre Habouzit ··O madcoder@debian.org OOO http://www.madism.org [-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --] ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: git push refspec problem 2007-11-07 15:20 ` Pierre Habouzit @ 2007-11-07 15:23 ` James 2007-11-07 15:26 ` Johannes Gilger 0 siblings, 1 reply; 10+ messages in thread From: James @ 2007-11-07 15:23 UTC (permalink / raw) To: Pierre Habouzit; +Cc: Johannes Schindelin, git On Nov 7, 2007, at 10:20 AM, Pierre Habouzit wrote: > On Wed, Nov 07, 2007 at 03:11:46PM +0000, Johannes Schindelin wrote: >> Hi, >> >> On Wed, 7 Nov 2007, James wrote: >> >>> fetch = +refs/heads/*:refs/remotes/origin/* >> >> This is a refspec. >> >>> push = ssh://james@my.server.com/home/james/scm/git/project.git/ >> >> This is a URL. It does not specify any refs. But "push =" expects >> a URL. >> >> You probably want to setup a different remote if you want to push >> to a >> different URL than you are fetching from. > > Oh, there is no way to pull through git:// and push to ssh:// > perfectly knowint it's the same physical repository so that the fetch > doesn't have the ssh-handhshake-overhead ? There has to be *some* way of pulling through git and pushing through ssh with a simple "git push". :-P I'm doing it manually, after all. I could have sworn I've read how to do its somewhere but have since forgotten. > -- > ·O· Pierre Habouzit > ··O madcoder@debian.org > OOO http://www.madism.org ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: git push refspec problem 2007-11-07 15:23 ` James @ 2007-11-07 15:26 ` Johannes Gilger 2007-11-07 15:38 ` Pierre Habouzit 0 siblings, 1 reply; 10+ messages in thread From: Johannes Gilger @ 2007-11-07 15:26 UTC (permalink / raw) To: James; +Cc: Pierre Habouzit, Johannes Schindelin, git James wrote: > There has to be *some* way of pulling through git and pushing through > ssh with a simple "git push". :-P I'm doing it manually, after all. I > could have sworn I've read how to do its somewhere but have since > forgotten. Would two remotes do the trick? One remote only has a fetch entry while the other one has a push entry. Regards, Jojo -- Johannes Gilger <heipei@hackvalue.de> http://hackvalue.de/heipei/ GPG-Key: 0x42F6DE81 GPG-Fingerprint: BB49 F967 775E BB52 3A81 882C 58EE B178 42F6 DE81 ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: git push refspec problem 2007-11-07 15:26 ` Johannes Gilger @ 2007-11-07 15:38 ` Pierre Habouzit 0 siblings, 0 replies; 10+ messages in thread From: Pierre Habouzit @ 2007-11-07 15:38 UTC (permalink / raw) To: Johannes Gilger; +Cc: James, Johannes Schindelin, git [-- Attachment #1: Type: text/plain, Size: 751 bytes --] On Wed, Nov 07, 2007 at 03:26:16PM +0000, Johannes Gilger wrote: > James wrote: > > There has to be *some* way of pulling through git and pushing through > > ssh with a simple "git push". :-P I'm doing it manually, after all. I > > could have sworn I've read how to do its somewhere but have since > > forgotten. > > Would two remotes do the trick? One remote only has a fetch entry > while the other one has a push entry. Yes you can do that, but that means you have to spell out the remote name either for fetching or pushing which somehow sucks :) -- ·O· Pierre Habouzit ··O madcoder@debian.org OOO http://www.madism.org [-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --] ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: git push refspec problem 2007-11-07 15:11 ` Johannes Schindelin 2007-11-07 15:20 ` Pierre Habouzit @ 2007-11-07 15:22 ` Johannes Gilger 2007-11-07 15:30 ` James 2007-11-07 15:39 ` Johannes Schindelin 1 sibling, 2 replies; 10+ messages in thread From: Johannes Gilger @ 2007-11-07 15:22 UTC (permalink / raw) To: Johannes Schindelin; +Cc: James, git Johannes Schindelin wrote: > Hi, > > On Wed, 7 Nov 2007, James wrote: > >> fetch = +refs/heads/*:refs/remotes/origin/* > > This is a refspec. > >> push = ssh://james@my.server.com/home/james/scm/git/project.git/ > > This is a URL. It does not specify any refs. But "push =" expects a URL. I think Johannes meant to say "But 'push =' expects a refspec." (the manpage even says so). About your problem: If you want to pull from a git:// repository and push to another with ssh:// (or in general when having two different repositories for pushing and fetching) in my novice understanding you would need two remotes. In your case, can't you just use your ssh-url for fetching as well? Regards, Jojo -- Johannes Gilger <heipei@hackvalue.de> http://hackvalue.de/heipei/ GPG-Key: 0x42F6DE81 GPG-Fingerprint: BB49 F967 775E BB52 3A81 882C 58EE B178 42F6 DE81 ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: git push refspec problem 2007-11-07 15:22 ` Johannes Gilger @ 2007-11-07 15:30 ` James 2007-11-07 20:40 ` Daniel Barkalow 2007-11-07 15:39 ` Johannes Schindelin 1 sibling, 1 reply; 10+ messages in thread From: James @ 2007-11-07 15:30 UTC (permalink / raw) To: Johannes Gilger; +Cc: Johannes Schindelin, git On Nov 7, 2007, at 10:22 AM, Johannes Gilger wrote: > Johannes Schindelin wrote: >> Hi, >> >> On Wed, 7 Nov 2007, James wrote: >> >>> fetch = +refs/heads/*:refs/remotes/origin/* >> >> This is a refspec. >> >>> push = ssh://james@my.server.com/home/james/scm/git/project.git/ >> >> This is a URL. It does not specify any refs. But "push =" expects >> a URL. > > I think Johannes meant to say "But 'push =' expects a refspec." (the > manpage even says so). > > About your problem: If you want to pull from a git:// repository and > push to another with ssh:// (or in general when having two different > repositories for pushing and fetching) in my novice understanding > you would need two remotes. In your case, can't you just use your > ssh-url for fetching as well? > > Regards, > Jojo I guess I could use my ssh url for pulling, as well. I simply figured it would be easier to add an ssh URL for push (like I was doing manually) and be done with it. But it doesn't seem there's a super simple solution (i.e., my syntax was wrong in the config file) to using git for pull and ssh for push. .james > -- > Johannes Gilger <heipei@hackvalue.de> > http://hackvalue.de/heipei/ > GPG-Key: 0x42F6DE81 > GPG-Fingerprint: BB49 F967 775E BB52 3A81 882C 58EE B178 42F6 DE81 ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: git push refspec problem 2007-11-07 15:30 ` James @ 2007-11-07 20:40 ` Daniel Barkalow 0 siblings, 0 replies; 10+ messages in thread From: Daniel Barkalow @ 2007-11-07 20:40 UTC (permalink / raw) To: James; +Cc: Johannes Gilger, Johannes Schindelin, git On Wed, 7 Nov 2007, James wrote: > On Nov 7, 2007, at 10:22 AM, Johannes Gilger wrote: > > >Johannes Schindelin wrote: > > >Hi, > > > > > >On Wed, 7 Nov 2007, James wrote: > > > > > > > fetch = +refs/heads/*:refs/remotes/origin/* > > > > > >This is a refspec. > > > > > > > push = ssh://james@my.server.com/home/james/scm/git/project.git/ > > > > > >This is a URL. It does not specify any refs. But "push =" expects a URL. > > > >I think Johannes meant to say "But 'push =' expects a refspec." (the > >manpage even says so). > > > >About your problem: If you want to pull from a git:// repository and > >push to another with ssh:// (or in general when having two different > >repositories for pushing and fetching) in my novice understanding > >you would need two remotes. In your case, can't you just use your > >ssh-url for fetching as well? > > > >Regards, > >Jojo > > > I guess I could use my ssh url for pulling, as well. I simply figured it > would be easier to add an ssh URL for push (like I was doing manually) and be > done with it. But it doesn't seem there's a super simple solution (i.e., my > syntax was wrong in the config file) to using git for pull and ssh for push. We *should* be able to make the rules: fetch tries URLs until one works, and then ignores later ones; push uses, in turn, all URLs that support pushing. Then you could just list both URLs, with the "git:" one first, and it would do what you want (plus, if the git server on your remote machine were down, it would fall back to ssh automatically for you). Actually, I think this would be a relatively easy project now, if you want to attempt it, since fetch and push and both in C now and the config file parser in remote.h reports all URLs in the config file's order. You'd just need to make it silently skip URLs in push that don't support pushing, and only give an error if none remain. (And add fallback support to fetch, for completeness; it's currently only using the first, IIRC). -Daniel *This .sig left intentionally blank* ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: git push refspec problem 2007-11-07 15:22 ` Johannes Gilger 2007-11-07 15:30 ` James @ 2007-11-07 15:39 ` Johannes Schindelin 1 sibling, 0 replies; 10+ messages in thread From: Johannes Schindelin @ 2007-11-07 15:39 UTC (permalink / raw) To: Johannes Gilger; +Cc: James, git Hi, On Wed, 7 Nov 2007, Johannes Gilger wrote: > Johannes Schindelin wrote: > > > On Wed, 7 Nov 2007, James wrote: > > > >> fetch = +refs/heads/*:refs/remotes/origin/* > > > > This is a refspec. > > > >> push = ssh://james@my.server.com/home/james/scm/git/project.git/ > > > > This is a URL. It does not specify any refs. But "push =" expects a > > URL. > > I think Johannes meant to say "But 'push =' expects a refspec." (the > manpage even says so). Of course. Thanks. Ciao, Dscho ^ permalink raw reply [flat|nested] 10+ messages in thread
end of thread, other threads:[~2007-11-07 20:41 UTC | newest] Thread overview: 10+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2007-11-07 15:01 git push refspec problem James 2007-11-07 15:11 ` Johannes Schindelin 2007-11-07 15:20 ` Pierre Habouzit 2007-11-07 15:23 ` James 2007-11-07 15:26 ` Johannes Gilger 2007-11-07 15:38 ` Pierre Habouzit 2007-11-07 15:22 ` Johannes Gilger 2007-11-07 15:30 ` James 2007-11-07 20:40 ` Daniel Barkalow 2007-11-07 15:39 ` Johannes Schindelin
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).