On Fri, Jan 8, 2010 at 12:38 AM, martinvz <martin.von.zweigbergk@xxxxxxxxx> wrote: > > > Santi Béjar-2 wrote: >> >> Can you provide, at least, a graph of your history (ala git log >> --graph --oneline for example)? And plot also the reflog entries and >> all the important commits. >> > > $ git log --graph --format=%h --all > * 2038a46 # topic-2 > * a7b93b2 > * f2501ae # origin/main > * cd5aaa9 > * cb232f3 > ... > * 5ed0d06 > * 3067862 > | * 6eba2fa # topic-1 > | * b09aaf4 > | * bc3b72a > |/ > | * 03d0d84 # topic-3 > | * 5160773 > | * 3c25642 > |/ > | * 6e9b12b # topic-4 > | * 75f5ab2 > | * bdd08ce > | * b5d5759 > |/ > * 486b580 > * a021696 > * 3ffe7df > * d0f55c5 > ... > > I have topic-1 checked out and run "git pull" and expect it to rebase (only) > commits bc3b72a, b09aaf4, 6eba2fa onto f2501ae, but it starts by applying > a021696 and 486b580. > > $ git reflog -g origin/main > f2501ae refs/remotes/origin/mai n@{0}: fetch origin: fast forward > 3ffe7df refs/remotes/origin/mai n@{1}: fetch origin: fast forward > ... > > I hope that's all that's all you need. It seems that the problem is that the > oldremoteref gets overwritten with the entry from the reflog. Is the problem > that 3ffe7df appears in the reflog or that 486b580 doesn't appear there? I'm > not clear on what ends up in the reflog. > > I just realized that I myself created a021696 and 486b580 (but not 3ffe7df), > probably by rebasing some now-dead branch against origin/main. Yes, it is. The code expects that you always branch your topic branches from the upstream branch, so all the possible fork points are in the reflog. Your flow was to create the topic from a local commit and then push that commit. By the way, when Git tries to apply these two commits it should detect that they are already applied so it should do nothing, isn't it? HTH, Santi -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html