<?xml version="1.0"?>
<?xml-stylesheet type="text/css" href="https://www.guia-ubuntu.com/skins/common/feed.css?303"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="es">
		<id>https://www.guia-ubuntu.com/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=TaracTalib</id>
		<title>Guía Ubuntu - Contribuciones del usuario [es]</title>
		<link rel="self" type="application/atom+xml" href="https://www.guia-ubuntu.com/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=TaracTalib"/>
		<link rel="alternate" type="text/html" href="https://www.guia-ubuntu.com/index.php/Especial:Contribuciones/TaracTalib"/>
		<updated>2026-04-26T11:28:44Z</updated>
		<subtitle>Contribuciones del usuario</subtitle>
		<generator>MediaWiki 1.22.7</generator>

	<entry>
		<id>https://www.guia-ubuntu.com/index.php/CVS</id>
		<title>CVS</title>
		<link rel="alternate" type="text/html" href="https://www.guia-ubuntu.com/index.php/CVS"/>
				<updated>2008-02-24T00:41:32Z</updated>
		
		<summary type="html">&lt;p&gt;TaracTalib: ouousitoure&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;elcnaba&lt;br /&gt;
{{INDdcha}}&lt;br /&gt;
El '''Sistema de Control de Versiones''' (''CVS'') permite que varios programadores trabajen de forma colaborativa en un mismo proyecto llevando un control de las versiones de los ficheros. De esta forma se permiten cambios concurrentes en un mismo fichero sin perder lo cambios realizados. Si usas o quieres usar esta herramienta se recomienda que pruebes [[CVSTrac]].&lt;br /&gt;
&lt;br /&gt;
== InstalaciÃ³n ==&lt;br /&gt;
&lt;br /&gt;
El programa viene en el paquete '''cvs''' que podemos [[aÃ±adir aplicaciones|instalar]] los repositorios oficiales de Ubuntu.&lt;br /&gt;
&lt;br /&gt;
== ConfiguraciÃ³n de un repositorio ==&lt;br /&gt;
&lt;br /&gt;
Vamos a tener cada proyecto en un repositorio separado, que es lo suyo para tener un control mÃ¡s fino sobre cada uno de los distintos repositorios. Es mejor asÃ­ por el tema de usuarios, permisos y configuraciones varias. Todos estos repositorios los vamos a crear dentro del directorio '''/var/lib/repositorio/''', por ejemplo, para tenerlos juntos y facilitar el tema de la copia de seguridad. &lt;br /&gt;
&lt;br /&gt;
Como buena prÃ¡ctica es aconsejable tener un usuario ''cvs'' que serÃ¡ el propietario de los ficheros:&lt;br /&gt;
&lt;br /&gt;
 $ adduser cvs&lt;br /&gt;
 $ chown cvs:cvs -R /var/lib/repositorio&lt;br /&gt;
&lt;br /&gt;
Una vez declaradas estas premisas procedemos a la inicializaciÃ³n del repositorio que albergarÃ¡ un hipotÃ©tico llamado ''tuxitron''. Estas tareas de instalaciÃ³n las haremos como ''root'':&lt;br /&gt;
&lt;br /&gt;
 $ cvs -d /var/lib/repositorio/tuxitron init&lt;br /&gt;
&lt;br /&gt;
Para que todos los usuarios del grupo '''cvs''' tengan permisos para trabajar con el repositorio, hacemos que todos los ficheros del reciÃ©n creado repositorio pertenezcan a ese grupo:&lt;br /&gt;
&lt;br /&gt;
 $ chgrp cvs /var/lib/repositorio/tuxitron -R&lt;br /&gt;
&lt;br /&gt;
Ahora le tenemos que indicar al CVS que puede disponer del nuevo repositorio. Si usamos el superdemonio ''xinetd'' tendremos que crear el fichero:&lt;br /&gt;
&lt;br /&gt;
 $ gedit /etc/xinetd.d/cvs &lt;br /&gt;
&lt;br /&gt;
y aÃ±adir el nuevo repositorio:&lt;br /&gt;
&lt;br /&gt;
 --allow-root=/var/lib/repositorio/tuxitron&lt;br /&gt;
&lt;br /&gt;
Al final debe quedar una cosa asÃ­:&lt;br /&gt;
&lt;br /&gt;
 service cvspserver&lt;br /&gt;
 {&lt;br /&gt;
         socket_type = stream&lt;br /&gt;
         protocol = tcp&lt;br /&gt;
         user = root&lt;br /&gt;
         group = cvs&lt;br /&gt;
         server = /usr/bin/cvs&lt;br /&gt;
         server_args = -f --allow-root=/var/lib/repositorio/perico --allow-root=/var/lib/repositorio/tuxitron pserver&lt;br /&gt;
         wait = no&lt;br /&gt;
         disable = no&lt;br /&gt;
 }&lt;br /&gt;
&lt;br /&gt;
Y reiniciamos el superservidor para que los cambios surtan efecto:&lt;br /&gt;
 $ /etc/init.d/xinetd reload&lt;br /&gt;
&lt;br /&gt;
== PersonalizaciÃ³n del repositorio ==&lt;br /&gt;
&lt;br /&gt;
Antes de empezar a poner cÃ³digo en el repositorio hay algunas cosas por hacer que nos facilitarÃ¡n luego el proceso de desarrollo. En el repositorio que acabamos de crear existe un directorio '''CVSROOT''' que contiene ficheros de carÃ¡cter administrativo, esto es, que nos permiten personalizar el comportamiento del CVS. Veamos algunos de ellos para el caso de programar en [[Java]]:&lt;br /&gt;
&lt;br /&gt;
* '''cvsignore''': Indica patrones de ficheros a ignorar por el CVS. Estos ficheros no se podrÃ¡n aÃ±adir al repositorio. Ejemplo:&lt;br /&gt;
&lt;br /&gt;
 *.class&lt;br /&gt;
 *.war&lt;br /&gt;
 *.ear&lt;br /&gt;
&lt;br /&gt;
* '''cvswrappers''': Especifica cÃ³mo serÃ¡n gestionados determinados ficheros. Sirve para indicar quÃ© ficheros son binarios. Ejemplo:&lt;br /&gt;
&lt;br /&gt;
 *.gif -k 'b'&lt;br /&gt;
 *.jpg -k 'b'&lt;br /&gt;
 *.png -k 'b'&lt;br /&gt;
 *.jar -k 'b'&lt;br /&gt;
 *.swf -k 'b'&lt;br /&gt;
&lt;br /&gt;
* '''writers''': Listado de usuarios que tienen permisos de escritura en el repositorio. Ejemplo:&lt;br /&gt;
&lt;br /&gt;
 fulanito&lt;br /&gt;
 menganito&lt;br /&gt;
 zutanito&lt;br /&gt;
&lt;br /&gt;
* '''passwd''': Nombre de los usuarios junto con sus correspondientes passwords. Cada lÃ­nea estÃ¡ compuesta de nombre del usuario, password codificado y correspondencia con usuario local. Ejemplo:&lt;br /&gt;
&lt;br /&gt;
 fulanito:********:cvs&lt;br /&gt;
 menganito:*********:cvs&lt;br /&gt;
 zutanito:*********:cvs&lt;br /&gt;
&lt;br /&gt;
Para encriptar los passwords puedes usar este programa en Perl, al que le pasas el password en plano como parÃ¡metro y lo devuelve convenientemente codificado:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;perl&amp;gt;&lt;br /&gt;
 #!/usr/bin/perl&lt;br /&gt;
 &lt;br /&gt;
 srand (time());&lt;br /&gt;
 my $randletter = &amp;quot;(int (rand (26)) + (int (rand (1) + .5) % 2 ?  65 : 97))&amp;quot;;&lt;br /&gt;
 my $salt = sprintf (&amp;quot;%c%c&amp;quot;, eval $randletter, eval $randletter);&lt;br /&gt;
 my $plaintext = shift;&lt;br /&gt;
 my $crypttext = crypt ($plaintext, $salt);&lt;br /&gt;
 &lt;br /&gt;
 print &amp;quot;${crypttext}\n&amp;quot;;&lt;br /&gt;
&amp;lt;/perl&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Estos ficheros no se editan directamente en el repositorio, a excepciÃ³n del ''passwd'' por motivos de seguridad, sino que deberemos hacer un ''checkout'' del directorio ''CVSROOT'' del repositorio para modificarlos y luego el ''commit'' correspondiente. Los ficheros ''cvsignore'' y ''writers'' tendrÃ¡s que crearlos y aÃ±adirlos al repositorio.&lt;br /&gt;
&lt;br /&gt;
== AÃ±adir un proyecto al repositorio ==&lt;br /&gt;
&lt;br /&gt;
Una vez tengamos creado el repositorio tenemos que crear un proyecto. En los proyectos simples habrÃ¡ un sÃ³lo proyecto por repositorio, pero en los mÃ¡s complejos puede haber varios proyectos relacionados en un mismo repositorio. En GNOME, por ejemplo, hay un repositorio y cada uno de los componentes de GNOME es un proyecto (Evolution, Nautilus, Evince, etc.). &lt;br /&gt;
&lt;br /&gt;
Lo que haremos en importar lo que tenemos creando un proyecto en el repositorio, de esta forma pondremos disponible el cÃ³digo para que otra gente se pueda incluir en el proceso de desarrollo. Se usa el comando '''import''' del CVS. Es importante ejecutar este comando desde el directorio donde tengamos las fuentes para importar. TambiÃ©n es fundamental establecer la variable de entorno '''CVSROOT''' que le indicarÃ¡ al cliente CVS donde estÃ¡ el repositorio.&lt;br /&gt;
&lt;br /&gt;
 $ export CVSROOT=/var/lib/repositorio/tuxitron&lt;br /&gt;
&lt;br /&gt;
La sintaxis del comando de importaciÃ³n es la siguiente:&lt;br /&gt;
&lt;br /&gt;
 $ cvs import -m &amp;quot;comentario&amp;quot; &amp;lt;proyecto&amp;gt; &amp;lt;etiqueta_vendedor&amp;gt; &amp;lt;etiqueta_version&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Los dos Ãºltimos parÃ¡metros tienen poca importancia, de modo que puedes sustituirlos por tu usuario y la palabra &amp;quot;inicio&amp;quot; mismo. Por ejemplo, si eres el usuario ''monkiki'' y el proyecto a importar se llama ''tuxitron'' la lÃ­nea de comandos serÃ­a:&lt;br /&gt;
&lt;br /&gt;
 $ cvs import -m &amp;quot;ImportaciÃ³n inicial&amp;quot; tuxitron monkiki inicio&lt;br /&gt;
&lt;br /&gt;
{{Nota|Si vas a usar [[CVSTrac]] en lugar de importar todo el proyecto, importa un directorio vacÃ­o o uno que contenga un fichero de texto sin importancia (del estilo de leeme.txt) y haz un commit del resto de los ficheros. Los ficheros importados no aparecen en el navegador web de CVS.}}&lt;br /&gt;
&lt;br /&gt;
== Binarios importados sin '-kb' ==&lt;br /&gt;
&lt;br /&gt;
Si accidentalmente aÃ±ades un fichero binario sin la opciÃ³n '-kb', puedes usar el comando ''cvs admin'' para arreglarlo. Por ejemplo:&lt;br /&gt;
&lt;br /&gt;
 $ cvs add -m &amp;quot;Imagen de prueba&amp;quot; imagen.gif&lt;br /&gt;
 $ cvs ci -m &amp;quot;Enviamos la imagen no marcada como binario&amp;quot; image.gif&lt;br /&gt;
