From: Bruce Korb <bkorb@gnu.org>
To: Chris Packham <judge.packham@gmail.com>
Cc: GIT <git@vger.kernel.org>, bkorb@gnu.org
Subject: Re: failed to push
Date: Mon, 01 Mar 2010 14:00:05 -0800 [thread overview]
Message-ID: <4B8C38E5.7090305@gnu.org> (raw)
In-Reply-To: <a038bef51003011342j3d761d0cmd96d8641f96ed15@mail.gmail.com>
Hi,
Thank you-all for your replies.
Chris Packham wrote:
>>> To ssh://bkorb@autogen.git.sourceforge.net/gitroot/autogen/autogen
>>> ! [rejected] master -> master (non-fast forward)
>>> error: failed to push some refs to 'ssh://bkorb@autogen.git.sourceforge.net/gitroot/autogen/autogen'
CF:
> It tells you right there at the end of the rejected line. The push
> would have resulted in a non-fast-forward update of the branch.
"non-fast forward" is not very helpful either.
> This basically means that the push you have attempted is not a simple
> fast forward. This basically means that the commit your work is based
> on is not present in the remote or that there have been other pushes
> to the remote and you need to pull them into your repository to handle
> any merging.
Since the sequence was:
git commit
git push
<more editing>
git commit --amend
git push
the neophyte (me) is not going to know that this produces an un-pulled
delta.
> OK that kind of sheds some light. I take it you've just switch from a
> centralized VCS?
"just switched"? No, I've been using BitKeeper for four years
and just recently converted my open source stuff to GIT. GIT
is harder to work with.
> In a DVCS like git all commits happen locally, the only time commits
> are sent to the remote repo are when you've pushed so 'git commit
> --amend' or 'git gui' with the amend box ticked only makes the change
> locally it won't implicitly figure out that a commit has been pushed
> out into the ether. One rule of thumb with git (I think it applies to
> most DVCSes) is not to amend a commit that has been pushed for this
> very reason.
Then please be kind enough to put a *CAUTION* button next to
the amend button and have it bring up something that gives you
a little warning. GIT *could* have been written in a way that
causes the remote repo to become synced with my local repo,
but apparently it was not and there was not adequate warning.
> Strictly speaking all commits are immutable, when you
> amend a commit you actually create a whole new commit and your old one
> is marked for garbage collection (if nothing else is based off it).
>
> In terms of recovering from your present situation I'd try the
> following (Disclaimer: maybe you shouldn't try these based solely on
> my advice. I'm still learning too)
>
> git pull
> <resolve merge issue, 'git mergetool' is your friend>
> git push
>
> I think this will basically sort things out but you may need to hand
> hold a few things through a merge depending on how different the 2
> commits are.
I will be trying this procedure momentarily. Meanwhile, since I am
the only person on the planet authorized to commit to the public repo:
> - or -
>
> git push -f
This fails with the same "non-fast forward" rejection message. :(
next prev parent reply other threads:[~2010-03-01 22:00 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-03-01 21:15 failed to push Bruce Korb
2010-03-01 21:23 ` Bruce Korb
2010-03-01 21:42 ` Chris Packham
2010-03-01 22:00 ` Bruce Korb [this message]
2010-03-01 22:04 ` SUCCESS -- " Bruce Korb
2010-03-02 11:44 ` Erik Faye-Lund
2010-03-02 19:09 ` Jakub Narebski
2010-03-02 21:36 ` Chris Packham
2010-03-02 23:07 ` [gitbook PATCH] add notes on re-writing history Chris Packham
2010-03-01 21:27 ` failed to push Jacob Helwig
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4B8C38E5.7090305@gnu.org \
--to=bkorb@gnu.org \
--cc=git@vger.kernel.org \
--cc=judge.packham@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.