Difference between revisions of "Git, Tagging"

From Wiki de Caballero
Jump to navigation Jump to search
Line 76: Line 76:
git branch nuevaRama
git branch nuevaRama
</syntaxhighlight>
</syntaxhighlight>
===Listar ramas===
<syntaxhighlight lang="bash">
git branch
</syntaxhighlight>
Para más información ver [http://git-scm.com/book/en/Git-Branching-Branch-Management libro oficial].


===Cargar una rama===
===Cargar una rama===
Line 110: Line 116:
git branch -d nuevaRama
git branch -d nuevaRama
</syntaxhighlight>
</syntaxhighlight>
===Conflictos===
Para más información sobre cuando se producen conflictos y cómo resolverlos trabajando con ''branches'', ver [http://git-scm.com/book/en/Git-Branching-Basic-Branching-and-Merging#Basic-Merge-Conflicts libro oficial].


[[Category: Git]]
[[Category: Git]]

Revision as of 02:54, 12 November 2013

Para entender sobre Git, leer previamente Git, lo Básico.

Tagging

Los tags son referencias a un commit en particular, pueden ser útiles por ejemplo para hacer referencia a una versión del desarrollo (e.g. 1.3.2).

Existen dos tipos de tags. Primero, lightweight que funcionan como un puntero a un objeto de Git pero no guardan información adicional. Segundo, annotaded que son guardados como objetos completos de Git y contienen información como nombre del tagger (quien hace el tag), e-mail, fecha y tienen un mensaje. En el libro oficial recomiendan usar annotaded tags.

Lightweight Tags

git tag nombreTag

Anotaded Tags

git tag -a nombreTag -m 'Mensaje del tag'

Listar tags

Listar todos los tags

Este comando lista los tags disponibles

git tag

Resultado:

v1
v1.3
v1.5

Listar tags usando filtro

Este comando lista los tags disponibles

git tag -l 'v1.*' # Lista solamente los tags que empiezan con v1.

Resultado:

v1.3
v1.5

Tag un commit anterior

Para hacer un tag sobre un commit anterior se usa, después del comando, el checksum del commit (o una parte) que se quiere usar. Funciona igual para lightweight o annotaded tags. Ej:

git tag -a nombreTag -m 'Mensaje del tag' 1132c1f

Quitar un tag

git tag rm nombreTag

Subir tags a un remote

git push nombreRemote nombreTag	# Sube nombreTag a nombreRemote
git push nombreRemote --tags	# Sube todos los tags que exiten localmente a nombreRemote

Branching

Branching funciona como caminos diferentes que pueden volver a unirse. En un punto determinado de la historia del proyecto se crean dos caminos que contienen lo mismo pero que pueden cambiar independientemente.

Existe un puntero HEAD que apunta a la rama actual.

La rama mestra se crea por defecto y se llama master.

Antes de cambiar de rama (checkout) es buena idea hacer un commit.

Crear una rama nueva, nueva branch

git branch nuevaRama

Listar ramas

git branch

Para más información ver libro oficial.

Cargar una rama

Este comando carga el contenido de una rama y hace que el puntero HEAD apunte a dicha rama.

git checkout nuevaRama

Cargar la rama maestra

Este comando carga el contenido de la rama maestra y hace que el puntero HEAD apunte a dicha rama.

git checkout master

Crear rama y cargarla

git checkout -b nuevaRama

Es un atajo que hace lo mismo que:

git branch nuevaRama
git checkout nuevaRama

Merge branches (unificar ramas)

git checkout master	# Se carga la rama master estando en otra rama
git merge nuevaRama	# Se hace merge de la nuevaRama sobre master

Borrar una rama

Se pueden borrar ramas cuando se desee pero puede ser buena idea hacerlo cuando se planee no usarla más, eso puede ocurrir por ejemplo cuando se trabajo en una rama, se unió al master y ya no tiene sentido tener la rama todavía porque no se va a trabajar más sobre ella.

git branch -d nuevaRama

Conflictos

Para más información sobre cuando se producen conflictos y cómo resolverlos trabajando con branches, ver libro oficial.