Abr 24
VC (Version Control) en emacs
Emacs provee de un front-end que agiliza el uso de control de versiones, dicha feature se llama VC (Version Control) y permite usar de forma generalizada distintos controles de versiones mediante una misma interfaz. Los controles de versiones soportados son SCCS, RCS, CVS, SVN, GIT y demás, aunque algunos de ellos no estan adaptados perfectamente o requieren de algún otro front-end más específico para ellos mismos, como es el caso de emergente GIT.
Modelo tradicional vs concurrente
Existen dos modelos basicos a hora de trabajar con controles de versiones, uno es el tradiciona y otro el concurrente que muestro a continuacion para notar las diferencias:
Modelo tradicional:
Modelo concurrente:
(Imágenes extraidas del libro ‘Learning GNU Emacs’, 3rd Edition by Debra Cameron, James Elliot, Marc Loy. O’Reilly)
Por lo que puede existir algún problema durante los procesos de check in debemos intentar resolverlos mediante M-x vc-resolve-conflicts. A partir de aquí podemos comenzar a explicar las siguientes tareas típicas y los keybindings asociados a un proceso general de desarrollo.
C-c C-c; commit del buffer comentado.
C-x v u: ‘vc-revert-buffer‘; revisa los cambios realizados desde el último check in.
C-x v c: ‘vc-cancel-version‘; cancela una revisión.
Indicadores VC
En el modeline se pueden mostrar los siguientes indicadores:
Si no muestra nada indica que no se está bajo VC.
CVS-version cambiado respecto al repositorio.
CVS:version cambios guardados pero no committeados.
Además debemos comprobar la variable ‘vc-handeled-backends’ que revisa cuál es el control de versiones disponible en el sistema que puede ser:
comb: el control de versiones empleado en el sistema es SCCS.
rcs: el control de versiones empleado en el sistema es RCS.
cvs: el control de versiones empleado en el sistema es CVS.
snv: el control de versiones empleado en el sistema es SNV.
Trabajando con grupos y directorios
C-x v d: ‘vc-directory‘; configura dired para registrar ficheros bajo el directorio actual.
Reporte de revisiones
C-x v =; ‘vc-diff‘; configura dired para mostrar los diffs y presionando ‘g‘ refresca el estado de VC en el directorio.
C-u C-x v =; muestra el fichero y dos revisiones para reportar diffs entre dichas versiones del fichero.
C-x v ~: ‘vc-version-other-window‘; realiza la revisión de cualquier fichero guardado.
Si estamos en foo.c y pulsamos C-x v ~ 1.3 abrirá el fichero foo.c~1.3~ (es decir la version 1.3 de dicho fichero).
Historial de cambios
C-x v l: ‘vc-print-log‘; muestra cambios en el historial y changelog.
C-x v a: ‘vc-update-change-log‘; actualiza el fichero changelog al estilo GNU.
Registrando un fichero
C-x v i: ‘vc-register‘; registrar un fichero en el control de versiones.
Insertando cabeceras del control de versiones
C-x v h: ‘vc-insert-headers‘; inserta cabeceras de control.
Además existe la variable ‘comment-start‘ y ‘comment-end‘ que puede tomar uno de estos tres valores: nroff, troff. groff.
Creando y recuperando snapshots
C-x v r: ‘vc-retrieve-snapshot‘; hace check out del snapshot del proyecto de desarrollo o lo que es lo mismo, asocia un nombre un snapshot nuevo.
C-x v s: ‘vc-create-snapshot‘; crea un nuevo snapshot del proyecto de desarrollo.
Renombrando ficheros
‘vc-rename-file‘; dicha función renombra un fichero bajo el control de versiones. Aunque en algunos controles de versiones da problemas, por lo que si ocurre debemos realizar de nuevo la acción limpiando la cache mediante ‘vc-clear-context‘.
Configurando VC
Las siguientes variables pueden modificarse para alterar el funcionamiento y configuración de VC:
‘vc-display-backends‘; maneja el control de versiones usado por VC.
‘vc-display-status‘; muestra el número de revisión y su estado.
‘vc-backend-header‘; contiene un listado de cabeceras dado por la variable ‘vc-cvs-header‘, etc.
‘vc-keep-workfiles‘; evita tener que hacer check out cada vez.
‘vc-mistrust-permissions‘; si se pone a ‘t‘ le indica a VC que no confie en los permisos del fichero local, sino en los del control de versiones.
‘vc-suppress-confirm‘; si se pone a ‘t’ elimina la confirmación para ‘vc-revert-buffer‘.
‘vc-initial-comment‘; comentario inicial cuando se muestra un fichero (opcional) por los controles de versiones.
‘vc-switches‘; puede tomar 2 valores:
-c para cuando haga diff tenga un formato context-diff.
-u para cuando haga diff tenga un formato unified-diff.
Extendiendo VC
Existen extensiones por ejemplo para ClearCase de IBM, llamada vc-clearcase.