&lt;br /&gt;
Ahora vamos a decirle que es un fichero binario:&lt;br /&gt;
&lt;br /&gt;
 $ cvs admin -kb imagen.gif&lt;br /&gt;
 $ cvs update -A imagen.gif&lt;br /&gt;
&lt;br /&gt;
{{nota|Esto no pasarÃ­a si tuviÃ©ramos el fichero '''cvswrappers''' correctamente configurado}}&lt;br /&gt;
&lt;br /&gt;
== Trabajar con CVS ==&lt;br /&gt;
&lt;br /&gt;
[[Imagen:TkCVS.jpg|thumb|TkCVS es un magnÃ­fico cliente grÃ¡fico para CVS.]]&lt;br /&gt;
La lÃ­nea de comandos admite gran cantidad de comandos y opciones. En la nomenclatura de CVS, los comandos son parÃ¡metros funcionales de CVS. En lugar de tener varios ejecutables, uno para hacer ''checkout'', otro para ''checkin'', otro para ''status''... tiene uno sÃ³lo llamado '''cvs''' que admite todos estos modos de funcionamiento. Veamos los principales:&lt;br /&gt;
&lt;br /&gt;
* '''checkout:''' Saca el fichero del repositorio y lo almacena localmente para poder trabajar con Ã©l.&lt;br /&gt;
* '''checkin:''' Una vez realizados los cambios, volcamos el fichero al repositorio donde estarÃ¡ disponible para el resto de desarrolladores.&lt;br /&gt;
* '''status:''' Indica el estado actual del fichero.&lt;br /&gt;
* '''log:''' Saca un listado con las revisiones del fichero.&lt;br /&gt;
&lt;br /&gt;
Pero lo mÃ¡s normal es que uses alguno de los clientes grÃ¡ficos que existen. Uno de los mejores, aunque no tenga buena apariencia, es '''TkCVS''', el cual podemos [[AÃ±adir aplicaciones|instalar]] con el paquete '''tkcvs''' de los repositorios oficiales de Ubuntu.&lt;br /&gt;
&lt;br /&gt;
== NotificaciÃ³n de los commits ==&lt;br /&gt;
&lt;br /&gt;
La configuraciÃ³n de un repositorio tambiÃ©n estÃ¡ sujeta al versionado. AsÃ­ que para aÃ±adir la opciÃ³n de notificaciÃ³n de correo de los ''commits'' tenemos que hacer un ''checkout'' del directorio especial '''CVSROOT'''.&lt;br /&gt;
&lt;br /&gt;
 $ cvs co CVSROOT&lt;br /&gt;
&lt;br /&gt;
Dentro de ese directorio hay unos cuantos ficheros. El que nos interesa ahora es '''loginfo''', al que tenemos que aÃ±adir la siguiente lÃ­nea:&lt;br /&gt;
&lt;br /&gt;
 DEFAULT /usr/bin/cvs-mailcommit --mailto direccion@correo.com --from direccion@correo.com --cvs %{sVv} --diff --full&lt;br /&gt;
&lt;br /&gt;
El programa que envÃ­a los correos lo podemos encontrar [http://www.infodrom.org/Infodrom/tools/cvs-mailcommit.html aquÃ­]. El parÃ¡metro ''mailto'' indica a quiÃ©n va destinado el correo. Podemos especificar varios ''mailto''. Lo que yo hago es crear un alias en el servidor de correo y enviar el correo a ese alias. AsÃ­ puedo poner o quitar los usuarios de destino sin tocar este fichero de configuraciÃ³n.&lt;br /&gt;
&lt;br /&gt;
== Hacer una copia de seguridad ==&lt;br /&gt;
&lt;br /&gt;
Veamos un ejemplo de cÃ³mo hacer una copia de seguridad de nuestro preciado repositorio de CVS. Simplemente lo que hace es:&lt;br /&gt;
&lt;br /&gt;
* Crea un archivo ''.tgz'' con el contenido del repositorio&lt;br /&gt;
* EnvÃ­a el archivo a un servidor de backup&lt;br /&gt;
* EnvÃ­a un correo al usuario ''root'' para avisarle del proceso&lt;br /&gt;
&lt;br /&gt;
El script es bastante simple y puedes adaptarlo a tus necesidades sin gran esfuerzo.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;bash&amp;gt;&lt;br /&gt;
 #!/bin/sh&lt;br /&gt;
 &lt;br /&gt;
 CVS_ROOT=&amp;quot;/var/lib/cvs&amp;quot;&lt;br /&gt;
 TMP_MSG=&amp;quot;/tmp/backup_cvs.tmp&amp;quot;&lt;br /&gt;
 TMP_DATA=&amp;quot;/root/Backup/CVS#$(date +%Y-%m-%d).tgz&amp;quot;&lt;br /&gt;
 &lt;br /&gt;
 # Make backup&lt;br /&gt;
 echo $TMP_DATA &amp;gt; $TMP_MSG&lt;br /&gt;
 echo &amp;quot;==================================&amp;quot; &amp;gt;&amp;gt; $TMP_MSG&lt;br /&gt;
 /bin/tar czf $TMP_DATA $CVS_ROOT 2&amp;gt;&amp;gt; $TMP_MSG&lt;br /&gt;
 &lt;br /&gt;
 # Subimos todo al FTP de GIT&lt;br /&gt;
 lftp -e &amp;quot;mput $TMP_DATA;quit&amp;quot; ftp://usuario:password@ftp.servidor.com/cvs&lt;br /&gt;
 &lt;br /&gt;
 # Send mail&lt;br /&gt;
 /bin/mail -s &amp;quot;CVS Backup&amp;quot; root &amp;lt; $TMP_MSG&lt;br /&gt;
 /bin/rm $TMP_MSG&lt;br /&gt;
&amp;lt;/bash&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Ver tambiÃ©n ==&lt;br /&gt;
&lt;br /&gt;
* [[CVSTrac]]&lt;br /&gt;
&lt;br /&gt;
=== Aplicaciones similares ===&lt;br /&gt;
&lt;br /&gt;
* [[Subversion]]&lt;br /&gt;
* [[:CategorÃ­a:ProgramaciÃ³n|Ver mÃ¡s en la categorÃ­a ''ProgramaciÃ³n'']]&lt;br /&gt;
&lt;br /&gt;
== Enlaces externos ==&lt;br /&gt;
&lt;br /&gt;
{{Wikipedia}}&lt;br /&gt;
{{Wikilibros|Tutorial de uso de CVS}}&lt;br /&gt;
* [http://www.linux.ie/articles/tutorials/cvs.php linux.ie :: Getting Started with CVS] {{en}}&lt;br /&gt;
* [http://www.cvstrac.org/ Sitio web oficial de CVSTrac] {{en}}&lt;br /&gt;
* [http://www.sanchivi.com/cm/cvspermissions/ CVSPermissions] {{en}}&lt;br /&gt;
* [http://www.ossp.org/pkg/tool/shiela/ OSSP shiela: CVS Access Control and Logging] {{en}}&lt;br /&gt;
* [http://ali.as/devel/cvsmonitor/ Sitio web oficial de CVS Monitor] {{en}}&lt;br /&gt;
* [http://www.linux.ie/articles/tutorials/managingaccesswithcvs.php Managing Access with CVS] {{en}}&lt;br /&gt;
&lt;br /&gt;
[[CategorÃ­a:ProgramaciÃ³n]]&lt;/div&gt;</summary>
		<author><name>TaracTalib</name></author>	</entry>

	</feed>