¿Qué es un Sistema de Control de Versiones (SCV)?
-
Se trata de un software que nos permite conocer información de las modificaciones que vamos haciendo a nuestro software.
-
En los
scv
de hoy en día esta información se aplica como un todo al conjunto de archivos de nuestro producto que hemos ido modificando de alguna manera. -
Con estas modificaciones podemos:
-
Mantener la ultima versión de los archivos que queramos.
-
Volver a alguna versión anterior…no necesariamente la última.
-
Aislarlas para poder proporcionarlas a otro desarrollador como un parche.
-
-
Pero si nos fijamos detenidamente, todo esto puede hacerse manualmente…
¿En qué consiste el control de versiones?
- ¿Qué nos aportan realmente?
-
-
La gestión automática de los cambios que se realizan sobre uno o varios ficheros de un proyecto.
-
Restaurar cada uno de los ficheros de un proyecto a un estado de los anteriores por los que ha ido pasando (no solo al inmediatamente anterior).
-
Permitir la colaboración de diversos programadores en el desarrollo de un proyecto.
-
Un histórico de las acciones llevadas a cabo, cúando y por quién…cosa muy útil cuando un proyecto es desarrollado por varias personas de manera simultanea.
-
Conceptos generales de los SCV (I)
- Repositorio
-
Es la copia maestra donde se guardan todas las versiones de los archivos de un proyecto.
- Copia de trabajo
-
La copia de los ficheros del proyecto que podemos modificar. Cada desarrollador tiene la suya propia.
- Check Out / Clone
-
La acción empleada para obtener una copia de trabajo desde el repositorio. En los
scv
distribuídos -como Git- esta operación se conoce como clonar el repositorio por que, además de la copia de trabajo, proporciona a cada programador su copia local del repositorio a partir de la copia maestra del mismo. - Check In / Commit
-
La acción empleada para llevar los cambios hechos en la copia de trabajo a la copia local del repositorio -CheckIn-. Esto crea una nueva revisión de los archivos modificados. Cada commit debe ir acompañado de un Log Message el cual es un comentario -Una cadena de texto que explica el commit- que añadimos a una revisión cuando hacemos el commit oportuno.
Conceptos generales de los SCV (II)
- Push
-
La accion que traslada los contenidos de la copia local del repositorio de un programador a la copia maestra del mismo.
- Update/Pull/Fetch+Merge/Rebase
-
Acción empleada para actualizar nuestra copia local del repositorio a partir de la copia maestra del mismo, además de actualizar la copia de trabajo con el contenido actual del repositorio local.
- Conflicto
-
Situación que surge cuando dos desarrolladores hacen un commit con cambios en la misma región del mismo fichero. El
scv
lo detecta, pero es el programador el que debe corregirlo. - Etiquetar
-
Poner un nombre común a todos los ficheros bajo control de versiones de un proyecto en un instante determinado.
- Rama
-
Representa una línea de evolución de nuestro software. Podemos tener todas las que queramos, pero normalmente una es especial: trunk, master/main, etc…
Tipos de SCV.
- Por la forma de almacenar los contenidos
-
-
Centralizados. Hay un único repositorio compartido por todos los desarrolladores. Sólo un responsable o grupo de responsables pueden llevar a cabo tareas administrativas en este repositorio. Es el caso de CVS y Subversion.
-
Distribuidos: Cada usuario tiene su propio repositorio. Los repositorios de todos los desarrolladores del proyecto pueden intercambiar información entre ellos. Es habitual disponer de un repositorio central que sirve como sincronización entre todos los repositorios de los desarrolladores. Es el caso de git, mercurial, bazaar, monotone, etc…
-
- Por la forma de modificar los contenidos de la copia local
-
-
Colaborativos: Varios desarrolladores pueden estar modificando el mismo fichero simultáneamente. Puden aparecer conflictos por modificar varios desarrolladores la misma parte del archivo. Es el caso de git o mercurial.
-
Exclusivos: Sólo un desarrollador puede estar modificando un archivo a la vez, el resto sólo pueden leerlo. Una vez se han pasado los cambios al repositorio entonces ya lo puede modificar otro desarrollador, pero nuevamente sólo uno. Es el caso de RCS o de SourceSafe.
-
Centralizados vs. Distribuidos en 90sg
¿Qué opciones tenemos disponibles?
- Hoy en día disponemos de muchos y diversos scv
-
¿Qué podemos hacer con un SCV?
- Operaciones basicas
-
-
Crear un repositorio
-
Clonar un repositorio
-
Actualizar un repositorio local con cambios remotos
-
Crear un commit
-
Actualizar un repositorio remoto con cambios locales
-
Crear una rama local y hacerla más tarde remota.
-
Importar cambios de una rama en otra.
-
Tipos de ramas
- Ramas de largo recorrido
-
-
Por lo general indican distintas versiones estables de nuestro software (v1.0, v2.0, etc…)
-
Es el caso de ramas como master/main o trunk.
-
Algunos proyectos disponen de ramas que complementan a las anteriores: next, proposed, pu (
proposed updates
).
-
- Ramas puntuales
-
-
Son ramas que se crean para trabajar en ellas en un solo aspecto. En inglés se las suele llamar Topic Branches.
-
Puede representar la corrección de un fallo, el añadido de una característica nueva o incluso probar algo de forma experimental.
-
Algunos desarrolladores emplean un prefijo en su nombre para identificar para qué se crearon:
-
Tip: Una idea (
tip-speedincrease
,tip/memsizereduction
, etc…) -
Wip: Work in Progress (
wip-bugdetection
, etc…) -
Hotfix: Arreglo de un fallo (
hotfix/segfault
) -
Iss: Un asunto (issue) identificado -fallo, nueva característica, etc…- (
iss32
,iss32v2
, etc..)
-
-
Formas de integrar una rama en otra (I)
Mezcla
master: A--B--C topic: A--B--C \ X--Y--Z (1) El tiempo pasa: A--B--C--D--E--F (2) \ X--Y--Z mezcla: A--B--C--D--E--F--M (3) \ / X--Y--Z
1 | Rama tópico |
2 | Tres nuevos commits en master |
3 | Un nuevo commit M representa la mezcla |
Formas de integrar una rama en otra (II)
Rebasamiento
-
No todos los scv disponen de esta posibilidad.
-
Aplicado al ejemplo anterior…obtendríamos esta nueva situación:
master: A--B--C topic: A--B--C \ X--Y--Z (1) El tiempo pasa: A--B--C--D--E--F (2) \ X--Y--Z mezcla: A--B--C--D--E--F (3) \ X'--Y'--Z'
1 | Misma rama tópico |
2 | Mismos tres nuevos commits en master |
3 | La rama tópico se trasplanta de su antiguo commit origen (C) al nuevo (F). |
lineal
:A--B--C--D--E--F--X'--Y'--Z'
-
Echa un vistazo a este vídeo que explica de forma sencilla la diferencia entre
rebase
ymerge
:
SCV’s con los que trabajaremos
-
Nos vamos a centrar en tres de ellos. Todos serán distribuídos, ya que con uno distribuído podemos simular el uso de uno centralizado.
-
Veremos una breve introducción a cada uno…incluso alguna característica especial que posean.
-
Veremos como llevan a cabo las operaciones básicas que hemos descrito anteriormente.
Los tres scv’s que emplearemos son:
-
git
-
bazaar
-
mercurial
Git (I)
-
Los desarrolladores del núcleo
linux
emplean BitKeeper hasta 2005. En este enlace puedes ver la historia del origen degit
. -
BitKeeper es un scv distribuído. Git también lo es, al igual que
Darcs
,Mercurial
oBazaar
yMonotone
. -
Linus comienza el desarrollo de
git
el 3 de abril de 2005, lo anuncia el dia 6 de abril. -
Git se auto-hospeda el 7 de abril de 2005.
-
Consta de herramientas de bajo de nivel (plumbing) y de alto nivel (porcelain). Estas últimas son las que se emplean habitualmente e internamente llaman a las de bajo nivel.
-
Cada nuevo commit creado en git es una
foto
de nuestro proyecto en ese instante…identificada por un número…su clave SHA-1. -
El algoritmo SHA-1 ya no es considerado seguro y Git ya está implementando el soporte de SHA-256. También tienes más información aquí(2020) y aquí(2022).
Git (II)
-
Toda la metainformación de git se guarda en un directorio que reside en la carpeta raíz de nuestro proyecto y que se llama .git:
.git |-- branches |-- COMMIT_EDITMSG |-- config |-- description |-- FETCH_HEAD |-- gitk.cache |-- HEAD |-- hooks |-- index |-- info |-- logs |-- objects |-- ORIG_HEAD +-- refs
Git (III)
- Uso
-
-
Al igual que ocurre con todas las herramientas de este tipo, existe una órden (
git
) que admite diferentes subórdenes. -
El primer uso que podemos hacer de ella es para saber la versión de
git
que tenemos instalada.
-
git --version
-
O para iniciar el repositorio local de un proyecto:
git init proyecto
-
funcionamiento habitual…
git add . git status git commit -m "Primer commit." -m "Descripcion detallada." git commit -a
-
Hablando de
commit
…-
Qué hace la opción
-p
de la ordenadd
?:-p, --patch Interactively choose hunks of patch between the index and the work tree and add them to the index. This gives the user a chance to review the difference before adding modified contents to the index. This effectively runs add --interactive, but bypasses the initial command menu and directly jumps to the patch subcommand. See “Interactive mode” for details.
-
Probémoslo con este ejemplo:
-
#include <stdio.h>
int main() {
float r = 1.2;
// float s = 0.0;
// r /= s;
printf("Hola!\nEl valor calculado es %f\n", r);
// return 0;
}
Git (IV)
- Configuración local
-
-
Se lleva a cabo en un archivo local al proyecto. Se trata de un archivo de texto.
-
Por tanto cada proyecto puede tener su configuración local
.git/config
-
- Configuración global
-
-
Se lleva a cabo en un archivo particular para cada usuario del s.o. Se trata de un archivo de texto con el mismo formato que en el caso anterior.
-
Por tanto cada usuario puede tener su configuración global para todos sus proyectos
~/.gitconfig
-
O más recientemente en
~/.config/git/config
-
- Ejemplos de configuración
git config user.name "nombre apellidos" git config user.email "usuario@email.com" ... git config --global user.name "nombre apellidos" git config --global user.email "usuario@email.com"
Git (V)
- Ramas
-
-
Es una de las características más valoradas en git. La facilidad para el trabajo con ramas.
-
Además es barato trabajar con ramas…a diferencia de otros
scv
-
git branch [-a] [-r] git show-branch ... git checkout [-b] [rama-de-partida] git switch rama git log [-p]
- Estado
git status git log ... git show git diff
Git (VI)
- Descartar cambios
git reset --hard git checkout rama|hash -- ruta-archivos git restore ruta-archivos
- Repositorios remotos
git remote add nombre protocolo git remote add origin maquina:ruta/hasta/repo ... [ssh] [http] [git] [git+ssh] git clone maquina:ruta/hasta/repo
- Operaciones con repositorios remotos
git pull [origin] [rama] git push [repo] [rama] git checkout -b rama origin/rama-remota git checkout -t origin/rama-remota git checkout --orphan rama git fetch git merge git pull = git fetch + git merge git rebase otra-rama
git merge
puede mezclar más de dos ramas/commits-
-
En ese caso se habla de octopus merge.
-
aquí tienes un récord difícil de batir.
-
Git (VII)
- Stash
-
-
Imagina…estás modificando tu copia de trabajo…montones de archivos modificados (sin hacer un commit aún) desde el último
pull
. -
En ese preciso instante, tu compañer@ -al/la que tanto aprecias- te dice que la actualices desde el repositorio original porque acaba de subir unos cambios…importantisimos…Ah!…y
HAZLO YA
!! -
Ok…lo que tu digas:
git stash git pull git stash pop
-
Git (VIII)
- Worktree
-
-
Se puede usar como una alternativa a stash.
-
Permite tener activas simultáneamente varias copias de trabajo a partir de un mismo repositorio.
-
En este vídeo puedes ver de forma resumida su funcionamiento.
-
El API principal se puede resumir en:
git worktree add git worktree list git worktree remove
-
Git (IX)
- Bisect
-
-
¿Bi-qué?…búsqueda B-I-N-A-R-I-A entre los commits.
git bisect start git bisect bad # la version actual esta mal git bisect good commit/tag # una version que sabemos que funciona
-
Después de ir alternando entre commits buenos y malos estaremos parados en el último commit entre los dos originales que introdujo el cambio erróneo. Para volver al estado original del que hemos partido:
git bisect reset
-
…There’s one more thing!
git bisect run mi-guion argumentos
"
mi-guion
" es un guión de shell que devuelve0
,1..124
,126
,127
-
Actualmente (noviembre 2021) se está proponiendo añadir una variante llamada bisección estocástica.
-
En marzo de 2022 se descubrió el fallo CVE-2022-0847 en el núcleo Linux. Desde que se introdujo el fallo en el núcleo hasta que se detectó se habían añadido al código fuente 185.011 commits…adivina como se encontró.
-
Y también puedes comprobar ("https://lwn.net/ml/linux-kernel/CAHk-=wgWcYX2oXKtgvNN2LLDXP7kXkbo-xTfumEjmPbjSer2RQ@mail.gmail.com") como en enero de 2024 el propio Linux Torvalds lo emplea durante la etapa de desarrollo de la versión 6.8 del núcleo Linux.
-
En este vídeo puedes ver una explicación de como se emplea.
-
Git (X)
- Cherry-Picking
-
-
Al hacer un
merge
o unrebase
…aplicamos varioscommits
simultáneamente… -
¿Y si queremos solo uno?..
git cherry-pick 7a2ed53 git cherry-pick master
-
- Shortlog
-
-
Resume la salida de
git log
en un formato apropiado para anuncios de nuevas versiones… -
Pero también es apropiado para extraer información sobre el trabajo de los desarrolladores. Prueba esto:
git shortlog -s -n --all --no-merges
-
Git (XI)
- Aliases
-
-
Podemos crear alias para órdenes+opciones que usemos habitualmente…
-
git config --global alias.co checkout git config --global alias.ci commit git config --global alias.st status git config --global alias.br branch git config --global alias.hist 'log --pretty=format:"%h %ad | %s%d [%an]" --graph --date=short' git config --global alias.type 'cat-file -t' git config --global alias.dump 'cat-file -p'
-
Y lo que esto hace realmente es añadir a
~./gitconfig
o a~/.config/git/config
estas líneas:
[alias] co = checkout ci = commit st = status br = branch hist = log --pretty=format:\"%h %ad | %s%d [%an]\" --graph --date=short
Git (XII)
Si tu shell lo permite…aún puedes abreviar más… , ten en cuenta
que esto no específico de git .
|
# mira en ~/.profile , ~/.bashrc o en ~/.bash_aliases # Consulta la documentacion de tu shell. alias gs='git status ' alias ga='git add ' alias gb='git branch ' alias gc='git commit' alias gd='git diff' alias go='git checkout ' alias gk='gitk --all&' alias gx='gitx --all' alias got='git ' alias get='git '
- Un ejemplo
-
go <branch>
-
Y aquí tienes alguno más.
-
Git (XIII)
- Detached HEAD
-
-
No solo podemos cambiar de rama…sino volver a un punto concreto en el pasado.
-
Esto produce una rama-virtual cuya cabeza es el numero-hash que hemos indicado:
-
$ git checkout 415e7c2 Note: checking out '415e7c2'. 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 performing another checkout. If you want to create a new branch to retain commits you create, you may do so (now or later) by using -b with the checkout command again. Example: git checkout -b new_branch_name HEAD is now at 415e7c2... First Commit $ cat message.txt Hello, World
Git (XIV)
- Etiquetas / Tags
-
-
Los número que genera
SHA1
para cada commit, no proporcionan mucha información a las personas. -
Nos puede interesar más asociar un texto significativo a un hash, algo que represente una información para nosotros, p.e.:
v1.0
. -
Eso se hace con la orden
tag
de git.git tag v1.0
-
Si no indicamos nada…etiquetamos el último commit de la rama actual.
-
A partir de este momento podemos emplear esa etiqueta en lugar del hash asociado al commit que la tiene, p.e:
git checkout v1.0 ... git checkout v1.0~3
-
La órden
git tag
sin parámetros lista las etiquetas que tenemos puestas.
-
Git (XV)
- Bare repos
-
-
Es el término que se emplea en git para referirse al repositorio local de un proyecto…al directorio
.git
. -
No tienen copia de trabajo, sólo metadatos.
-
Algunas opciones (como
clone
) permiten trabajar con ellos:
-
$ git clone --bare hello hello.git Cloning into bare repository hello.git... done. $ ls hello.git HEAD config description hooks info objects packed-refs refs
-
Habitualmente -y para identificarlos fácilmente- estos repositorios se suelen llamar como el proyecto que representan y con la extensión
.git
, p.e.:hola-mundo.git
.
Git (XVI)
- Hooks
-
-
Los
hooks
son guiones que se ejecutan automáticamente antes o después de determinadas acciones comocommit
,push
, etc… -
Por ejemplo, en el
hook
pre-commit podríamos comprobar si el mensaje tiene errores ortográficos o lo que hacen el proyecto Godot Engine. -
Cada vez que creamos un repositorio git, disponemos del directorio
.git/hooks
donde ya hay ejemplos de estos guiones:
-
applypatch-msg.sample post-update.sample pre-commit.sample pre-push.sample update.sample commit-msg.sample pre-applypatch.sample prepare-commit-msg.sample pre-rebase.sample
-
Puedes tomar cualquiera de ellos como punto de partida, eso sí:
-
Quítales el sufijo
.sample
-
Dales permiso de ejecución si no lo tienen
-
-
Para tener más información de cada uno de ellos ejecuta:
git help hooks
Git (XVII)
- Reflog
-
-
Es la manera en la cual git guarda información de cuándo se actualizan las "cabezas" de las ramas.
git reflog git reflog show [rama | --all]
-
Para referirse a los commits emplea la notación:
rama@{referencia}
master@{5} (1) tip/speedincrease@{17} (2) bugfix/badcss@{one.month.ago} (3)
-
1 | Dónde apuntaba master hace 5 movimientos. |
2 | Dónde apuntaba tip/speedincrease hace 17 movimientos. |
3 | Dónde apuntaba bugfix/badcss hace un mes. |
Se puede usar, por ejemplo, para recuperar
commits
perdidos. Ten en cuenta que reflog
almacena estos commits por
defecto un máximo de 30 dias, consulta
git reflog.
Git (XVIII)
- Clean
-
-
Elimina de la copia de trabajo los archivos que no están bajo control de versiones. ¡Lleva cuidado al usarla! git clean.
-
- Fsck
-
-
Dado que git se puede ver como un sistema de ficheros indexado por contenido…también tiene su herramienta fsck o chkdsk correspondiente: git fsck.
-
Si alguna vez la tienes que usar echa un vistazo a esta otra: git-repair.
-
- Gc
-
-
Elimina ficheros usados por
git
para el mantenimiento del repositorio. También optimiza el repositorio para su uso habitual: git gc.
-
Git (XIX)
Git (XX)
-
Si necesitas renombrar una rama ya publicada y compartida entre los desarrolladores del proyecto, no está de más que veas como lo ha hecho Federico Mena Quintero con la rama master del proyecto librsvg.
-
También es recomendable que leas la guía de estilo de git.
-
Consulta esta propuesta de especificación de commits para que sean fácilmente legibles por las personas y, al mismo tiempo, procesables por herramientas informáticas. O esta otra hecha por el propio Linus Torvalds donde propone escribir mejores mensajes asociados a los commits, para ello da unas guías relativas al formato y al lenguaje empleados en estos mensajes.
-
Y si crees que conoces a fondo cómo funciona Git te recomiendo que eches un vistazo a este artículo. Te sorprenderá.
Git (XXI): submodules / subtrees
-
Son dos elementos muy importantes cuando queremos usar nuestro proyecto (bajo control con git) con otro u otros proyectos que también están controlados por git.
-
No es tan sencillo como clonar el otro proyecto en una carpeta dentro del nuestro…piensa a que puede ser debido.
-
Git nos proporciona una manera oficial de hacerlo:
-
Y existe un proyecto externo que usa subarboles
-
Y aquí tienes un resumen/comparativa de ambos métodos.
Compatible con Git
Sapling began 10 years ago as an initiative to make our monorepo scale in the face of tremendous growth. Public source control systems were not, and still are not, capable of handling repositories of this size. Breaking up the repository was also out of the question, as it would mean losing monorepo’s benefits, such as simplified dependency management and the ability to make broad changes quickly. Instead, we decided to go all in and make our source control system scale.
-
Han procurado que sea compatible con git a nivel de órdenes.
-
Pero tiene sus diferencias.
Para terminar con Git
-
Si eres un usuario asiduo de
github
te recomiendo que veas -
las valoraciones que esta herramienta hace de los repositorios alojados alli.
-
Las sugerencias de plantillas para archivos .gitignore que tiene.
Mercurial (I)
-
web del proyecto.
-
Su nombre le viene del término hidrargirio
-
Es un
scv
distribuído. Es software libre. Disponible en OS-X, Windows y GNU/Linux. -
Surge aproximadamente a la vez que git, las órdenes que entiende se llaman prácticamente de la misma forma. Escrito en python y partes en
C
. -
Dado que funciona de manera similar a
git
los flujos de trabajo que tenemos disponibles son similares a los que ya conocemos degit
. -
Toda la información relativa al control de versiones de un proyecto se guarda en el directorio raíz del proyecto, concretamente en el subdirectorio "
.hg
". -
La configuración general para cada usuario se guarda en
~./hgrc
y la configuración local para cada proyecto se guarda en<repo>/.hg/hgrc
.
Mercurial (II)
hg clone http://github.com/repo/hola-mundo
cd hola-mundo
(editar ficheros)
hg add (nuevos ficheros)
hg commit -m 'Cambios'
hg push
hg init (directorio del proyecto)
cd (directorio del proyecto)
(Anyadimos archivos..)
hg add
hg commit -m "Primer commit"
Mercurial (III)
-
Admite el añadido de extensiones
-
Podemos ver las extensiones disponibles con:
hg help extensions
-
Pedir información de una de ellas con:
hg help nombre-extension
-
Las extensiones se deben habilitar, p.e. en
.hg/hgrc
:[extensions] foo = # Podemos especificar la ruta concreta [extensions] myfeature = ~/.hgext/myfeature.py
Mercurial (IV)
-
También se pueden deshabilitar de una en una:
[extensions] # disabling extension bar residing in /path/to/extension/bar.py bar = !/path/to/extension/bar.py # ditto, but no path was supplied for extension baz baz = !
-
En la instalación de
mercurial
vienen estas extensiones por defecto, pero también disponemos de otras hechas por terceros. Por cierto…¿a qué te suena la extensión shelve?
Mercurial (V)
-
Para dar de alta un nuevo repositorio en un proyecto, edita su
<proyecto>/.hg/hgrc
y añade una nueva entrada enpaths
así:
[paths] default = http://www.hgrepos.net/r1 (1) default-push = ssh://dca@hgrepos.net/r1 (2) ... alias1 = URL1 alias2 = URL2
1 | Es especial, se usa como valor por defecto cuando no especificamos
la URL . |
2 | Idem pero cuando hacemos un push .
|
<<<<<<< /tmp/conflict/crab.cpp void function() { ======= int function() { >>>>>>> /tmp/crab.cpp
Mercurial (VI)
-
Si usas subversion, quizás te sean útiles hgsubversion y también estos guiones.
-
Estas otras aplicaciones también pueden serte útiles al emplear mercurial:
-
hgview, tiene una variante en modo texto llamada
hgview-curses
(algo menos completa).
-
-
Dispones también del libro de mercurial y de una guía.
-
Si usas
Eclipse
te puede interesar este plugin. Otros editores/IDEs también disponen de plugins para trabajar con mercurial.
Mercurial vs. Git
De los creadores de Git is MacGyver and Mercurial is James Bond
- Git vs. Mercurial
-
-
En Git los objetos con los que trabaja son:
blob
,tree
ycommit
. -
Mercurial usa los mismos conceptos pero los llama:
file
,manifest
ychangeset
. -
Ambos
scv
's usan una claveSHA-1
para identificar estos tres tipos de objetos. Mercurial llama a esta clave nodeid. -
Ambos ven la historia del proyecto como un Grafo Acíclico Dirigido.
-
Mercurial distingue entre dos tipos de ramas: ramas con nombre y clones de repositorios.
-
Mercurial además de la clave SHA-1 asociada a un changeset genera un número de revision local.
-
Mercurial no necesita añadir los cambios de los archivos al índice (
stage
) como git.
-
Mercurial. Vídeos relacionados
Bazaar (I) . It just works
-
web del proyecto.
-
En ocasiones se le llama Bazaar-NG (New Generation) ya que es una reimplementación de GNU Arch
-
El nombre le viene de un ensayo publicado por Eric S. Raimond: The Cathedral and the Bazaar: Musings on Linux and Open Source by an Accidental Revolutionary.
-
En la propia web del proyecto se nos dan 10 razones para usar
bazaar
. -
Como mercurial, se puede ampliar su funcionalidad con plugin’s.
-
Toda la información relativa al control de versiones de un proyecto se guarda en el directorio raíz del proyecto, concretamente en el subdirectorio "
.bzr
".
Bazaar (II)
- Funcionamiento
-
-
Creamos e iniciamos un repositorio:
bzr init repo-bzr
-
Trabajamos en él:
cd repo-bzr edit file1 file2 ... bzr add file1 file2 ... bzr status bzr ignore *~ bzr alias commit="commit --strict"
-
Bazaar (III)
-
Creamos un commit y vemos el
log
:bzr commit -m "Anyadido hola.txt" hola.txt bzr log
bzr log ------------------------------------------------------------ revno: 1 committer: Fernando Perez <fperez@ua.es> branch nick: repo-bzr timestamp: Mon 2013-12-16 20:59:22 +0100 message: Anyadido hola
-
Probamos a actualizar nuestra copia de trabajo
bzr update
Bazaar (IV)
-
Las ramas viven en su propio directorio.
bzr branch . rama2 bzr branch rama2 display cd rama2; edit hola.txt bzr commit -m "decimos adios" Committing to: /home/fernando/repos/repo-bzr/rama2/ modificado hola.txt Committed revision 2.
cd ../display bzr merge ../rama2
M hola.txt Todos los cambios se aplicaron correctamente.
bzr status modified: hola.txt pending merge tips: (use -v to see all merge revisions) Fernando Perez 2013-12-16 decimos adios
Bazaar (V)
- Algunas características especiales
-
-
Hosting recomendado: https://launchpad.net/ o también http://savannah.gnu.org/
-
Cliente con interfaz gráfica de usuario: bazaar explorer
-
Unity3D es un motor de juegos en 3D que permite configurar bazaar como herramienta de control de versiones para sus proyectos.
-
- Configuración
-
-
En el directorio
$HOME/.bazaar
, en tres archivos:-
bazaar.conf
-
locations.conf
-
authentication.conf
-
-
Obtenemos información de la configuración con:
bzr config
-
Modificamos la configuración con:
bzr config opt=value bzr config --remove opt
-
Bazaar. Vídeos relacionados
Git vs. Mercurial vs. Bazaar
-
A lo largo del tema no hemos tratado de presentar un ganador, tan sólo ver tres implementaciones diferentes de una misma tecnología: sistemas de control de versiones distribuídos
-
Al terminar este tema sí que deberíais tener una serie de criterios para ayudaros a decidir qué scv deberías emplear.
-
Si aún así no fuera suficiente, quizás esta web y esta otra puedan ayudarte un poco más.
Prácticas individuales
Git
-
Crea (si no tienes ya) una cuenta en github, gitlab, codeberg, sourcehut o bitbucket. Una vez hecho da de alta un proyecto/repositorio y configura git localmente para que puedas hacer push/pull a él.
-
Créate algunos alias locales y globales en git.
-
Crea varias ramas locales y súbelas como remotas al repositorio creado en el primer paso.
-
Provoca un fallo en el software en un commit de manera que después de crear varios commits más puedas encontrarlo con
git bisect
. -
Haz uso de algún
hook
de git.
-
Debes entregar la carpeta del proyecto gestionado con git comprimida en formato
tgz
. -
Si necesitas aclarar algo de las órdenes empleadas (por ejemplo cómo has usado bisect) usa un archivo de texto llamado
readme.txt
donde puedes explicar y aclarar lo que consideres oportuno. -
La práctica se entregará en pracdlsi en las fechas allí indicadas.
Prácticas en grupo
-
Qué es breezy? En qué se diferencia de otros SCV?
-
Qué es pijul? En qué se diferencia de otros SCV? A qué SCV de versiones se parece?
-
Explicadnos qué es SVK.
-
Explicadnos qué es Tailor.
-
Explicadnos qué son los submódulos en git. Presentadnos algún ejemplo de uso.
-
Explicadnos qué es git-annex. Poned algún ejemplo de uso.
-
git-town complementa git de distintas formas. Contadnos cómo lo hace.
-
Bazaar dispone de bound branches…tratad de explicarnos qué son.
Aclaraciones
-
Debes estudiar, aclarar y ampliar los conceptos que en ellas encuentres empleando los enlaces web y bibliografía recomendada que puedes consultar en la página web de la ficha de la asignatura y en la web propia de la asignatura.