domingo, 25 de septiembre de 2022

GIT - 1 - Borrar y Renombrar archivos - Revertir Cambios.

 

Borrar un archivo.


Para borrar un archivo del árbol de trabajo podríamos usar el comando "rm" sobre el mismo. Sin embargo aún tendríamos que usar git add [archivo_borrado] para que está modificación quedara registrada y luego ya podríamos hacer el commit.


chema@lenovo:~/proyecto$ rm main.py
chema@lenovo:~/proyecto$ git status
On branch master
Changes not staged for commit:
  (use "git add/rm <file>..." to update what will be committed)
  (use "git restore <file>..." to discard changes in working directory)
	deleted:    main.py

no changes added to commit (use "git add" and/or "git commit -a")
chema@lenovo:~/proyecto$ git add main.py
chema@lenovo:~/proyecto$ git status
On branch master
Changes to be committed:
  (use "git restore --staged <file>..." to unstage)
	deleted:    main.py

chema@lenovo:~/proyecto$ git commit -m "Pasos para borrar un archivo."
[master 5a2eea1] Pasos para borrar un archivo.
 1 file changed, 2 deletions(-)
 delete mode 100644 main.py

Sin embargo con;

$ git rm [archivos]

No solo borramos los archivos del árbol de trabajo sino que también lo preparamos para hacer el commit.

chema@lenovo:~/proyecto$ git rm main.py
rm 'main.py'
chema@lenovo:~/proyecto$ git status
On branch master
Changes to be committed:
  (use "git restore --staged <file>..." to unstage)
	deleted:    main.py

chema@lenovo:~/proyecto$ git commit -m "borrado de un archivo."
[master e86a317] borrado de un archivo.
 1 file changed, 0 insertions(+), 0 deletions(-)
 delete mode 100644 main.py

Mover o Renombrar un Archivo.

Lo mismo ocurre si queremos mover un archivo de un directorio a otro dentro del árbol de trabajo. Para ahorrar tener que confirmar la modificación con git add, directamente tecleamos:

$ git mv [archivo] [nuevo_nombre]

y así podemos mover los archivo entre directorios o bien también lo podemos usar para cambiar el nombre de los archivos y tener estas modificaciones registradas y listas para hacer el commit.

mover un archivo con git

chema@lenovo:~/proyecto$ git status
On branch master
nothing to commit, working tree clean
chema@lenovo:~/proyecto$ git mv main.py ./MOVER/
chema@lenovo:~/proyecto$ git status
On branch master
Changes to be committed:
  (use "git restore --staged <file>..." to unstage)
	renamed:    main.py -> MOVER/main.py

Ignorar Cambios.


Git ve cada archivo en el árbol de trabajo como una de estas tres cosas:

- Rastreado. Un archivo que se ha preparado o confirmado previamente.
- Sin seguimiento. Un archivo que no se ha preparado ni confirmado.
- Ignorado. Un archivo que se le ha dicho explícitamente a git que ignore cualquier cambio que se produzca.

Esos archivos o directorios son aquellos que no suelen formar parte del proyecto tales como archivos de compilación o archivos temporales generados por el ordenador. 

Los archivos a ignorar se buscan en un archivo especial llamado .gitignore, un archivo oculto que hay que crear en la raíz del repositorio. Este archivo debe crearse y editarse a mano cuando tengas nuevos archivos que quieras ignorar. Los archivos .gitignore contienen patrones que se comparan con los nombres de los archivos de los repositorios para determinar si deben ignorarse o no.

Se pueden usar patrones globales dentro del archivo para ampliar los casos en los que determinados archivos no deban ser incluidos. Puedes ver una buena explicación del uso de los mismos en esta página.

Ejemplo de archivo .gitignore

# Byte-compiled / optimized / DLL files
__pycache__/
*.py[cod]
*$py.class

El propio archivo .gitignore necesita ser comprometido "commit" al igual que el resto.


¿Cómo evitar el rastreo de archivos a los que previamente les has hecho "commit" ?


$ git rm --cached nombre-del-archivo

Establece un archivo como "untracked file", sin seguimiento.

