Re: Head, Branch != Head -> Branch?

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



After going through the code and thinking about this. I think the
unexpected results came from git branch not checking out the branch I
created.
I know git checkout -b master would have been the result I wanted. If
I were to create another commit with HEAD checked out instead of
master, master would not update, only HEAD would.
I guess the real crime here is that git branch does not checkout the
branch created. I don't think I ever wanted to create a branch without
checking it out, otherwise I would use git tag.

Tomas Zubiri
Software Developer
Cel: +54 911 5891 8239


El sáb., 14 de dic. de 2019 a la(s) 15:00, Tomas Zubiri
(me@xxxxxxxxxxxxxxx) escribió:
>
> Hello, I'm writing because I believe I found a case where git could be
> simplified. I'm posting my terminal log so that you can see exactly
> what I saw. Comments are marked with >> . Important spanish git was
> translated.
>
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git status
> HEAD detached at 54da1ac
> Cambios no rastreados para el commit:
>   (usa "git add <archivo>..." para actualizar lo que será confirmado)
>   (usa "git checkout -- <archivo>..." para descartar los cambios en el
> directorio de trabajo)
>
> modificado:     cv/en/index.html
> modificado:     cv/index.html
>
> sin cambios agregados al commit (usa "git add" y/o "git commit -a")
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git add cv/en/index.html
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git add cv/index.html
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git commit -m
> "Agrego mi celular, por favor no me manden spam"
> [HEAD detached 82b2b55] Agrego mi celular, por favor no me manden spam
>  2 files changed, 3 insertions(+), 1 deletion(-)
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git push
> fatal: Actualmente no estás en una rama.
> Para hacer un push a la historia que lleva al estado actual
> (HEAD detached), use
>
> git push origin HEAD:<nombre-de-rama-remota>
>
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git push origin ^C
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git log
> commit 82b2b55b3f7768a60e3d8bcda97d4d623ff0e044 (HEAD)
> Author: Tomas Zubiri <me@xxxxxxxxxxxxxxx>
> Date:   Fri Dec 13 21:37:30 2019 -0300
>
>     Agrego mi celular, por favor no me manden spam
> >> This is the commit I wanted to push
>
> commit 54da1ac07a5c7c2e7234911a0af76aee042b5b99
> Author: Tomas Zubiri <me@xxxxxxxxxxxxxxx>
> Date:   Fri Dec 13 20:33:11 2019 -0300
>
>     Limpio url para cv en inglés.
> >> This is an abandoned commit I didn't push.
>
>
>
> commit 81542e725149ba5da36560ad14d4871eb7ea01e6 (origin/master)
> Author: Tomas Zubiri <me@xxxxxxxxxxxxxxx>
> Date:   Fri Oct 18 17:08:50 2019 -0300
>
>     especifico tecnologías de contribución de codigo
> >> This is what's in production
>
>
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git checkout origin/master^C
> >> ^C cancels the command, I notice there's an extra commit.
>
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git branch newmaster
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git checkout origin/master
> La posición previa de HEAD era 82b2b55 Agrego mi celular, por favor no
> me manden spam
> >> Previous head position was..
>
> HEAD está ahora en 81542e7 especifico tecnologías de contribución de codigo
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git cherry-pick newmaster
> [HEAD desacoplado 912c91a] Agrego mi celular, por favor no me manden spam
>  Date: Fri Dec 13 21:37:30 2019 -0300
>  2 files changed, 3 insertions(+), 1 deletion(-)
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git log
> commit 912c91a92e17de33247e2040d1dd01adbfc218eb (HEAD)
> Author: Tomas Zubiri <me@xxxxxxxxxxxxxxx>
> Date:   Fri Dec 13 21:37:30 2019 -0300
>
>     Agrego mi celular, por favor no me manden spam
>
> commit 81542e725149ba5da36560ad14d4871eb7ea01e6 (origin/master)
> Author: Tomas Zubiri <me@xxxxxxxxxxxxxxx>
> Date:   Fri Oct 18 17:08:50 2019 -0300
>
>     especifico tecnologías de contribución de codigo
> >> Looks good.
>
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git branch master
> fatal: Una rama llamada 'master' ya existe.
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git branch -D master
> Eliminada la rama master (era 679eaf3)..
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git branch master
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git push^C
> >> Gotta double check.
>
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git log
> commit 912c91a92e17de33247e2040d1dd01adbfc218eb (HEAD, master)
> Author: Tomas Zubiri <me@xxxxxxxxxxxxxxx>
> Date:   Fri Dec 13 21:37:30 2019 -0300
>
>     Agrego mi celular, por favor no me manden spam
>
> commit 81542e725149ba5da36560ad14d4871eb7ea01e6 (origin/master)
> Author: Tomas Zubiri <me@xxxxxxxxxxxxxxx>
> Date:   Fri Oct 18 17:08:50 2019 -0300
>
>     especifico tecnologías de contribución de codigo
>
>
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git push
> fatal: Actualmente no estás en una rama.
> >> Fatal: You are not currently on a branch.
>
> Para hacer un push a la historia que lleva al estado actual
> (HEAD desacoplado), use
>
> git push origin HEAD:<nombre-de-rama-remota>
>
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git push origin/master
> fatal: Actualmente no estás en una rama.
> Para hacer un push a la historia que lleva al estado actual
> (HEAD desacoplado), use
>
> git push origin/master HEAD:<nombre-de-rama-remota>
>
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git push ^Cigin/master
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git log
> commit 912c91a92e17de33247e2040d1dd01adbfc218eb (HEAD, master)
> Author: Tomas Zubiri <me@xxxxxxxxxxxxxxx>
> Date:   Fri Dec 13 21:37:30 2019 -0300
>
>     Agrego mi celular, por favor no me manden spam
>
> commit 81542e725149ba5da36560ad14d4871eb7ea01e6 (origin/master)
> Author: Tomas Zubiri <me@xxxxxxxxxxxxxxx>
> Date:   Fri Oct 18 17:08:50 2019 -0300
>
>     especifico tecnologías de contribución de codigo
>
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git push >> So
> confused I repeated a command.
> fatal: Actualmente no estás en una rama.
> Para hacer un push a la historia que lleva al estado actual
> (HEAD desacoplado), use
>
> git push origin HEAD:<nombre-de-rama-remota>
>
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git log
> commit 912c91a92e17de33247e2040d1dd01adbfc218eb (HEAD, master)
> Author: Tomas Zubiri <me@xxxxxxxxxxxxxxx>
> Date:   Fri Dec 13 21:37:30 2019 -0300
>
>     Agrego mi celular, por favor no me manden spam
>
> commit 81542e725149ba5da36560ad14d4871eb7ea01e6 (origin/master)
> Author: Tomas Zubiri <me@xxxxxxxxxxxxxxx>
> Date:   Fri Oct 18 17:08:50 2019 -0300
>
>     especifico tecnologías de contribución de codigo
>
>
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git push
> fatal: Actualmente no estás en una rama.
> >> Fatal: Not currently on a branch
>
> Para hacer un push a la historia que lleva al estado actual
> (HEAD desacoplado), use
>
> git push origin HEAD:<nombre-de-rama-remota>
>
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git checkout master
> Cambiado a rama 'master'
> >> Now on 'master' branch
>
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git push
> fatal: La rama actual master no tiene una rama upstream.
> >> This error message is something I would expect, since I deleted the master branch and created a new one. That's ok.
>
> Para realizar un push de la rama actual y configurar el remoto como
> upstream, use
>
> git push --set-upstream origin master
>
> (base) tomas@toms:~/Projects/tomaszubiri.com/site$ git log
> commit 912c91a92e17de33247e2040d1dd01adbfc218eb (HEAD -> master)
> Author: Tomas Zubiri <me@xxxxxxxxxxxxxxx>
> Date:   Fri Dec 13 21:37:30 2019 -0300
>
>     Agrego mi celular, por favor no me manden spam
>
> commit 81542e725149ba5da36560ad14d4871eb7ea01e6 (origin/master)
> Author: Tomas Zubiri <me@xxxxxxxxxxxxxxx>
> Date:   Fri Oct 18 17:08:50 2019 -0300
>
>     especifico tecnologías de contribución de codigo
>
>
> Thank you for stepping in my shoes for a moment here. I understand now
> that Head is a special kind of tag and it must be attached to a
> branch. But I don't yet understand why the distinction between head
> attached to branch and head and branch in the same commit is
> necessary. Couple that to the fact that git forgot (perhaps with good
> cause) what remote master pointed to, it feels like this is a place
> where git could improve in simplicity.
>
> My naive suggestion would be as follows:
>
>  When HEAD is pointing to a commit and another branch is pointing to
> the same commit, consider the head attached to that commit.
> I understand that, if there were multiple branches on the same commit,
> git wouldn't know what remote to push to, so in such case a
> disambiguation would be needed, but the case here would be that we are
> on 2 branches, not none!
>
> What am I missing here? Would this change have catastrophic consequences?
>
> Regards.




[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux