01 diciembre, 2013

Nice config for Git - Configuración práctica para Git

En mi experiencia intermedia en Git me he dado cuenta que vale la pena entender realmente su funcionamiento via consola de comandos. Es algo extraño (y que personalmente aun me cuesta entender), ya que las aplicaciones tienden normalmente a tener interfaces de usuario con metáforas desarrolladas para que el usuario tenga una interacción transparente con el programa.

Es cierto que los sitios que administran repositorios Git (tipo Github o BitBucket) ofrecen muchas herramientas gráficas que permiten entender e incluso realizar tareas de merging, clone, fork, rebasing, entre otras, via Web. Además existen los clientes gráficos (GITK, TortoiseGit) que suelen estar muy cargados de elementos y a veces son incomprensibles, con mil opciones y cajas de chequeo que no se sabe que acción [destructiva] pueda realizar sobre el repositorio. Aun así, estas herramientas no siempre son suficiente y en algunos casos el no entender claramente los principios de Git nos puede llevar a cometer errores (experiencia personal y dedicatoria a mi buen amigo Luis :P) por estos medios.

De todas formas, como Git sigue siendo lo que es, guardando su gran potencial, vale la pena saber cómo trabajar en consola PERO acomodando su entorno de trabajo de la mejor manera para que sea productivo, fácil y eficiente. Aquí van unos datos que me parecen muy útiles para la configuración del entorno Git para trabajo por consola:

Activar colores

Tan simple como ejecutar el comando:

git config —global color.ui true

Añadir un log más limpio

Siguiendo algo que encontré hace unos días enhttps://coderwall.com/p/euwpig, estoy usando un maravilloso log mucho más resumido y claro que el clasico log de git. Para instalarlo:

git config —global alias.lg “log —color —graph —pretty=format:’%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset’ —abbrev-commit —”

y para ejecutarlo:

git lg
git lg -p


Es solo de probar y se entiende la diferencia.

Herramienta externa para merge

No olvidar instalar una herramienta externa para hacer merge. Mis ejemplos clásicos son: WinMerge para Windows y Meld para Linux (seguro que los que Vim dirán que todo se puede en consola …. pero toma su tiempo acostumbrarse). Luego no olvidar asignar ese programa en la configuración de git:

git config —global merge.tool meld

Para seguir trabajando comodamente recomiendo ir de todas formas de la mano de las interfaces gráficas que mencioné previamente. De esta forma se entiende qué hace cada botón y quizas en algunos casos permita ganar tiempo.