Saca los archivos de nuestro repositorio local y del área de staging, pero los mantiene en el disco duro, no los borra. Básicamente le dice a Git que deje de trackear el historial de cambios de estos archivos, por lo que pasaran a un estado untracked o Sin seguimiento. Si no queremos que git les vuelva a hacer seguimiento los añadiríamos al archivo .gitignore.


Revertir Cambios.

Tenemos que distinguir entre dos posibles escenarios.

A) Revertir cambios antes de que los archivos pasen al Stage.

B) Revertir cambios cuando los archivos ya están en el Stage.


- Revertir cambios antes del Stage.

$ git checkout [archivos]

Revierte cambios en archivos antes de que sean confirmados, antes de que se haga un commit nuevo y  siempre que no los hayamos añadido al Stage, usando un git add. 

Se vuelve a la versión del último commit o confirmación realizada. Es decir, descartamos las modificaciones que hayamos hecho en el archivo y lo devolvemos a como estaba anteriormente, en la confirmación o commit previo.

Veámoslo con un ejemplo.

Imaginemos que iniciamos un repositorio, creamos un archivo y dentro escribimos un comentario. Después lo pasamos al stage y realizamos un commit.

chema@lenovo:~/proyecto$ git init
hint: Using 'master' as the name for the initial branch. This default branch name
hint: is subject to change. To configure the initial branch name to use in all
hint: of your new repositories, which will suppress this warning, call:
hint: 
hint: 	git config --global init.defaultBranch <name>
hint: 
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
hint: 'development'. The just-created branch can be renamed via this command:
hint: 
hint: 	git branch -m <name>
Initialized empty Git repository in /home/chema/proyecto/.git/
chema@lenovo:~/proyecto$ echo "# Primera linea del archivo" > main.py
chema@lenovo:~/proyecto$ git add main.py 
chema@lenovo:~/proyecto$ git commit -m "primer commit"
[master (root-commit) ef8ab09] primer commit
 1 file changed, 1 insertion(+)
 create mode 100644 main.py

Ahora, imaginemos que añadimos más código al archivo. Como es un ejemplo para mostrar como funciona el comando, solamente voy a añadir dos líneas más, pero funciona igual si has tecleado miles de líneas de código.

chema@lenovo:~/proyecto$ echo "#Segunda linea añadida" >> main.py 
chema@lenovo:~/proyecto$ echo "#Tercera linea añadida" >> main.py 
chema@lenovo:~/proyecto$ cat main.py 
# Primera linea del archivo
#Segunda linea añadida
#Tercera linea añadida

Ahora me doy cuenta de que en el archivo hay un error y no recuerdo como estaba originalmente cuando funcionaba. Lo que necesito es deshacer lo que he hecho desde la última vez que guarde los cambios. 

Lo único que hay que hacer es usar, el comando $ git checkout main.py

chema@lenovo:~/proyecto$ git checkout main.py
Updated 1 path from the index
chema@lenovo:~/proyecto$ cat main.py
# Primera linea del archivo
Y volvemos al estado original.

Otro ejemplo. Supongamos que tenemos un programa con un montón de archivos y directorios. Como todo funciona bien hacemos un commit del repositorio y seguimos programando. Cuando llevamos algunas líneas de código lo volvemos a probar y algo no va. No sabemos donde puede estar el bug pero si sabemos que la ultima versión que teníamos funcionaba. Decidimos empezar otra vez y volvemos a la anterior versión que era estable. Para ello usamos:

$ git checkout .
(no se si se ve pero al final hay un punto.)

Al escribir este comando de esta forma le decimos que vuelva a la última versión, a la versión previa.
En git esto es volver al commit previo.

- Revertir los cambios cuando ya hemos añadido esos archivos al Stage.


$ git reset HEAD <archivos>

Así como el comando anterior nos permitía revertir cambios a archivos modificados antes de que pasaran al Stage, este comando nos permite deshacer cambios que ya estén en el Stage bien porque ya hayamos hecho, por ejemplo un git add . o un git add *.

Es decir lo que nos permite es pasar archivos, que ya estaban en el Stage preparados para hacer un commit, al árbol de trabajo de nuevo. En definitiva sacar esos archivos del Stage. 

Veámoslo con un ejemplo.

Partimos del ejemplo anterior y le añadimos un cuarto comentario al archivo. Después, aunque solamente tenemos un archivo, lo añadimos al stage. Entonces nos damos cuenta de que queremos cambiar algo antes de hacer el commit con lo que usamos este comando para devolver el archivo, al árbol de trabajo.

chema@lenovo:~/proyecto$ echo "Cuarta linea añadida" >> main.py
chema@lenovo:~/proyecto$ git add *
chema@lenovo:~/proyecto$ git status
On branch master
Changes to be committed:
  (use "git restore --staged <file>..." to unstage)
	modified:   main.py

chema@lenovo:~/proyecto$ git reset HEAD main.py
Unstaged changes after reset:
M	main.py
chema@lenovo:~/proyecto$ cat main.py
# Primera linea del archivo
Cuarta linea añadida
chema@lenovo:~/proyecto$ git status
On branch master
Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git restore <file>..." to discard changes in working directory)
	modified:   main.py

no changes added to commit (use "git add" and/or "git commit -a")

Que quede claro que no se modifica el archivo, simplemente lo saca del Stage y lo devuelve al árbol de trabajo para que podamos trabajar con el. (Aunque si coges ese archivo y lo modificas antes de hacer un commit también lo sacarás del Stage porque habrás hecho una modificación que no has confirmado)

Comandos equivalentes son:

$ git restore --staged <archivos>

$ git reset -p      En este caso nos pedirá confirmación paso a paso de las acciones a realizar.


- Revertir los cambios si ya hemos hecho un commit. 


Si ya hemos realizado una instantánea del repositorio al realizar un commit y queremos anularlo, podemos hacerlo de diversas formas dependiendo de lo que queramos conseguir.

A) Cambiando el último commit:


$ git commit --amend 

Es la forma conveniente de modificar la confirmación más reciente. Sobrescribe el commit previo, es decir, se añade lo que ya tengamos en esa instantánea con lo que tengamos actualmente en el Stage. Si no hemos añadido o modificado nada, se puede utilizar simplemente para editar el mensaje de confirmación anterior sin cambiar su instantánea.

SOLAMENTE USALO EN COMMITS LOCALES porque borra el historial del último commit que en proyectos en grupo podría haber realizado otra persona. Las confirmaciones modificadas son en realidad confirmaciones completamente nuevas y la confirmación anterior ya no aparecerá.

Por ejemplo. Digamos que acabamos de realizar una confirmación (commit) y cometimos un error en el mensaje de confirmación. Ejecutar este comando cuando no hay nada todavía nuevo preparado, que esté en el Stage, nos permite modificar el anterior mensaje de confirmación anterior sin alterar su instantánea.

chema@lenovo:~/proyecto$ git log
commit 2f08687ba8e43dbd7d40d0405108a841c97c69a9 (HEAD -> master)
Author: usuario <usuario@correo.es>
Date:   Thu Sep 22 19:33:06 2022 +0200

    primer commit. Contiene un error.
chema@lenovo:~/proyecto$ git commit --amend -m "primer commit. Error Subsanado."
[master c5ecfed] primer commit. Error Subsanado.
 Date: Thu Sep 22 19:33:06 2022 +0200
 1 file changed, 1 insertion(+)
 create mode 100644 main.py
chema@lenovo:~/proyecto$ git log
commit c5ecfed30cff8625efd54e1ea136906ef2cca50d (HEAD -> master)
Author: usuario <usuario@correo.es>
Date:   Thu Sep 22 19:33:06 2022 +0200

    primer commit. Error Subsanado.

Si te fijas es cierto que hemos modificado el mensaje de la confirmación, pero si miras bien verás que el número del commit (en negrita) también es distinto.


Otro ejemplo habitual. Digamos que hemos editado algunos archivos que nos gustaría confirmar en una sola instantánea, pero luego nos damos cuenta de que se nos ha olvidado añadir uno de los archivos la primera vez. Bastará con prepara el nuevo archivo, añadirlo al Stage y usar este comando.

chema@lenovo:~/proyecto$ git log
commit 2ebf529db3565c2c9a26f9fa65ef5ffcc6fc3d5d (HEAD -> master)
Author: usuario <usuario@correo.es>
Date:   Fri Sep 23 17:33:07 2022 +0200

    primer commit
chema@lenovo:~/proyecto$ > archivo_añadir
chema@lenovo:~/proyecto$ git add archivo_añadir 
chema@lenovo:~/proyecto$ git commit --amend -m "Primer commit con archivo olvidado añadido"
chema@lenovo:~/proyecto$ git show
commit 1b9aa03962422e4cf73c5496ec66557901c81e8f (HEAD -> master)
Author: usuario <usuario@correo.es>
Date:   Fri Sep 23 17:33:07 2022 +0200

    primer commit. Con archivo olvidado añadido


B) Revertir un commit por completo. (ROLL BACK)


$ git revert HEAD

Crea un nuevo commit que es justo la inversa del último, con lo que volvemos al estado del anterior. Sin embargo esta acción no sobrescribe el commit previo ni lo elimina del historial

* Estado del archivo en la última instantánea.
chema@lenovo:~/proyecto$ cat main.py 
# Primera linea del archivo
#!/usr/bin/env python3
import math

* Deshacemos los cambios
chema@lenovo:~/proyecto$ git revert HEAD
[master 7d7e430] Revert "muevo commit"
 1 file changed, 2 deletions(-)

chema@lenovo:~/proyecto$ cat main.py 
# Primera linea del archivo

* El último commit es el inverso del anterior.
chema@lenovo:~/proyecto$ git log
commit 7d7e43071d1b48ea76ba6f0ab99e0e1732e688ea (HEAD -> master)
Author: usuario <usuario@correo.es>
Date:   Fri Sep 23 19:53:05 2022 +0200

    Revert "nuevo commit"
    
    This reverts commit 7b0418f9029abea87808f019f0683bc6b70ec709.

commit 7b0418f9029abea87808f019f0683bc6b70ec709
Author: usuario <usuario@correo.es>
Date:   Fri Sep 23 19:51:59 2022 +0200

    muevo commit

C) Revertir un commit por completo que no sea el último.


El Id es el código alfanumérico muy largo que aparece al lado de la palabra commit. Lo calcula el programa con el algoritmo SHA1. Sirve para garantizar que la integridad del commit y que ese commit es único.

En el ejemplo anterior el ID del primer commit es 7b0418f9029abea87808f019f0683bc6b70ec709

$ git revert <ID del commit>

Este comando desharía los cambios de esa instantánea en concreto, pero ojo que esto nos puede dar dolores de cabeza el revertir cambios anteriores que ya estaban consolidados.

Borrar todos los commits posteriores a uno previo.


$ git reset --hard <id o sha del commit>

Se BORRAN PARA SIEMPRE todos los commits más nuevos y se recupera el repositorio al estado del que hemos ido.

Movernos entre distintos commits.

En ocasiones nos interesa movernos atrás en el tiempo para ver como estaba un repositorio en un momento concreto. 

Considera este repositorio con 4 confirmaciones.

chema@lenovo:~/Prueba$ git log --oneline
0face9c (HEAD -> main) Añadido archivo de instrucciones
e624744 añadido nuevo comando a main.py
ad3b242 Segundo commit.
5011475 Primer commit del repositorio.

Si quisiera volver, a ver como estaba el proyecto en el segundo repositorio (ad3b242) se puede usar:

$ git checkout <id del commit>

git checkout ad3b242
Note: switching to 'ad3b242'.

You are in 'detached HEAD' state. You can look around, make experimental
changes and commit them, and you can discard any commits you make in this
state without impacting any branches by switching back to a branch.

If you want to create a new branch to retain commits you create, you may
do so (now or later) by using -c with the switch command. Example:

  git switch -c <new-branch-name>

Or undo this operation with:

  git switch -

Turn off this advice by setting config variable advice.detachedHead to false

HEAD is now at ad3b242 Segundo commit.
chema@lenovo:~/Prueba$ ls
main.py

Pero OJOOOO, que si realizas alguna modificación y la confirmas no volverás a la rama main o master que es en la que estas trabajando, si no que crearemos una nueva rama. Aunque el concepto de ramas lo veremos en los siguientes capítulos voy a hacer una modificación al repositorio y un commit para ver lo que ocurre.

Luego, si le pregunto a git cuantas ramas tengo y donde estoy, veo lo siguiente:

chema@lenovo:~/Prueba$ git branch
* (HEAD detached from ad3b242)
  main
 
El asterisco indica en donde estoy. Para volver a donde estaba trabajando, tengo que desplazarme al último commit de mi rama principal que en mi caso se llama main (también puede aparecerte como master)

$ git checkout <rama a donde nos queremos mover>

chema@lenovo:~/Prueba$ git checkout main
Warning: you are leaving 1 commit behind, not connected to
any of your branches:

  327aad6 prueba de checkout

If you want to keep it by creating a new branch, this may be a good time
to do so with:

 git branch <new-branch-name> 327aad6

Switched to branch 'main'
chema@lenovo:~/Prueba$ git log --oneline 
* 0face9c (HEAD -> main) Añadido archivo de instrucciones
* e624744 añadido nuevo comando a main.py
* ad3b242 Segundo commit.
* 5011475 Primer commit del repositorio.
 

y volvemos a donde estabamos.

miércoles, 14 de septiembre de 2022

Curso Esquemático de Git y Github

imagen de entrada de git







Curso Esquemático de Git y Github.


Cuando pasas de un proyecto sencillo a otro más complicado, estas trabajando con más personas en un mismo programa o si simplemente quieres tener un registro de como está evolucionando el código que estas desarrollando para que un tú del futuro sepa lo que has hecho, tenemos que utilizar si o si un administrador de versiones. El más conocido en términos de rendimiento, seguridad y flexibilidad es Git y su plataforma GitHub.

Antes de meternos en materia de como funciona, es necesario entender como se pueden controlar las diferentes versiones de un programa. Si tuviéramos que hacer nosotros manualmente un control de como evoluciona un programa podríamos usar el comando "diff" de Linux de la siguiente forma.

Imaginemos un programa como el siguiente:

# version 0.1 
print("Hola Mundo")

Vamos a ponerle un nombre y guardarlo. Yo lo llamaré archivo_1.py. Ahora vamos a añadir una nueva línea:

# version 0.2 
print("Hola Mundo")
print("Esta es la segunda versión")

Lo vamos a guardar con un nombre distinto para poder comparar ambas versiones. Este se llamará archivo_2.py

Si en el shell de Linux tecleamos:

$ diff archivo_1.py archivo2_py

Veremos lo siguiente:

1c1
< # version 0.1 
---
> # version 0.2 
2a3
> print("Esta es la segunda versión")
Aunque se pueden intuir las diferencias existentes entre los archivos, el resultado no es fácilmente comprensible. Esto es debido a que fue diseñado para ser usado por computadoras y no por humanos. Pero a groso modo lo que viene a decir es que la primera línea del primer archivo debe cambiarse por la primera del segundo para que estén sincronizados. El símbolo "<" es el texto que sale y el ">" el que entra
Y que a la segunda línea del primer archivo que no cambia, hay que añadirle la tercera del segundo archivo.

Otras formas de hacer los mismo es usando el parámetro -u que compara ambos programas línea por línea.

$ diff -u archivo_1.py archivo2_py
--- archivo_1.py	2022-08-15 18:15:18.939411615 +0200
+++ archivo_2.py	2022-08-15 18:15:31.091518676 +0200
@@ -1,2 +1,3 @@
-# version 0.1 
+# version 0.2 
 print("Hola Mundo")
+print("Esta es la segunda versión")

Y quizá la más intuitiva es la que lo compara a dos columnas:

$ diff -y archivo_1.py archivo2_py
# version 0.1 			|# version 0.2 
print("Hola Mundo")		   print("Hola Mundo")
				>  print("Esta es la segunda versión")

Aplicando Cambios.

Para guardar los cambios que ha habido de la versión 0.1 del programa a la 0.2 usaríamos la siguiente instrucción:

$ diff -u archivo_1.py archivo2_py > cambios.diff

Si ahora, por ejemplo, se nos borra el archivo_2.py pero conservamos el archivo con las diferencias podemos volver a generarlo con las siguiente instrucción.

$ patch archivo_1.py < cambios.diff

Esto nos dará el archivo_2.py que se nos había borrado.

Esto es especialmente útil cuando tienes un programa que contiene un error y que tu no localizas. Imagina que se lo pasas a un amigo que te lo soluciona. Este amigo genera un nuevo archivo con las diferencias "cambios.diff" y te lo reenvía. Tu aplicas la solución ejecutando el comando "patch" tal como vimos en el ejemplo anterior sobre tu archivo.

IMPORTANTE: estos comandos se pueden aplicar también sobre directorios.

No obstante imagínate el lio que supondría aplicar estos métodos cada vez que hayas realizado modificaciones significativas en tus programas. Para hacerlo de forma automática por ti están los controladores de versiones como es el caso de Git.


Instalando GIT, configuración y uso.


1.- Instalando GIT.

Primeramente debemos comprobar si tenemos Git instalado. Para ello podemos usar:

$ git --version
git version 2.34.1

Esto nos dice que tenemos la versión 2.34.1 instalada. 

Si no lo tuviésemos instalado, en Linux una de las formas de hacerlo es con:

$ sudo apt-get install git

Si no usas un gestor de paquetes entonces hay que ir a su página web y seguir las instrucciones.

En Ubuntu además puedes considerar instalar estos dos paquetes que te pueden ayudar aunques son opcionales:

- Gitk 

Es un navegador gráfico que se usa para ver de manera gráfica el historial de un repositorio git.

Se instala con:

$ sudo apt-get install gitk

Ejemplo con $ gitk -all sobre un repositorio.

gtik ejemplo

- Git-gui

Es un entorno gráfico para usar los comandos de git sobre los repositorios.

Se instala con:

$ sudo apt-get install git-gui

Ejemplo de uso de $git gui

git gui



2.- CONFIGURANDO GIT.

Una vez instalado lo primero que tenemos que hacer es configurarlo con nuestro nombre y correo electrónico:

$ git config --global user.email  micorreo@ejemplo.com

$ git config --global user.name  mi_nombre

Usamos el parámetro "--global" porque queremos usar estos valores para todos los repositorios que creemos. Si queremos usar un correo y nombre especifico para un proyecto concreto, dentro de ese proyecto usaremos la mima instrucción pero con el parámetro "--local".

Si quieres ver como está la configuración actual de Git puedes usar el siguiente comando:

$ git config -l  o $ git config --list


3.- INICIANDO EL REPOSITORIO.

Dentro de la carpeta del proyecto hay dos formas de iniciar git.

Si empezamos el repositorio desde cero:

$ git init

Sin argumentos nos crea una carpeta oculta .git en la carpeta de trabajo donde iran todos los archivos que git necesita para funcionar. Si le pasamos como argumento un nombre entonces nos crea una carpeta con ese nombre y dentro crea la carpeta oculta .git.

Si lo que queremos es hacer una copia de un repositorio ya existente en otro lugar, entonces usaremos:

$ git clone dirección@delrepositorio


Antes de continuar hay que aclarar estos tres conceptos:

escenarios en git

El directorio
. Ahí están todos los archivos del proyecto tanto los que queramos realizar un seguimiento como los que no. Es el directorio de trabajo con todos sus archivos y directorios.

Working Tree. En este mismo directorio, a todo lo que queremos realizar un seguimiento para controlar sus cambios, tanto si son archivos concretos como directorios, es lo que va a formar el llamado árbol de trabajo. Esta lleno de archivo que editas, donde se agregan nuevos archivos y de los que eliminamos archivos innecesarios. Cualquier cambio en el árbol de trabajo, queda registrado y se muestra como archivos o directorios modificados.

Stage. Es el lugar donde se guardan los cambios, para luego ser llevados definitivamente al repositorio cuando hagamos instantáneas del proyecto llamadas confirmaciones o commits en inglés.

Vamos a ver un pequeño ejemplo de como crear un repositorio desde cero. Primero creamos el directorio de trabajo (proyecto), entramos en él y posteriormente iniciamos el repositorio.

creación de un repositorio desde cero


4.- Añadir archivos al árbol de trabajo o rastrearlos.

Si queremos ir añadiendo archivos uno a uno.

$ git add [nombre_del_archivo]

Pasa los archivos del directorio al staging area.

Si queremos añadir todo el directorio. (el punto al final aquí es importante, no es una errata)

$ git add .


primer archivo añadido



En el ejemplo anterior creamos un archivo nuevo llamado main.py, que antes no estaba. Quise ver en que estado estaba para git. 

Lo realizamos con la sentencia:

$ git status

Git nos dijo como estaba el árbol de trabajo y la situación actual del repositorio. También que estamos en la rama "master", que aún no hemos hecho ningún "commit" y que tenemos un archivo sin seguimiento, que es el main.py vacío que hemos creado.

Lo añadimos al seguimiento con "git add" y como vemos después, otra vez con git status, el archivo aparece ahora en verde y está listo para acciones posteriores.


5.- Pasar los cambios del Working Tree al Stage.


Ahora que ya tenemos un repositorio git, lo hemos configurado y hemos creado un archivo. El siguiente paso es realizar algunos cambios en el mismo y confirmar instantáneas de esos cambios en el repositorio cada vez que el proyecto alcance un estado que quieras conservar.  Tendremos que poner todo lo que queramos que se conserve en el Stage Area "Escenario" para poder realizarle una instantánea.

Abre el archivo main.py e incluye algún comentario o algo de texto. 

Ahora queremos conservar nuestro proyecto tal como esta en este momento, con el comentario o texto que acabamos de añadir. Como hemos modificado el archivo que ya teníamos rastreado, si hacemos un "git status"  el programa nos avisa que tenemos un archivo que ya teníamos rastreado pero que hemos hecho cambios. Como queremos hacer la instantánea del archivo con el comentario nuevo introducido tenemos nuevamente que confirmar ese cambio para que el archivo pase del área de trabajo al Escenario (Stage).

Hacemos nuevamente:

$ git add main.py

Ahora si que podemos tomar la instantánea del proyecto ya que el archivo está en el staging area. Para conservar el repositorio tal como está en este momento y hacer la instantánea o foto del proyecto en su estado actual.

El comando a utilizar es:

$ git commit

Como ves este comando toma los archivo, directorios etc que están en el área de trabajo y crea el repositorio.

Al hacerlo se abrirá tu editor de texto por defecto, el mío en Ubuntu es nano y podrás escribir de forma detallada en que consisten las modificaciones, para que tu yo del futuro o cualquiera que lo lea pueda saber lo que se ha hecho.

El editor por defecto se puede modificar con:

$ git config --global core.editor <nombre_editor>                   (nano, vim, emac etc)

Existen unas reglas de estilo a seguir que brevemente son:

- La primera línea se pondrá una breve descripción de no más de 50 caracteres de lo que se ha hecho desde el último commit.

- Luego añadimos una descripción ya más detallada del mismo.

primer commit

Guardamos y ya está. 

Nota: Si no escribes nada o sales se aborta el commit.

Si el repositorio es para tí y no estás muy interesado en realizar una descripción detallada de los cambios puedes utilizar el comando:

$ git commit -m "texto con la descripción abreviada del cambio"

Por ejemplo:

$ git commit -m "Primer commit"

No te saldrá el editor de texto y el commit se guardará con el texto introducido.


Otro atajo para realizar los commits, puede ser también:

$ git commit -a 

Es un atajo para confirmar cualquier cambio en los archivos que tengamos rastreados y confirmarlos en un solo paso. Pero ¡Ojo! no realiza commit de los archivos nuevos, solamente de los que estén en seguimiento, es decir de aquellos que hayamos hecho un "git add [archivo]" primero.

Es una mezcla de "git add . + git commit"

Luego, para ver los comentarios de los commits usaremos el argumento "log". Hay varios parámetros que podemos usar.

El más sencillo es:

$ git log

chema@lenovo:~/proyecto$ git log
commit 168d6f4f8baa5c29310309b82c5e7b9232ff877d (HEAD -> master)
Author: usuario <usuario@correo.es>
Date:   Fri Sep 9 19:33:22 2022 +0200

    Proyecto inicial para aprender git básico
    
    Este es el commit o primera instantanea del proyecto. Hemos iniciado un
    repositorio, creado un archivo. Luego hemos añadido ese archivo al segui-
    miento de git. Añadimos un comentario volvimos a confirmar los cambios y
    realizamos el primer commit.

$ git log --stat

Muestra estadísticas de los commits.

chema@lenovo:~/proyecto$ git log --stat
commit 168d6f4f8baa5c29310309b82c5e7b9232ff877d (HEAD -> master)
Author: usuario <usuario@correo.es>
Date:   Fri Sep 9 19:33:22 2022 +0200

    Proyecto inicial para aprender git básico
    
    Este es el commit o primera instantánea del proyecto. Hemos iniciado un
    repositorio, creado un archivo. Luego hemos añadido ese archivo al segui-
    miento de git. Añadimos un comentario volvimos a confirmar los cambios y
    realizamos el primer commit.

 main.py | 1 +
 1 file changed, 1 insertion(+)

$ git log -p 

Nos indica los cambios entre commits, equivalente a la salida de la instrucción "diff -u" que vimos al principio del capitulo. Página la salida.

chema@lenovo:~/proyecto$ git log -p
commit 168d6f4f8baa5c29310309b82c5e7b9232ff877d (HEAD -> master)
Author: usuario <usuario@correo.es>
Date:   Fri Sep 9 19:33:22 2022 +0200

    Proyecto inicial para aprender git básico
    
    Este es el commit o primera instantánea del proyecto. Hemos iniciado un
    repositorio, creado un archivo. Luego hemos añadido ese archivo al segui-
    miento de git. Añadimos un comentario volvimos a confirmar los cambios y
    realizamos el primer commit.

diff --git a/main.py b/main.py
new file mode 100644
index 0000000..1274ace
--- /dev/null
+++ b/main.py
@@ -0,0 +1 @@
+# comentario

$ git log --oneline

Muestra cada commit que hayamos hecho en una sola línea, con lo que es más fácil de ver.


$ git show [id]

Lo mismo que el comando anterior pero mostrando solamente el último commit realizado. Si se introduce un ID concreto nos muestra solamente ese. El ID es el número largo que aparece después del commit, (en el siguiente ejemplo el ID es 168d6f4f8baa5c29310309b82c5e7b9232ff877d. Se puede usar abreviadamente los 6 primeros caracteres, en vez de teclear el número entero.)

chema@lenovo:~/proyecto$ git show
commit 168d6f4f8baa5c29310309b82c5e7b9232ff877d (HEAD -> master)
Author: usuario <usuario@correo.es>
Date:   Fri Sep 9 19:33:22 2022 +0200

    Proyecto inicial para aprender git básico
    
    Este es el commit o primera instantanea del proyecto. Hemos iniciado un
    repositorio, creado un archivo. Luego hemos añadido ese archivo al segui-
    miento de git. Añadimos un comentario volvimos a confirmar los cambios y
    realizamos el primer commit.

diff --git a/main.py b/main.py
new file mode 100644
index 0000000..1274ace
--- /dev/null
+++ b/main.py
@@ -0,0 +1 @@
+# comentario

$ git diff (archivo) 

Equivale al comando "diff -u" que vimos al principio, para comparar las diferencias entre dos versiones del mismo archivo. Nos muestra los cambios en los archivos en seguimiento PERO teniendo en cuenta el último commit y antes de realizar uno nuevo. Se le puede especificar tambien el nombre de un archivo en concreto.

$ git add -p  

Para confirmar las modificaciones realizadas a los archivos, antes de hacer el commit. En vez de realizar las confirmaciones de los cambios en los archivos de forma automática nos muestra los cambios y nos permite confirmarlos o no. Es como "git add" pero nos permite ver antes los cambios y confírmalos para añadirlos al stage.

chema@lenovo:~/proyecto$ git add -p
diff --git a/main.py b/main.py
index 3808744..91479a0 100644
--- a/main.py
+++ b/main.py
@@ -1,2 +1,2 @@
 # comentario

(1/1) Stage this hunk [y,n,q,a,d,e,?]? 

$ git diff --staged

Para ver los cambios en el stage pero que aún no tienen commit.