G.L.U.P. - Guía de Linux Para el Usuario _______________________________________________________________________________________________________________ Copyright Oc 1993, 1994, 1996 Larry Greenfield Todo lo que Ud. necesita saber para comenzar a utilizar Linux, el clon gratuito de Unix. Este manual cubre los comandos básicos de Unix, y también los específicos de Linux. El destinatario de este manual es el usuario principiante de Unix, aunque puede ser de utilidad como referencia para los usuarios más experimentados. _______________________________________________________________________________________________________________ Esta página se ha dejado en blanco intencionalmente. _______________________________________________________________________________________________________________i UNIX es marca registrada de X/Open. MS-DOS y Microsoft Windows son marcas registradas de Microsoft Corporation. OS/2 y Operating System/2 son marcas registradas de IBM X Window System es una marca registrada del X Consortium, Inc. Motif es una marca registrada de la Open Software Foundation. Linux no es marca registrada, ni tiene ninguna conexión con UNIX o con los UNIX System Labora- tories, o con X/Open. Por favor, ponga en conocimiento del autor cualquier marca registrada que no se haya mencionado. Copyright Oc Larry Greenfield 427 Harrison Avenue Highland Park, NJ 08904 leg+@andrew.cmu.edu Traducción al castellano 1997 Grupo LuCAS. Ver apéndice LuCAS para una relación completa. Se garantiza el permiso para realizar y distribuir copias literales de este manual, siempre que se preserven la nota de derechos de autor y este permiso en todas las copias. Se garantiza el permiso para copiar y distribuir versiones modificadas de este manual bajo las condiciones de las copias literales, siempre que las secciones en las cuales se reimprime "La Licencia Pública General GNU", "La Licencia Pública General de Biblioteca GNU", y otras en las cuales haya partes claramente marcadas bajo un derecho de autor separado, se reproduzcan bajo las mismas condiciones que ellas estipulan, y se logre que el trabajo derivado resultante en su totalidad se distribuya bajo los términos de una notificación de permiso idéntica a esta misma. Se garantiza el permiso de copiar y distribuir traducciones de este manual a otros idiomas bajo las condiciones dadas para versiones modificadas. "La Licencia Pública General GNU" y "La Licencia Pública General de Biblioteca GNU" pueden incluirse a través de una traducción aprobada por la Free Software Foundation, en lugar de los originales en inglés. A su opción, Ud. puede distribuir copias literales o modificadas de este documento bajo los términos de la "La Licencia Pública General GNU", excepto las secciones marcadas claramente bajo otros derechos de autor. Con distintos objetivos, pueden garantizarse ciertas excepciones a esas reglas. Escriba a Larry Greenfield a la dirección dada más arriba, o envíe correo electrónico a leg+@andrew.cmu.edu y consulte. Se solicita (pero no se requiere) que Ud. notifique al autor cuando se imprima a gran escala o se comercialice este documento. Las regalías y donaciones serán aceptadas y sustentarán las siguientes ediciones. _______________________________________________________________________________________________________________ii Estas son algunas de las convenciones tipográficas que se utilizan en este libro. negrita Se utiliza para iniciar nuevos conceptos, AVISOS, y palabras reservadas de lenguajes. itálica Se utiliza para enfatizar el texto. inclinada Se usa para marcar meta-variables en el texto, especialmente en representaciones de la línea de comandos. Por ejemplo, "ls -l foo" donde foo se coloca en la posición donde "iría" un nombre de archivo, como por ejemplo /bin/cp. monoespaciada Se usa para representar la interacción en la pantalla. También se usa para los ejemplos de código fuente, sea que se trate de código "C", guiones de shell, o lo que sea, y para mostrar archivos en general, como por ejemplo archivos de configuración. Cuando razones de claridad adicional lo exijan, estos ejemplos se enmarcarán en cuadros finos. ________ |_Tecla_| Representa la tecla que debe oprimir. En general lo verá utilizado de la siguiente manera: _______ "Oprima |_Intro_|para continuar." 3 El diamante en el margen, como los diamantes negros en las montañas de ski, marcan los lugares de "peligro" o "precaución". Debe leer cuidadosamente los párrafos marcados de este modo. Esta X en el margen indica la existencia de instrucciones especialmente destinadas a los usuarios del X Window System. Esto indica un parágrafo que contiene información especial que debe leerse con todo cuidado. Agradecimientos El autor quiere agradecer a las siguientes personas por su invaluable ayuda, tanto con Linux en sí como con la escritura de The Linux User's Guide. Linus Torvalds por proveer el material acerca del cual se escribe este libro. Karl Fogel me ha proporcionado una enorme ayuda con la escritura de mi documentación de Linux y además escribió la mayor parte del Capítulo 8 y el Capítulo 9. Cualquier reconocimiento hacia su labor será insuficiente. Maurizio Codogno escribió gran parte del Capítulo 11. David Channon escribió el apéndice sobre el vi. (Apéndice A) Yggdrasil Computing, Inc. por su generoso (y voluntario) sostén para este manual. Red Hat Software por su (más reciente y también voluntario) sostén. El programa fortune por proveerme algunas de las preciosas citas con las cuales comenzar cada capítulo. Aún cuando a nadie más le gusten, a mí me encantan. iii _______________________________________________________________________________________________________________iv Índice General 1 Introducción 1 1.1 >Quién debe leer este libro? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 1.1.1 >Qué debe hacer antes de leer este libro? . . . . . . . . . . . . . . . . . . . . 1 1.2 >Cómo evitar leer este libro? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 1.3 >Cómo leer este libro? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 1.4 Documentación de Linux . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3 1.4.1 Otros libros de Linux . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 1.4.2 COMOs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 1.4.3 >Qué es el Proyecto de Documentación de Linux? . . . . . . . . . . . . . . . . 4 1.5 Sistemas operativos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 2 A propósito, >qué es Unix? 7 2.1 La historia de Unix . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 2.2 La historia de Linux . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 2.2.1 Linux aquí y ahora . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 2.2.2 Unas pocas preguntas y respuestas . . . . . . . . . . . . . . . . . . . . . . . . 9 2.2.3 Software comercial en Linux . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 3 En el principio 11 3.1 La computadora despierta . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 3.2 Linux despierta . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 3.3 La actuación del usuario . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 3.3.1 El ingreso . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 3.3.2 Al abandonar la computadora . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 3.3.3 Como apagar la computadora . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 v _______________________________________________________________________________________________________________vi * * @ 3.4 Mensajes del núcleo . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 4 El shell de Unix 21 4.1 Comandos Unix . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 4.1.1 Un comando Unix típico . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 4.2 Autoayuda . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 4.3 Almacenaje de la información . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24 4.3.1 Miremos los directorios con ls . . . . . . . . . . . . . . . . . . . . . . . . . . 25 4.3.2 El directorio actual y cd . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27 4.3.3 Creación y borrado de directorios . . . . . . . . . . . . . . . . . . . . . . . . . 29 4.4 Información en movimiento . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 4.4.1 cp como un monje . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 4.4.2 La poda con rm . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32 4.4.3 Sería interesante tener un rastrillo . . . . . . . . . . . . . . . . . . . . . . . . 33 5 El sistema de ventanas X 35 5.1 Ejecución y salida del sistema de ventanas X . . . . . . . . . . . . . . . . . . . . . . 35 5.1.1 Ejecución de X . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 5.1.2 Salida de X . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 5.2 >Qué es el sistema de ventanas X? . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 5.3 >Qué es esto que hay en mi pantalla? . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 5.3.1 XClock . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 5.3.2 XTerm . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 5.4 Gestores de ventanas . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 5.4.1 Cuando se crean nuevas ventanas . . . . . . . . . . . . . . . . . . . . . . . . . 38 5.4.2 Foco . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39 5.4.3 Moviendo ventanas . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39 5.4.4 Profundidad . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 5.4.5 Iconizar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 5.4.6 Variando el tamaño . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 5.4.7 Maximización . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41 5.4.8 Menús . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41 5.5 Atributos X . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41 _______________________________________________________________________________________________________________ÍNDI* *CE GENERAL @ 5.5.1 Geometría . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41 5.5.2 Presentación . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42 5.6 Características comunes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43 5.6.1 Botones . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43 5.6.2 Barras de menú . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44 5.6.3 Barras de desplazamiento . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44 6 Trabajando con Unix 47 6.1 Comodines . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 6.1.1 >Qué ocurre realmente? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48 6.1.2 El signo de interrogación . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48 6.2 Ganar tiempo con bash . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 6.2.1 Editando la línea de comandos . . . . . . . . . . . . . . . . . . . . . . . . . . 49 6.2.2 Completamiento de comandos y nombres de fichero . . . . . . . . . . . . . . . 49 6.3 La entrada estándar y La salida estándar . . . . . . . . . . . . . . . . . . . . . . . . 50 6.3.1 Algunos conceptos de Unix . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 6.3.2 Redireccionar la salida . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 6.3.3 Redireccionar la entrada . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51 6.3.4 Las tuberías . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51 6.4 Multitarea . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52 6.4.1 Usando el control de trabajos . . . . . . . . . . . . . . . . . . . . . . . . . . . 52 6.4.2 Teoría del control de trabajos . . . . . . . . . . . . . . . . . . . . . . . . . . . 56 6.5 Consolas virtuales: como estar en varios lugares a la vez . . . . . . . . . . . . . . . . 57 7 Pequeños programas potentes 61 7.1 El poder de Unix . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61 7.2 Trabajando con ficheros . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 7.3 Estadísticas del sistema . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 7.4 >Qué hay en un fichero? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 7.5 Comandos de edición . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67 8 Editando archivos con Emacs 71 8.1 >Qué es Emacs? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71 8.2 Comenzar rápidamente en X . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73 _______________________________________________________________________________________________________________viii * * @ 8.3 Editando varios archivos al mismo tiempo . . . . . . . . . . . . . . . . . . . . . . . . 74 8.4 Terminando una sesión de edición . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75 8.5 La tecla Meta . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76 8.6 Cortar, pegar, destruir y tirar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76 8.7 Buscar y reemplazar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77 8.8 >Qué es lo que ocurre realmente? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78 8.9 Pidiendo ayuda a Emacs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79 8.10 Especializando buffers: Modos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80 8.11 Modos de programación . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81 8.11.1 Modo C . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81 8.11.2 Modo Scheme . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81 8.11.3 Modo de correo . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82 8.12 Como ser más eficiente aún . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83 8.13 Personalizando Emacs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 8.14 Averiguando más . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88 9 Qué viene a continuación? . . . . . . . . . . . . . . . . . . . . . . . . . . . . 138 A.4 Tutorial avanzado de Vi . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 139 A.4.1 Movimiento . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 139 A.4.2 Modificación del texto . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 140 A.4.3 Copiar y mover bloques de texto . . . . . . . . . . . . . . . . . . . . . . . . . 142 A.4.4 Búsqueda y cambio de texto . . . . . . . . . . . . . . . . . . . . . . . . . . . . 144 B The GNU General Public License 147 C The GNU Library General Public License 155 D >Qué es LuCAS? 165 E >Qué es INSFLUG? 167 Capítulo 1 Introducción How much does it cost to entice a dope-smoking Unix system guru to Dayton? Brian Boyle, Unix World's First Annual Salary Survey 1.1 >Quién debe leer este libro? >Es Ud. la persona que debe leer este libro? Permítame responder a esta pregunta haciéndole estas otras: >Acaba de obtener Linux de alguna fuente, lo instaló y ahora quiere saber que puede hacer? O, >es un usuario de computadoras que nunca ha utilizado Unix y está considerando usar Linux pero quiere saber lo que puede hacer con él? Si tiene este libro, la respuesta a esas preguntas probablemente es "sí". Cualquiera que tiene Linux (el clon gratuito de Unix escrito por Linus Torvalds) en su PC, pero no sabe que hacer después de la instalación, debe leer este libro. Aquí encontrará explicaciones sobre la mayoría de * *los comandos básicos de Unix, e incluso de algunos avanzados. También trataremos acerca del potente editor GNU Emacs y de muchas otras aplicaciones importantes en Unix. 1.1.1 >Qué debe hacer antes de leer este libro? Este libro da por sentado que Ud. tiene acceso a un sistema Unix (Cómo evitar leer este libro? La mejor manera de aprender el uso de casi cualquier programa de computadora es poniéndose a trabajar sobre la computadora. La mayoría de las personas encuentran de poco beneficio la lectura de un libro si no utilizan a la vez el programa. Por lo tanto, la mejor manera de aprender Unix y Linux es utilizándolos. Utilice Linux para todo lo que pueda. Experimente. No tenga miedo _es posible que haga algunos líos, pero siempre puede volver a instalar todo. Mantenga actualizadas las copias de seguridad1 y Cómo leer este libro? La manera sugerida para aprender Unix es leer un poquito, luego jugar un poquito. Juegue hasta que se sienta cómodo con los conceptos, y luego puede saltar entre los temas que se cubren en el libro. Encontrará una variedad de temas, algunos de los cuales serán de su interés. Luego de un tiempo, se sentirá lo suficientemente confiado como para utilizar comandos sin saber exactamente que es lo que deberían hacer. Esta es una buena señal. Lo que mucha gente asocia con Unix es el shell de Unix: se trata de un programa especial que interpreta comandos. En la práctica, ésta es una manera conveniente de ver las cosas, pero debe _____________________________________________1 N. del T.: backups _______________________________________________________________________________________________________________1.4. D* *ocumentación de Linu@ saber que Unix es realmente mucho más que el shell, o mucho menos _dependiendo de como lo mire. Este libro le dirá como utilizar el shell, los programas que usualmente vienen con Unix, y algunos programas que no son muy comunes (pero que Linux casi siempre trae). El capítulo actual es un meta-capítulo _se discute acerca del libro y de como aplicarlo para poder hacer nuestro trabajo. Los otros capítulos contienen: Capítulo 2 trata del origen y destino de Unix y Linux. También se habla de la Free Software Foundation y el proyecto GNU. Capítulo 3 habla de como arrancar y detener su computadora, y de lo que sucede durante esas operaciones. Gran parte de esto tiene que ver con temas que no es necesario conocer para utilizar Linux, pero aún así son útiles e interesantes. Capítulo 4 introduce el shell de Unix. Es con este programa con el cual las personas realizan su trabajo, y corren los programas que necesitan. Trata de los programas y comandos básicos que necesitará conocer para utilizar Unix. Capítulo 5 cubre el sistema de ventana X2. X es la cara gráfica principal de Unix, e incluso algunas distribuciones lo configuran como opción predeterminada. Capítulo 6 analiza algunas de las características más avanzadas del shell de Unix. El aprendizaje de las técnicas tratadas en este capítulo le ayudará a ser más eficiente. Capítulo 7 tiene breves descripciones de muchos de los comandos Unix. Cuanto más herramientas sabe utilizar un usuario, más rápidamente puede concluir su trabajo. Capítulo 8 describe el editor de textos Emacs. Se trata de un programa muy extenso que integra varias de las herramientas de Unix bajo una única interfaz. Capítulo 9 trata acerca de las distintas maneras que hay de personalizar un sistema Unix para satisfacer sus gustos personales. Capítulo 10 investiga los medios por los cuales un usuario Unix puede comunicarse con otras máquinas alrededor del mundo, incluyendo el correo electrónico y la Red de Alcance Mundial3. Capítulo 11 describe algunos de los comandos con más opciones y más difíciles de utilizar. Capítulo 12 muestra formas sencillas de evitar errores en Unix y Linux. 1.4 Documentación de Linux Este libro, Guía de Linux Para el Usuario, está pensado para el principiante en Unix. Afortunada- mente, el Linux Documentation Project (Proyecto de Documentación de Linux) también está escri- biendo_libros_para_los_usuarios_más_experimentados4._ 2N. del T.: X Window System. 3N. del T.: también conocida como WWW o World Wide Web. 4N. del T.: El proyecto LuCAS está ocupándose de traducir parte de la documentación de Linux al castell* *ano. Para obtener información actualizada de las traducciones, vea el apéndice D. _______________________________________________________________________________________________________________4 * * @ 1.4.1 Otros libros de Linux Los otros libros incluyen Installation and Getting Started 5, que es una guía para obtener e instalar Linux, The Linux System Administrator's Guide, trata como organizar y mantener un sistema Linux, y The Linux Kernel Hacker's Guide, que explica como modificar Linux. The Linux Network Administrator Guide6 muestra como instalar, configurar y utilizar una conexión de red. 1.4.2 COMOs Además de los libros, el Proyecto de Documentación de Linux7 ha realizado una serie de pequeños documentos que describen como configurar algún aspecto particular de Linux. Por ejemplo, el SCSI-COMO describe algunas de las complicaciones que aparecen al utilizar SCSI _que es una manera estándar de comunicarse con ciertos dispositivos_ y Linux. Estos COMOs están disponibles en varios formatos: en un libro como The Linux Bible o Dr. Linux ; en el foro de discusión comp.os.linux.answers; o en varios lugares de la WWW. El sitio central de la información acerca de Linux es http://www.linux.org. 1.4.3 >Qué es el Proyecto de Documentación de Linux? Como casi todo lo asociado con Linux, el Proyecto de Documentación de Linux consiste en un conjunto de gente que trabaja alrededor del mundo. Originalmente organizado por Lars Wirzenius, el Proyecto está coordinado en la actualidad por Matt Welsh con la ayuda de Michael K. Johnson. Se espera que el Proyecto de Documentación de Linux provea los libros que satisfagan todas las necesidades de documentación de Linux en algún momento. Por favor, díganos si hemos tenido éxito o qué es lo que debemos mejorar. Puede contactar al autor en leg+@andrew.cmu.edu, a Matt Welsh en mdw@cs.cornell.edu8. 1.5 Sistemas operativos El propósito principal de un sistema operativo es dar el soporte que necesitan los programas que hacen un trabajo de interés para el usuario. Por ejemplo, Ud. puede estar utilizando un editor si quiere crear un documento. Ese editor no puede realizar su trabajo sin la ayuda del sistema operativo _necesitará esta ayuda para interactuar con la terminal, los archivos, y el resto de la computadora. Si todo lo que hace el sistema operativo es dar soporte a las aplicaciones que Ud. desea utilizar, >por qué se necesita todo un libro sólo para hablar del sistema operativo? Existe un montón de actividades de mantenimiento de rutina (además de los programas que utilizará principalmente) _____________________________________________5 N. del T.: Disponible en castellano como Linux: Instalación y Primeros Pasos. Vea el apéndice D 6N. del T.: Disponible en castellano como Guía de Administración de Redes con Linux. Vea el apéndice D 7N. del T.: El grupo INSFLUG ha traducido varios de los documentos HOWTO, acuñando el término COMO. Vea el apéndice E. 8N. del T.: y al coordinador de esta traducción César Ballardini en cballard@santafe.com.ar _______________________________________________________________________________________________________________1.5. S* *istemas operativos @ que Ud. también necesitará realizar. En el caso de Linux, el sistema operativo contiene además un montón de "mini-aplicaciones" para ayudarle a realizar de manera más eficiente su trabajo. El conocimiento del sistema operativo le será de ayuda si su trabajo no se centra en alguna aplicación monolítica. Los sistemas operativos (SO, para abreviar) pueden ser simples y mínimos, como DOS, o grandes y complejos, como OS/2 o VMS. Unix trata de estar en un punto medio. A la vez que proporciona más recursos y hace más que los primitivos SO, no trata de hacer todo. Unix se diseñó originalmente como una simplificación de un sistema operativo que se denominó Multics. La filosofía original de diseño de Unix fue la de distribuir la funcionalidad en pequeñas partes: los programas9. De esta forma, el usuario puede obtener nueva funcionalidad y nuevas características de una manera relativamente sencilla mediante las diferentes combinaciones de pequeñas partes (programas). Además, en el caso de que aparezcan nuevas utilidades (y de hecho aparecen), puede Ud. integrarlas en su espacio de trabajo. Cuando escribo este documento, por ejemplo, utilizo activamente los siguientes programas: fvwm para manejar mis "ventanas", emacs para editar el texto, LATEX para darle forma, xdvi para ver una presentación preliminar, dvips para prepararlo para la impresión, y luego lpr para imprimirlo. Si mañana llegara a conseguir otro programa de presentación preliminar de archivos dvi, podría utilizarlo en lugar del xdvi sin cambiar el resto de los programas que uso. En el momento actual mi sistema está corriendo treinta y ocho programas simultáneamente. (Gran parte de ellos son programas del sistema que "duermen" hasta que tienen algún trabajo específico para realizar.) Cuando utilice un sistema operativo, deseará minimizar la cantidad de trabajo que tiene que llevar a cabo para concluir su tarea. Unix proporciona varias herramientas que pueden ayudarle, pero para ello debe conocer que es lo que hacen. No es muy productivo perderse una hora intentando poner a andar alguna cosa y al final tener que abandonar todo. Este libro le enseñará qué herramientas debe Ud. utilizar en qué situación, y como combinar esas herramientas entre sí. La parte clave de un sistema operativo se denomina "núcleo"10. En muchos sistema operativos, como Unix, OS/2, o VMS, el núcleo proporciona las funciones necesarias para los programas que están corriendo, y los planifica para su ejecución. Esto significa básicamente que el programa A puede tomar una cierta cantidad de tiempo, el programa B la misma cantidad, etc.. El núcleo siempre está funcionando: es el primer programa que arranca cuando se enciende el sistema, y el último programa que hace algo cuando se apaga el equipo. _____________________________________________9 Este diseño estuvo determinado por el hardware sobre el cual funcionó originalmente Unix. Por alguna extra** ña razón, el sistema operativo resultante fue muy útil sobre otras plataformas de hardware. El diseño bás* *ico fue tan bueno que aún veinticinco años despúes sigue usándose. 10N. del T.: núcleo del inglés "kernel". _______________________________________________________________________________________________________________6 * * @ Capítulo 2 A propósito, >qué es Unix? Ken Thompson tiene un automóvil en cuyo proyecto de diseño trabajó. A diferencia de otros automóviles, éste no tiene velocímetro, nivel de combustible, ni ninguna de las estúpidas luces que importunan al conductor moderno. En su lugar, si el conductor comete algún error, se enciende un enorme "?" en el centro del tablero. "El conductor experimentado", dice, "sabrá usualmente que es lo que anda mal." 2.1 La historia de Unix En 1965, los Bell Telephone Laboratories (Bell Labs, una división de AT&T) estaba trabajando con General Electric y el Proyecto MAC del MIT para escribir un sistema operativo llamado Multics. Para hacer más corta una historia de por sí larga, Bell Labs decidió que el proyecto no estaba yendo a ninguna parte y disolvió el grupo. Esto, sin embargo, dejó a la Bell sin un buen sistema operativo. Ken Thompson y Dennis Ritchie decidieron esbozar un sistema operativo que supliera las necesi- dades de la Bell Labs. Cuando Thompson llegó a necesitar un entorno de desarrollo (1970) que corriera en una PDP-7, aprovechó para poner en práctica sus ideas. Brian Kernighan le dió el nombre de Unix como un juego de palabras contra Multics. Un tiempo después, Dennis Ritchie inventó el lenguaje de programación "C". En 1973, se ree- scribió el sistema operativo Unix en C, en lugar del ensamblador original1. En 1977, se movió Unix a una nueva máquina distinta de las PDP en las que había corrido previamente, mediante un proceso que se denomina migración. El hecho de que Unix estaba escrito en C facilitó la migración, pues gran parte del código ya escrito necesitó sólo una simple recompilación, y no una rescritura. Al final de los '70, AT&T tenía prohibido competir en la industria de la computación, por lo que otorgó licencias económicas de Unix a varios colegios y universidades. Unix se difundió lentamente fuera de las instituciones académicas, pero pronto también se hizo popular en el ámbito comercial. El Unix de la actualidad es distinto del Unix de 1970. Existen dos corrientes principales: System V, _____________________________________________1 "Lenguaje ensamblador" es un lenguaje de computadoras muy elemental, y que está indisolublemente ligado a un tipo particular de ordenador. 7 _______________________________________________________________________________________________________________8 * * @ de los Unix System Laboratories (USL), que es una subsidiaria de Novell2, y BSD, Berkeley Software Distribution. La versión USL está ahora por su cuarta versión, o SVR43, mientras que la última BSD es la 4.4. Sin embargo, existen muchas diferentes versiones de Unix entre estas dos. La mayoría de las versiones de Unix son desarrolladas por compañías de software y derivan de uno de los dos agrupamientos. Las versiones que se utilizan actualmente incorporan características de ambas variaciones. Las versiones actuales de Unix para PC Intel cuestan entre $500 y $2000. 2.2 La historia de Linux El autor primario de Linux es Linus Torvalds. A partir de la versión original, ha sido mejorado por incontables personas de todo el mundo. Se trata de un clon del sistema operativo Unix, escrito desde cero. Ni USL, ni la Universidad de California, Berkeley, tuvieron participación en la escritura de Linux. Una de las cosas más interesantes de Linux es que el desarrollo ocurre simultáneamente alrededor del mundo. La gente ha contribuído desde Australia a Finlandia y esperamos que lo siga haciendo. Linux comenzó como un proyecto para explorar el chip 386. Uno de los primeros proyectos de Linus fue un programa que pueda alternar entre la impresión de AAAA y BBBB. Esto luego evolucionó hacia Linux. Linux ha sido registrado bajo los términos de la Licencia Pública General GNU (GNU General Public License) o GPL. Esta licencia, escrita por la Free Software Foundation (FSF), está diseñada para evitar que alguna persona restrinja la distribución de software. En pocas palabras, dice que aunque Ud. cobre a alguien por entregarle una copia, no podrá impedir que ese alguien la regale. También significa que debe estar disponible el código fuente4. Esto es útil para los programadores. Cualquiera puede modificar Linux y aún distribuir sus modificaciones, siempre que mantenga el código bajo la misma licencia. En Linux puede correr la mayoría del software popular en Unix, incluyendo el Sistema de Ven- tanas X. X se desarrolló en el Instituto Tecnológico Massachusetts, para permitir a los sistemas Unix la creación de ventanas gráficas, y la cómoda interacción con las mismas. En la actualidad, el sistema X se usa en todas las versiones disponibles de Unix. Además de las dos variaciones de Unix, System V y BSD, existe un conjunto de documentos de estandarización publicados por la IEEE denominados POSIX. Linux antes que nada satisface los documentos POSIX-1 y POSIX-2. Su apariencia se asemeja mucho a la de BSD en ciertas partes, mientras que es parecido a System V en otras. Es una combinación (y para la mayoría de las personas, una buena) de los tres estándares. Algunas de las utilidades incluídas con las distribuciones de Linux proceden de la Free Software Foundation y son parte del proyecto GNU. El proyecto GNU es un esfuerzo para escribir un avanzado _____________________________________________2 Recientemente vendida a Novell, antes era propiedad de AT&T. 3Una manera críptica de decir "System five, Revision four". 4El código fuente de un programa es lo que el programador lee y escribe. Luego se traduce a un código de máquina ilegible para las personas, que es el que la computadora interpreta. _______________________________________________________________________________________________________________2.2. L* *a historia de Linux @ sistema operativo portable con el estilo de Unix. "Portable" significa que pueda correr en una variedad de máquinas distintas, no sólo en PCs Intel, Macintoshes, o lo que sea. El sistema operativo del Proyecto GNU se llama Hurd. La principal diferencia entre el Linux y el GNU Hurd no se encuentra en la interfaz del usuario, sino en la del programador _el Hurd es un sistema operativo moderno, mientras que Linux es más parecido al diseño original de Unix. La historia precedente de Linux olvida mencionar otra persona más allá de Linus Torvalds. Por ejemplo, H. J. Lu se ha ocupado de mantener gcc y la biblioteca C de Linux (dos elementos necesarios para todos los programas en Linux) casi desde el principio de la vida del sistema operativo. Ud. puede encontrar una lista de personas que merecen reconocimiento por su trabajo en cada sistema Linux, en el archivo /usr/src/linux/CREDITS. 2.2.1 Linux aquí y ahora La primer cifra en el número de versión de Linux indica revisiones realmente importantes en alcance. Este número cambia muy lentamente y para la época en que esto se escribe (febrero de 1996), sólo está disponible la versión "1"5. La segunda cifra indica revisiones de menor envergadura. Los segundos números cuando son pares representan versiones más estables, en las que uno puede confiar plenamente; cuando son impares indican versiones en desarrollo, que son más propensas a contener errores. La última cifra es el número menor de lanzamiento _cada vez que se libera una nueva versión, que tal vez sólo arregla unos pocos problemas o agrega unas pocas características, se incrementa en uno este número. En febrero de 1996, la última versión estable es la 1.2.11, y la última en desarrollo es la 1.3.61. Linux es un sistema grande y desafortunadamente contiene errores que los desarrolladores reparan al encontrarlos. Aún cuando algunas personas puedan experimentar malfuncionamientos regular- mente, esto se debe normalmente a causa de piezas de hardware que no son estándares o que están defectuosas; los errores6 que afectan a todos los usuarios son escasos y no se dan seguido. Por supuesto, ésos son los errores del núcleo. Los errores pueden presentarse en casi cada as- pecto del sistema, y los usuarios de poca experiencia tienen problemas para diferenciar los distintos programas entre sí. Por ejemplo, cierto problema puede hacer que todos los caracteres aparezcan como un galimatías _>es un error o una "característica"? Sorpresivamente es una característica _existen ciertas secuencias de control que al aparecer provocan el galimatías. Espero que este libro le sea de ayuda para poder identificar esas situaciones. 2.2.2 Unas pocas preguntas y respuestas Antes de embarcarnos para nuestra larga travesía, repasemos las cuestiones ultra-importantes. Pregunta: >Cómo se pronuncia Linux? Respuesta: De acuerdo con Linus, debe pronunciarse con un sonido corto ih, como prInt, mInImal, etc. Linux debe rimar con Minix, que es otro clon de Unix. No debe pronunciarse como _____________________________________________5 N. del T.: La traducción se hace en febrero de 1997, y ya la versión "2" es cosa de todos los días. 6N. del T.: error del inglés bug. _______________________________________________________________________________________________________________10 * * @ la pronunciación (americana) de "Peanuts" en Linus, sino más bien como "LIH-nucks". Y la u es cortante, como en "rule", no suave como en "ducks". Linux debe al menos rimar con "cynics". Pregunta: >Por qué trabajar en Linux? Respuesta: >Por qué no? Linux es generalmente más barato que los otros sistemas operativos (o al menos no más caro) y con frecuencia es menos problemático que algunos sistemas comerciales. Puede que no sea el mejor sistema para sus aplicaciones en particular, pero para alguien que está interesado en utilizar las aplicaciones Unix disponibles para Linux, se trata de un sistema de alta "performance". 2.2.3 Software comercial en Linux Existe un montón de software comercial disponible para Linux. Comenzando con Motif _que es una interfaz para el sistema X Window que vagamente nos recuerda a Microsoft Windows, Linux tiene cada vez más software comercial. En estos tiempos, Ud. puede adquirir cualquier cosa, desde Word Perfect (el popular procesador de palabras) hasta Maple, que es un paquete que realiza complejas manipulaciones simbólicas, para Linux. Para aquellos lectores interesados en las cuestiones legales, esto está permitido por la licencia de Linux. A la vez que la licencia GNU General Public License (que se reproduce en el Apéndice B) cubre el núcleo de Linux, la licencia GNU Library General Public License (que se puede ver en el Apéndice C) cubre la mayor parte del código del cual dependen las aplicaciones. Esto permite que los proveedores de software comercial puedan vender sus aplicaciones y reservarse el código fuente de las mismas. Debe Ud. percatarse de que los dos documentos antes nombrados son notificaciones de derechos de autor. Ellos no regulan como utiliza Ud. el software, solamente indican bajo cuales circunstancias Ud. puede copiar dicho software, o sus productos derivados. Para la Free Software Foundation, ésta es una distinción muy importante: Linux no involucra ninguna licencia "estilo pitón", que lo envolverá y asfixiará, sino que está protegido por la misma ley que le impide a Ud. fotocopiar un libro. Capítulo 3 En el principio This login session: $13.99, but for you $11.88. Tal vez ha tenido experiencia con MS-DOS u otro sistema operativo monousuario, como OS/2 o el de Macintosh. En esos sistemas operativos, Ud. no tiene que identificarse frente a la computadora antes de poder utilizarla; siempre se supone que es el único usuario en el sistema y que puede acceder a todo lo que quiera. Por el contrario, Unix es un sistema operativo multiusuario _no sólo puede utilizarlo más de una persona a la vez, sino que las distintas personas recibirán distinto trato. Para poder identificar las personas, Unix necesita un usuario para que el proceso denominado ingreso1 pueda identificarlo o identificarla2. Apenas se enciende una computadora, tiene lugar un complejo proceso antes que la misma esté lista para ser usada. Como esta guía está orientada a Linux, les diré que es lo que sucede durante la secuencia de arranque3. Debe advertir Ud. que si está utilizando Linux en alguna clase de ordenador distinto a una PC Intel, algunos temas de este capítulo no se aplicarán a su caso. En su mayoría, dichos temas se encontrarán en la Sección 3.1. Si Ud. está interesado únicamente en utilizar su computadora, puede saltearse toda la informa- ción de este capítulo, excepto la de la Sección 3.3. 3.1 La computadora despierta Lo primero que sucede cuando se conecta la alimentación a su computadora es la ejecución de un programa denominado BIOS. Su nombre proviene de las iniciales de Basic Input/Output System, que significa Sistema de Entrada/Salida Básico. Este programa está almacenado de manera perma- nente dentro de la computadora en chips que normalmente son del tipo de lectura solamente. Para _____________________________________________1 N. del T.: ingreso en inglés logging in 2Desde ahora en adelante, utilizaré los pronombres masculinos para identificar a todas las personas. Esta es la convención estándar en inglés (N. del T.: y en castellano), y con esto no quiero decir que sólo los hom* *bres pueden utilizar computadoras. 3N. del T.: arranque, del inglés boot-up. 11 _______________________________________________________________________________________________________________12 * * @ nuestros propósitos, el BIOS es un programa que nunca se puede cambiar. Al funcionar, realiza ciertas comprobaciones mínimas y luego se fija si hay un disquete en la primer disquetera. Si en- cuentra alguno, mira en su "sector de arranque" y comienza a ejecutar su código, si lo hay. Si hay un disquete pero no contiene un sector de arranque, el BIOS mostrará el siguiente mensaje: Non-system disk or disk error Si quitamos el disquete y apretamos una tecla, el proceso de arranque continuará. Si no existe un disquete en la disquetera, el BIOS se fija si existe un registro maestro de arranque (MBR: master boot record) en el disco rígido. Si es así comienza a ejecutar el código que allí encuentra, que se ocupa de cargar el sistema operativo. En los sistemas Linux, el cargador se llama LILO _por LInux LOader_, puede ocupar el MBR y en ese caso cargará el Linux. (La distribución en particular que esté utilizando puede manejar el arranque desde el disco rígido de otra manera, así que debe controlar esto en la documentación que se incluye con la distribución. Otra buena referencia es la documentación de LILO, [1 ].) 3.2 Linux despierta Luego que el BIOS le pasa el control a LILO, LILO a su vez le pasa el control al núcleo de Linux. El núcleo es el programa central del sistema operativo, que controla a todos los demás. Lo primero que hace Linux una vez que comienza su ejecución es cambiar la CPU a modo protegido. El procesador 803864 que controla su computadora tiene dos modos que se denominan "modo real" y "modo protegido". El sistema operativo DOS corre en modo real, al igual que el BIOS. Sin embargo, los sistemas operativos más avanzados necesitan correr en modo protegido. Por ello, cuando Linux arranca, descarta el BIOS. Los procesadores distintos al 386 llegan a este estado de manera diferente. Ningún otro procesador necesita cambiar a modo protegido, y sólo unos pocos tienen un contexto tan pesado de carga, como LILO y el BIOS. Una vez que arranca el núcleo, Linux trabaja casi de la misma manera. A continuación, Linux mira que clase de hardware tiene debajo. Necesita saber que clase de discos rígidos tiene, si hay o no un ratón de bus, si está conectado a una red, y otras trivialidades como esas. Linux no puede recordar ciertas cosas luego de apagado, de manera que las pregunta cada vez que arranca. Afortunadamente, no se las pregunta a Ud.: Pero qué es un sistema de archivos?, se estará preguntando Ud. . Un sistema de archivos es la disposición de los archivos en el disco rígido. Además permite que Unix sepa cuales partes del disco rígido están ocupadas y cuales no. Desafortunadamente, ciertos factores como los cortes en el suministro de energía hacen que la información que el sistema de archivos tiene sobre la disposición en el disco de los archivos no coincida con la disposición real. En estos casos se ve la utilidad de un programa llamado fsck, que es capaz de encontrar estas situaciones y (con suerte) corregirlas. o Se lanzan programas especiales de encaminamiento para las redes. Estos programas informan a su computadora cómo se supone que puede comunicarse con las otras. o Se borran los archivos temporales que crean ciertos programas. o Se actualiza correctamente el reloj del sistema. Esto es más complicado de lo que puede parecer, pues Unix de manera predeterminada, necesita la hora en UCT (Universal Coordinated Time), también conocido como hora de Greenwich, y el reloj de la CMOS _que es alimentado por una batería dentro de la computadora_ muy probablemente estará configurado con la hora local. Esto significa que debe tener algún programa que lea la hora del reloj de la CMOS y la corrija transformándola en hora UCT. _______________________________________________________________________________________________________________14 * * @ Después que init termina con sus actividades de arranque, comienza con sus tareas planificadas. init se convierte así en el padre de todos los procesos del sistema Unix. Un proceso es simplemente un programa que está corriendo; como cualquier programa puede correr más de una vez, entonces puede haber más de un proceso para un programa dado en particular. En Unix, los procesos _instancias de un programa_ se crean mediante una llamada al sistema5 _que es un servicio provisto por el núcleo_ denominada fork. (Se lo llama "fork" (bifurcación) pues un proceso se bifurca en dos independientes.) init forkea (bifurca) unos cuantos procesos, los que a su vez forkean6 otros. En su sistema Linux con toda seguridad init corre varias instancias de un programa llamado getty. getty es el programa que le permitirá iniciar el ingreso al usuario, y que a continuación lanzará el programa login. 3.3 La actuación del usuario 3.3.1 El ingreso Lo primero que hay que hacer para poder utilizar una máquina con Unix es identificarse frente a la misma. Este proceso, conocido en inglés como logging in (registro de ingreso), es la manera que tiene Unix de saber cuales son los usuarios autorizados para utilizar el sistema. Durante el ingreso se le preguntará un nombre de cuenta y una contraseña7. Los nombres de las cuentas son por lo general parecidos a los nombres de las personas, y se lo asignará el administrador del sistema. Si Ud. es el administrador del sistema deberá crearse una cuenta para poder trabajar sin los cuidados especiales que requiere la cuenta root. (La información necesaria para llevar a cabo dicha tarea podrá encontrarla en Installation and Getting Started 8 o en The Linux System Administrator's Guide.) Luego de que tenga lugar la secuencia de procedimientos durante el arranque, Ud. verá en la pantalla algo como lo que se muestra a continuación: (la primer línea es meramente un saludo _podría ser alguna advertencia legal, o cualquier otra cosa) Welcome to the mousehouse. Please, have some cheese. mousehouse login: Sin embargo, puede ser que lo que el sistema le presente al arrancar no se parezca a esto. Por ejemplo, puede que en lugar de una aburrida pantalla de texto nos muestre una pantalla gráfica. Aún en este caso, la computadora le pedirá sus datos al ingreso y más o menos de la misma manera. Si éste es el caso en su sistema, entonces el entorno de trabajo que utilizará es el sistema X. El X Window System es un sistema de ventanas y en el capítulo 5 se discutirán algunas de las diferencias con las que se enfrentará. De cualquier manera, el proceso de ingreso será similar en ambos casos. Si va a utilizar X, busque las apariciones de una X grandota en el margen de esta guía. _____________________________________________5 N. del T.: llamada al sistema del inglés system call. 6N. del T.: Mis disculpas por el término, prometo no usarlo más :-). 7N. del T.: contraseña, palabra clave del inglés password 8N. del T.: Puede consultar la versión en castellano ya existente _______________________________________________________________________________________________________________3.3. L* *a actuación del usua@ Esta es, por supuesto, la invitación que Ud. buscaba para ingresar (login). A lo largo de este manual utilizaremos el usuario ficticio (o no tan ficticio, dependiendo de su máquina) larry9. Donde Ud. vea larry debe poner el nombre de su propia cuenta. Los nombres de las cuentas se basan en general en los nombres reales; los sistemas Unix más grandes y serios tienen cuentas que usan el apellido del usuario, alguna combinación de nombre y apellido, y aún se da el caso que deban agregarle algunos dígitos. Por ejemplo, nombres de cuentas posibles para Larry Greenfield podrían ser: larry, greenfie, lgreenfi, lg19. mousehouse será, de la misma manera, el "nombre" de la máquina sobre la que trabajaré. Es posible que cuando Ud. instale Linux se le pregunte el nombre que desea asignarle. Esto no es demasiado importante, pero cada vez que haga falta utilizaré mousehouse o, más raramente, lionsden cuando necesite de un segundo sistema por razones de claridad o de contraste. _______ Luego de teclear larry y apretar |_Intro_|, nos encontramos con lo siguiente: mousehouse login: larry Password: Linux está solicitando su contraseña10. Cuando escriba su contraseña no podrá ver lo que está tecleando, en razón de la privacidad necesaria a dicha palabra. Escriba cuidadosamente: puede borrar caracteres, pero no podrá ver lo que está editando. No escriba muy despacio si hay gente mirándole _podrían llegar a descubrirla. En cualquier caso, si se equivoca no se haga problemas, pues el sistema le dará otra oportunidad de ingresar. Luego que ingrese correctamente su nombre de cuenta o nombre de usuario y su contraseña, aparecerá un corto mensaje denominado "mensaje del día"11 que se obtiene del archivo /etc/motd. Este archivo se utiliza para dar a conocer cualquier clase de información a los usuarios con respecto al estado del sistema y es responsabilidad del administrador del sistema fijar su contenido. Después de todo esto aparece un prompt. Un prompt es un símbolo que nos indica que la computadora está lista para recibir un comando. Debe parecerse a la siguiente figura: /home/larry$ Si Ud. está utilizando X Window, el prompt aparecerá en alguna de las "ventanas" que hay en pantalla. (Las "ventanas" son simples cajas rectangulares.) Para escribir en el prompt, mediante el ratón, mueva el cursor del mismo (probablemente se ve como una gran "X" o una flecha) dentro de la ventana. 3.3.2 Al abandonar la computadora por qué?. 16"Compilada" se refiere al proceso mediante el cual un programa de computadora escrito por una persona se traduce a algo que entiende la computadora. Si una característica se ha "compilado en su interior" significa que es* *tá incluída en el programa. 17N. del T.: "colour" es la variante ortográfica del inglés insular y "color" la norteamericana. _______________________________________________________________________________________________________________18 * * @ 2. La próxima tarea del núcleo es informar acerca de la velocidad de su sistema, medida en "BogoMIPS". Un "MIP" equivale a un millón de instrucciones por cada segundo, mientras que un "BogoMIP" es un "bogus MIP"18: cuantas veces la computadora puede hacer absolutamente nada por cada segundo. (Como este bucle no hace nada en realidad, el número calculado no es tampoco una medida de la velocidad del sistema.) Linux utiliza este número cuando necesita esperar por algún dispositivo de hardware. Calibrating delay loop.. ok - 33.28 BogoMIPS 3. El núcleo de Linux también nos comenta acerca de la utilización de la memoria: Memory: 23180k/24576k available (544k kernel code, 384k reserved, 468k data) Esto significa que la máquina tiene 24 megabytes de memoria. Parte de esta memoria está reservada por el núcleo. El resto puede ser utilizada por los programas. Éste es el lugar temporal conocido como RAM que se utiliza sólo como almacenamiento de corto plazo. Su computadora también dispone de una memoria permanente denominada disco rígido. El con- tenido del disco rígido se mantiene intacto aún luego de quitar la alimentación del ordenador. 4. A lo largo del proceso de arranque, Linux controla distintas partes del hardware y nos muestra mensajes indicativos de las mismas. This processor honours the WP bit even when in supervisor mode. Good. 5. Ahora Linux pasa a la configuración de red. Lo que veremos a continuación está mejor explicado en The Linux Networking Guide19 , y está fuera del alcance de este documento. Swansea University Computer Society NET3.033 for Linux 1.3.50 IP Protocols: ICMP, UDP, TCP 6. Linux soporta la FPU, la unidad de punto flotante20 Ésta es un chip especial (o parte de un chip en el caso del procesador 80486DX) que se ocupa de la aritmética con números no enteros. Algunos de esos chips no están en buenas condiciones, y cuando Linux trata de identificarlos la máquina "se cuelga"21. La máquina deja de funcionar. Si esto sucede, Ud. verá en su pantalla lo siguiente: Checking 386/387 coupling... Sino, el mensaje será: _____________________________________________18 N. del T.: bogus significa espurio (para los argentinos: trucho). 19N. del T.: Disponible en castellano. Vea el apéndice D. 20N. del T.: unidad de punto flotante del inglés Floating Point Unit. 21N. del T.: se cuelga del inglés crashes. _______________________________________________________________________________________________________________3.4. M* *ensajes del núcleo @ Checking 386/387 coupling... Ok, fpu using exception 16 error reporting. si está utilizando un 486DX. Si tiene un 386 con un 387, le aparecerá: Checking 386/387 coupling... Ok, fpu using irq13 error reporting. 7. Y ahora se controla la instrucción "halt". Checking 'hlt' instruction... Ok. 8. Luego de esta configuración inicial, Linux escribe una línea identificándose a sí mismo. En ella explica cual es la versión del núcleo, la del compilador de C de GNU que se utilizó para compilarlo, y la fecha de dicha compilación. Linux version 1.3.55 (root@mousehouse) (gcc version 2.7.0) #1 Sun Jan 7 14:56:26 EST 1996 9. El controlador serie comienza a consultar acerca del hardware instalado. Un controlador es una parte del núcleo que controla un dispositivo, normalmente un periférico. Se hace responsable por los detalles de la comunicación entre la CPU y el dispositivo. Esto permite que la gente que escribe aplicaciones de usuario se pueda concentrar en la aplicación, pues no tiene que preocuparse por como trabaja exactamente la computadora. Serial driver version 4.11 with no serial options enabled tty00 at 0x03f8 (irq = 4) is a 16450 tty01 at 0x02f8 (irq = 3) is a 16450 tty02 at 0x03e8 (irq = 4) is a 16450 Aquí vemos que ha encontrado tres puertos serie. Un puerto serie es el equivalente del puerto COM en DOS; es el dispositivo que se utiliza normalmente para comunicarse con modems y ratones. Lo que significan las líneas anteriores es que el puerto serie 0 (COM1) tiene la dirección 0x03f8. Cuando dicho puerto interrumpe al núcleo, usualmente para decir que tiene datos listos, utiliza la IRQ 422. Las IRQ son un medio que tienen los periféricos de hablarse con el software. Cada puerto serie también tiene un chip controlador, que usualmente se denomina 16450; aunque también puede ser el 8250 o el 16550. 10. A continuación viene el puerto paralelo, que normalmente se conecta a la impresora. Los puertos paralelos en Linux tienen nombres que comienzan con lp. lp son las iniciales de Line Printer23, aunque en los tiempos actuales parece más apropiado usar las iniciales de Laser Printer. (Sin embargo, Linux se comunica sin problemas con cualquier clase de impresora _______conectada_al_puerto_paralelo:_de_matriz_de puntos, chorro de tinta, o laser.) 22N. del T.: IRQ, Interrupt ReQuest (petición de interrupción). 23N. del T.: Impresora de líneas. _______________________________________________________________________________________________________________20 * * @ lp0 at 0x03bc, (polling) Este mensaje dice que ha encontrado un puerto paralelo, y que usará el controlador de dispos- itivo estándar. 11. Linux identifica luego las unidades de disco rígido. En el sistema que le estoy mostrando, mousehouse, tengo instalados dos unidades de disco rígido IDE. hda: WDC AC2340, 325MB w/127KB Cache, CHS=1010/12/55 hdb: WDC AC2850F, 814MB w/64KB Cache, LBA, CHS=827/32/63 12. El núcleo ahora busca las unidades de disco flexible. En este ejemplo, la máquina tiene dos unidades: la "A" es una unidad de 5 1=4 ", y la "B" es una de 3 1=2 ". Linux denomina fd0 a la unidad "A", y fd1 a la unidad "B". Floppy drive(s): fd0 is 1.44M, fd1 is 1.2M floppy: FDC 0 is a National Semiconductor PC87306 13. El próximo controlador que arranca en mi sistema ejemplo es el controlador SLIP. Escribe un mensaje acerca de su configuración. SLIP: version 0.8.3-NET3.019-NEWTTY (dynamic channels, max=256) (6 bit encapsulation enabled) CSLIP: code copyright 1989 Regents of the University of California 14. El núcleo explora dentro de los discos rígidos que ha encontrado. Busca las distintas particiones que tiene cada uno. Una partición es una sección lógica de una unidad que se utiliza para evitar que interfieran entre sí distintos sistemas operativos coexistentes. En este ejemplo, la computadora tiene dos discos (hda y hdb) con cuatro y una particiones, respectivamente. Partition check: hda: hda1 hda2 hda3 hda4 hdb: hdb1 15. Finalmente, Linux monta la partición raíz. Ésta es la partición del disco en la cual reside el sistema operativo Linux. Cuando Linux "monta" esta partición, hace que esté disponible para los usuarios. VFS: Mounted root (ext2 filesystem) readonly. Capítulo 4 El shell de Unix Es muy fácil crear archivos en el sistema operativo UNIX. Por lo tanto, los usuarios tienden a crear muchos archivos que utilizan una gran cantidad de espacio. Se ha dicho que la única cosa estándar y común a todos los sistemas UNIX es el mensaje-del-día que les pide a los usuarios que borren los archivos que no necesitan. Guía del administrador de System V.2 4.1 Comandos Unix Cuando ingresa al sistema Unix, se enfrenta con algo más o menos como lo que se muestra a continuación: /home/larry$ Ese "algo" se denomina prompt1. Como su nombre sugiere, le solicita a Ud. que ingrese un comando. Todos los comandos Unix consisten de una secuencia de letras, números y caracteres. No son válidos los espacios dentro del nombre del comando. Algunos comandos válidos son mail, cat, y CMU_is_Number-5. Algunos caracteres no están permitidos_volveremos a este tema más adelante. Unix además hace diferencia entre mayúsculas y minúsculas2, lo que significa que Cat y cat son comandos distintos. El prompt se muestra como resultado del accionar de un programa especial denominado intérprete de comandos3. El intérprete de comandos o shell acepta los comandos que escribe el usuario y los ejecuta. Los comandos pueden formar programas en el lenguaje del intérprete de comandos, y a dichos programas se los denomina "guiones de shell". _____________________________________________1 N. del T.: prompt significa solicitud. 2La diferenciación entre mayúsculas y minúsculas es una cosa muy personal. Algunos sistemas operativos * *como OS/2 y Windows NT preservan las diferencias, pero no las cuentan como distintas. En la práctica habitual con Unix, se utiliza raramente la diferenciación. La situación de tener un par de comandos Cat y cat diferentes, no es co* *mún. 3N. del T.: intérprete de comandos del inglés shell. 21 _______________________________________________________________________________________________________________22 * * @ Los shell en Unix se clasifican en dos grandes grupos: los tipo Bourne y los tipo C. Los shell tipo Bourne toman su nombre a partir de su inventor, Steven Bourne. Steven Bourne escribió el shell original de Unix, denominado sh; a partir de entonces, la mayoría de los shells tienen un nombre con el sufijo sh para indicar que son extensiones de la idea original. Existen varias implementaciones de este shell, que colectivamente llevan el nombre de shells Bourne. También son comunes los shells tipo C cuyo original fue implementado por Bill Joy. Tradicionalmente, los shell Bourne se han utilizado para los scripts de shell y por razones de compatibilidad con el sh original, mientras que los shells C han sido más comunes en su aplicación interactiva. (Los C tienen ventajas en cuanto a sus mejores características interactivas, aunque son más difíciles de programar.) Linux viene con un shell Bourne denominado bash, escrito por la organización "Free Software Foundation"4. El nombre bash proviene de Bourne Again SHell, uno de los tantos juegos de palabras en Unix. Se trata de un shell Bourne "avanzado": tiene las capacidades estándar de programación que se encuentran en todos los shells Bourne y además varias de las características interactivas que se encuentran en los shells C. bash es el shell predeterminado cuando uno usa Linux. Apenas ingresa por primera vez, el prompt que Ud. ve es producto de la acción de bash, en otras palabras: está Ud. corriendo su primer programa Unix, el shell bash. Mientras esté conectado, el shell bash estará permanentemente funcionando. 4.1.1 Un comando Unix típico _______ El primer comando que debe conocer es cat. Para utilizarlo, escriba "cat" y luego oprima |_Intro_|: /home/larry$ cat Si tiene ahora el cursor posicionado en una línea nueva, entonces lo que ha hecho está bien. Existen unas cuantas variantes que podría haber tecleado_algunas funcionarán, otras no. o Si tuvo algún error de tecleo al escribir "cat" , debería haber visto algo más o menos así: /home/larry$ ct ct: command not found /home/larry$ Por lo tanto, el shell le informa que no pudo encontrar un programa denominado "ct" , y le ofrece otro prompt para seguir trabajando. Recuerde que Unix hace diferencia entre mayúsculas y minúsculas: CAT está mal escrito. o Puede que Ud. haya escrito algunos espacios en blanco antes del comando, como:5 /home/larry$ cat _____________________________________________4 N. del T.: La Fundación para el Software Libre _tal es la traducción de su nombre_ se ocupa de la producci** ón y distribución de software que no tiene limitaciones en su uso y/o copia, enfrentando de esta manera las prácti* *cas de las compañías tradicionales de desarrollo. Que el software sea libre no significa que sea barato: la libertad i* *ncluye la gratuidad, pero es mucho más que ello. 5El ` ' indica que el usuario escribió un espacio. _______________________________________________________________________________________________________________4.2. A* *utoayuda @ Sin embargo, el resultado es correcto, y el programa cat corre sin problemas. _______ o También puede que haya oprimido un |_Intro_|en una línea en blanco; no se preocupe y continúe, pues no tiene ningún efecto. Doy por sentado que Ud. ha corrido con éxito cat y está esperando que haga algo que lo maraville. Pues bien, no, no es un juego. cat es una_muy_útil_utilidad que no parece muy útil a primera vista. Escriba cualquier cosa y luego oprima |_Intro_|. Lo que verá es: /home/larry$ cat Help! I'm stuck in a Linux program! Help! I'm stuck in a Linux program! (El texto inclinado marca que es lo que he tecleado.) Lo que parece haber hecho cat es devolver un eco de lo escrito. Esto es útil a veces, tal vez no ahora. Así que salgamos de este programa y veamos otros con beneficios más obvios. ________ ________ Para finalizar ciertos comandos Unix, teclee |_Ctrl-d_|6. |_Ctrl-d_|es el carácter end-of-file7, o EOF, para abreviar. Puede que en ciertos libros de texto aparezca como end-of-text8. Nos referiremos a este carácter como EOF. Es un carácter de control que informa a los programas Unix que ha cesado el ingreso de datos. Cuando cat ve que no teclea más nada, termina. Para ver otro ejemplo parecido, pruebe el programa sort. Como su nombre lo indica, sort_es_ un programa de clasificación. Si Ud. teclea unas cuantas líneas y luego oprime |_Ctrl-d_|, sort las mostrará a la salida de manera ordenada. Esta clase de programas se denominan filtros, porque toman texto desde su entrada, lo filtran, y lo vierten a su salida modificado de alguna manera. Tanto cat como sort son filtros inusuales. cat es inusual pues lee el texto de entrada y no lo cambia. sort es inusual porque lee todas las líneas de entrada hasta el EOF, antes de emitir su salida. La mayoría de los filtros trabajan sobre la base de línea por línea: leen una línea de la entrada, realizan cierto cómputo, y escriben una línea diferente de salida. 4.2 Autoayuda El comando man muestra las páginas de la guía de referencia para un comando dado9. Por ejemplo: /home/larry$ man cat cat(1) cat(1) NAME ________________________________________________ ___ 6Mantenga oprimida la tecla etiquetada |_Ctrl|_y aprete |_d_|, luego suelte ambas. 7N. del T.: fin de archivo. 8N. del T.: fin de texto. 9man también puede mostrar información acerca de las llamadas al sistema, subrutinas, formatos de archivos, etc.. En la versión original de Unix el comando mostraba la información exactamente igual a la que aparecí* *a en la documentación impresa. Por ahora, es probable que Ud. sólo esté interesado en obtener ayuda acerca de los c* *omandos. _______________________________________________________________________________________________________________24 * * @ cat - Concatenates or displays files SYNOPSIS cat [-benstuvAET] [--number] [--number-nonblank] [--squeeze-blank] [--show-nonprinting] [--show-ends] [--show-tabs] [--show-all] [--help] [--version] [file...] DESCRIPTION This manual page documents the GNU version of cat ... Hay aproximadamente una página completa de información sobre cat10. Pruebe correr "man" en este momento. No espere entender la página de manual que se le muestra. Las páginas de manual suponen un cierto conocimiento de Unix _conocimiento que tal vez Ud. no tenga en este momento. Cuando termine de leer la página, es probable que vea un bloque en video inverso al final de la página, parecido a "--more--" o a "Line 1". Se trata del pedido de más (información), que pronto le será muy familiar. En lugar de dejar escapar el texto fuera de los límites de la pantalla, man se detiene al final de_cada_página,__y espera para ver que ha decidido hacer Ud.. Si desea seguir leyendo, oprima | Barra espaciadora |y avanzará una página. Si desea terminar con la lectura de la página del manual, |_____________________| oprima |_q_|. Regresará entonces al prompt del shell, que esperará hasta que Ud. escriba otro comando. man provee además una función de búsqueda de palabras clave. Por ejemplo, digamos que Ud. está interesado en el tema PostScript, el lenguaje de control de impresoras desarrollado por Adobe. Si escribe "man -k ps" o "man -k Postscript" , recibirá como resultado una lista de todos los comandos, llamadas al sistema, y otras partes documentadas de Unix que contengan la palabra "ps" (o "Postscript") en su nombre o descripción breve. Esto puede llegar a ser muy útil cuando quiere buscar una herramienta para hacer algo, pero no conoce su nombre _o si existe. 4.3 Almacenaje de la información Los filtros son muy útiles cuando Ud. se ha transformado en un usuario experimentado, pero tienen un pequeño problema. >Cómo almacena Ud. la información. Seguramente, dónde están? Acaba de encontrar el concepto de directorio "actual". Como puede ver en el prompt, su directorio actual es /home/larry y allí no hay archivos. Si desea la lista de archivos de un directorio más poblado, pruebe con el directorio raíz: /home/larry$ ls / _____________________________________________12 Puede haber o no un límite a la "profundidad" a la cual puede llegar el sistema de archivo. (En mi caso nunca la alcancé_uno fácilmente puede tener directorios de 10 niveles de profundidad.) 13N. del T.: Nombre relativo del archivo o directorio. 14N. del T.: Nombre completo o absoluto. 15N. del T.: trayectoria del inglés path. _______________________________________________________________________________________________________________26 * * @ _______________________________________________________________________________________________________________ Figura_4.1_Típico_árbol_(podado)_de_directorios_Unix.__________________________________________________ / ________||bin |___dev | |___etc | |___home ________larry | | | |___sam |___ | lib |___proc | |___tmp | | |___usr________||X11R6 | |___bin | |___emacs | |___ | etc | |___g++-include | |___include | |___lib | |___ ________ | local | bin | | | |___emacs | | | |___etc | | | |___lib | |___ | man | |___spool | |___src________linux | |___tmp _______________________________________________________________________________________________________________ bin etc install mnt root user var dev home lib proc tmp usr vmlinux /home/larry$ En el comando anterior, "ls /" , el directorio ("/" ) es lo que se denomina un parámetro. La primer palabra de un comando es el nombre del comando, y cualquier cosa que le siga son sus parámetros. Los parámetros generalmente modifican la forma en la que actúa un programa_para ls, el parámetro le dice de cual directorio desea Ud. la lista de archivos. Algunos comandos tienen parámetros especiales denominados opciones o interruptores16 Para ver esto, pruebe: /home/larry$ ls -F / bin/ etc/ install/ mnt/ root/ user/ var@ dev/ home/ lib/ proc/ tmp/ usr/ vmlinux /home/larry$ _____________________________________________16 N. del T.: interruptores del inglés switches. _______________________________________________________________________________________________________________4.3. A* *lmacenaje de la informac@ El "-F" es una opción. Las opciones son clases especiales de parámetros que comienzan con un guión y modifican el funcionamiento del programa. Para "ls" , "-F" es una opción que le permite a Ud. ver cuales de las entradas son directorios, cuales son archivos especiales, cuales programas, y cuales son archivos normales. Cualquiera que termina con una barra es un directorio. Trataremos con más detalle las características de ls más adelante. pwd /home/larry mousehouse> _______________________________________________________________________________________________________________ cd [directorio] _______________________________________________________________________________________________________________ Como puede Ud. ver, pwd le dice cuál es su directorio actual18_ se trata de un comando muy simple. La mayoría de los comandos actúa, de forma predeterminada, sobre el directorio actual. Podemos cambiar nuestro directorio actual mediante el comando cd. Por ejemplo, pruebe: /home/larry$ cd /home /home$ ls -F larry/ sam/ shutdown/ steve/ user1/ /home$ Si Ud. omite el parámetro opcional directorio, se lo retornará a su directorio raíz personal, o directorio original. De otro modo, cd lo cambiará al directorio especificado. Por ejemplo: /home$ cd /home/larry$ cd / /$ cd home /home$ cd /usr /usr$ cd local/bin /usr/local/bin$ Como puede ver, cd le permite expresar el directorio de destino con trayectorias absolutas o rela- tivas. Una trayectoria absoluta comienza con una "/" y especifica todos lo directorios que existen antes del archivo que Ud. desea. Una trayectoria relativa está referida a su directorio actual. En el ejemplo anterior, cuando estaba en "/usr", hice un movimiento relativo a "local/bin"_"local" es un directorio que existe bajo "/usr", y "bin" es un directorio bajo "local". ("cd home" también fue un cambio de directorio relativo.) Existen dos directorios que se utilizan solamente para trayectorias relativas: "." y "..". El directorio "." se refiere al directorio actual, y ".." es el directorio anterior: son "abreviaturas" de directorio, y existen en todos los directorios, aunque no cuadran bien en la metáfora de "carpeta dentro de carpeta". Aún el directorio raíz tiene un directorio anterior: él es su propio directorio anterior. _____________________________________________17 N. del T.: Directorio de trabajo actual. 18En este libro verá todos los términos en uso: directorio de trabajo presente, directorio actual, o directo* *rio de trabajo. Prefiero "directorio actual", aunque a veces recurra a las otras formas a causa de razones de estilo. _______________________________________________________________________________________________________________4.3. A* *lmacenaje de la informac@ El archivo ./chapter-1 viene a ser el archivo chapter-1 que está en el directorio actual. Ocasion- almente, será necesario que Ud. coloque explícitamente el "./" para que ciertos comandos funcionen, aunque esto es raro. En la mayoría de los casos, dará igual poner ./chapter-1 o chapter-1. El directorio ".." es más útil cuando queremos "retroceder": /usr/local/bin$ cd .. /usr/local$ ls -F archives/ bin/ emacs@ etc/ ka9q/ lib/ tcl@ /usr/local$ ls -F ../src cweb/ linux/ xmris/ /usr/local$ En este ejemplo, me cambié al directorio anterior mediante "cd .." y luego listé el directorio /usr/src desde /usr/local utilizando el nombre ../src. Debe advertir que si hubiese estado en /home/larry, ejecutar el comando "ls -F ../src" no me habría servido al propósito de ver lo que hay en /usr/src. El directorio "~/" es un alias para su directorio personal: /usr/local$ ls -F ~/ /usr/local$ Puede ver que aún no hay nada en su directorio personal. "~/" será más útil a medida que aprendamos más acerca de como manipular los archivos. 4.3.3 Creación y borrado de directorios _______________________________________________________________________________________________________________ mkdir directorio1 [directorio2 . . . directorioN] _______________________________________________________________________________________________________________ En Unix, crear directorios es extremadamente simple, y puede ser una muy útil herramienta de organización. Para crear un nuevo directorio, utilice el comando mkdir. Por supuesto, mkdir viene de make directory19. Con un pequeño ejemplo, veamos como funciona esto: /home/larry$ ls -F /home/larry$ mkdir report-1993 /home/larry$ ls -F report-1993/ /home/larry$ cd report-1993 /home/larry/report-1993$ mkdir puede tomar más de un parámetro, a los que interpreta como nombres de directorios que debe crear. Puede especificarlos mediante su nombre relativo o absoluto; report-1993 es un caso de_ejemplo_con_trayectoria_relativa._________ 19N. del T.: Crear directorio. _______________________________________________________________________________________________________________30 * * @ /home/larry/report-1993$ mkdir /home/larry/report-1993/chap1 ~/report-1993/chap2 /home/larry/report-1993$ ls -F chap1/ chap2/ /home/larry/report-1993$ _______________________________________________________________________________________________________________ rmdir directorio1 [directorio2 . . . directorioN] _______________________________________________________________________________________________________________ El opuesto de mkdir es rmdir (remove directory20). rmdir trabaja exactamente igual que mkdir. Un ejemplo de rmdir es: /home/larry/report-1993$ rmdir chap1 chap3 rmdir: chap3: No such file or directory /home/larry/report-1993$ ls -F chap2/ /home/larry/report-1993$ cd .. /home/larry$ rmdir report-1993 rmdir: report-1993: Directory not empty /home/larry$ Como puede apreciar, rmdir se niega a borrar un directorio que no existe, y tampoco permite eliminar directorios que tengan algo dentro. (Recuerde que report-1993 tiene un subdirectorio, chap2, dentro de él) Existe un tema interesante para pensar, entonces: >qué pasa si intenta eliminar su directorio actual? Averig"uémoslo: /home/larry$ cd report-1993 /home/larry/report-1993$ ls -F chap2/ /home/larry/report-1993$ rmdir chap2 /home/larry/report-1993$ rmdir . rmdir: .: Operation not permitted /home/larry/report-1993$ Otra situación del mismo estilo, es que sucede si intenta eliminar el directorio anterior al directorio actual. Bien, esto no es un problema nuevo: el directorio anterior al actual no está vacío (existe el actual en él), así que no puede ser borrado. 4.4 Información en movimiento Todos este asunto de los directorios está muy lindo, pero no son de ninguna ayuda, a menos que Ud. tenga algún sitio donde almacenar sus datos. Los dioses del Unix vieron este problema y lo solucionaron haciendo que los usuarios tengan archivos21 _____________________________________________20 N. del T.: Eliminar directorio. 21N. del T.: También denominados ficheros. _______________________________________________________________________________________________________________4.4. I* *nformación en movimi@ Aprenderemos más acerca de la creación y edición de archivos en los próximos capítulos. Los comandos básicos para manipular archivos en Unix son cp, mv, y rm. Sus nombres provienen de copy22, move23, y remove24, respectivamente. 4.4.1 cp como un monje _______________________________________________________________________________________________________________ cp [-i] fuente destino cp [-i] archivo1 archivo2 . . . archivoN directorio-de-destino25 _______________________________________________________________________________________________________________ cp es una utilidad muy práctica en Unix, y además muy poderosa. Permite que una persona pueda copiar más información en un segundo que lo que podía copiar un monje del siglo XIV en todo un año. Debe ser muy cuidadoso con cp si no dispone de una cantidad importante de espacio en disco. A nadie le hace gracia ver el mensaje "Disk full"26 cuando está trabajando con archivos importantes. cp también puede sobreescribir archivos existentes sin previo aviso _trataremos este tema más adelante. Bien, hablaremos primero acerca de la primer línea en la plantilla del comando. El primer parámetro de cp es el nombre del archivo que hay que copiar, el segundo es el lugar donde se desea depositar la copia. Puede obtener una copia con un nombre distinto, o una en un directorio diferente. Veamos algunos ejemplos: /home/larry$ ls -F /etc/passwd /etc/passwd /home/larry$ cp /etc/passwd . /home/larry$ ls -F passwd /home/larry$ cp passwd frog /home/larry$ ls -F frog passwd /home/larry$ El primer comando cp que corrí tomó el archivo /etc/passwd, que contiene los nombres de todos los usuarios en un sistema Unix, y lo copió en mi directorio raíz. cp no borra el archivo fuente, así que no hice nada que pudiera dañar el sistema. O sea que ahora existen dos copias del contenido del archivo /etc/passwd, ambas se denominan passwd, pero una está en el directorio /etc y la otra en /home/larry. _____________________________________________22 N. del T.: Copiar. 23N. del T.: Mover. 24N. del T.: Quitar, borrar. 25cp necesita de dos renglones en su plantilla porque el significado del segundo parámetro depende de la cantidad de parámetros. 26N. del T.: Disco lleno. _______________________________________________________________________________________________________________32 * * @ Luego, creamos una tercera copia de /etc/passwd cuando tecleamos "cp passwd frog" _ ahora hay tres copias: /etc/passwd, /home/larry/passwd y /home/larry/frog. El contenido de esos tres archivos es el mismo, sus nombres de archivo difieren. cp puede copiar archivos entre directorios si el primer parámetro es un archivo y el segundo es un directorio. En este caso, el nombre simple (sin el path) de destino coincidirá con el original, para cada archivo. También se puede copiar un archivo y cambiar su nombre de destino en una sola operación, caso que se da cuando ambos parámetros son nombres de archivo. Aquí reside uno de los peligros de cp. Si tecleara "cp /etc/passwd /etc/group" , el comando cp crearía normalmente un archivo nuevo con el contenido idéntico al de /etc/passwd y con el nombre /etc/group. Por lo tanto, si /etc/group ya existiera, cp destruiría el contenido del antiguo sin darle la oportunidad de guardarlo. (Ni siquiera escribirá un mensaje en el cual le advierta que está por destruir un archivo al copiarle otro encima.) Echemos una mirada a otro ejemplo de cp: /home/larry$ ls -F frog passwd /home/larry$ mkdir passwd_version /home/larry$ cp frog passwd passwd_version /home/larry$ ls -F frog passwd passwd_version/ /home/larry$ ls -F passwd_version frog passwd /home/larry$ >Cómo usé cp en este caso? Evidentemente, cp puede tomar más de dos parámetros, como se puede apreciar en la segunda línea de plantillas del comando. Lo que el comando anterior realizó es copiar los archivos que aparecen listados (frog, y passwd) al directorio passwd_version. De hecho, cp puede tomar cualquier número de parámetros: interpreta los primeros n - 1 como los nombres de archivo que debe copiar, y el nésimoparámetro como el nombre del directorio al cual se deben copiar los anteriores. No puede renombrar archivos cuando copia más de uno a la vez_siempre mantienen su nom- bre simple. Esto nos lleva a una pregunta interesante. >Qué es lo que pasaría si tecleamos "cp frog passwd toad" , donde frog y passwd existen, y toad no es un directorio? Inténtelo y lo sabrá. 4.4.2 La poda con rm _______________________________________________________________________________________________________________ rm [-i] archivo1 archivo2 . . . archivoN _______________________________________________________________________________________________________________ Ahora que hemos aprendido como crear millones de archivos con cp (y créame, muy pronto encontrará nuevas maneras de crear más archivos), sería útil aprender la manera de borrarlos. De _______________________________________________________________________________________________________________4.4. I* *nformación en movimi@ hecho, es muy simple: el comando que anda necesitando es rm, y funciona como Ud. se lo esperaría: a cualquier archivo cuyo nombre se pasa como parámetro a rm se lo borra. Por ejemplo: /home/larry$ ls -F frog passwd passwd_version/ /home/larry$ rm frog toad passwd rm: toad: No such file or directory /home/larry$ ls -F passwd_version/ /home/larry$ Como puede Ud. apreciar, rm es extremadamente espartano. No sólo no pide su confirmación, sino que borra cosas aún en el caso en que haya errores en la línea de comandos. Esto bien puede ser peligroso. Considere la diferencia entre estos dos comandos: /home/larry$ ls -F toad frog/ /home/larry$ ls -F frog toad /home/larry$ rm frog/toad /home/larry$ y este otro: /home/larry$ rm frog toad rm: frog is a directory /home/larry$ ls -F frog/ /home/larry$ Como puede ver, la diferencia en un caracter hace una diferencia importante en la salida del comando._Qué es el sistema de ventanas X? El Sistema de Ventanas X es un método de trabajo gráfico y distribuido, desarrollado principal- mente en el Instituto Tecnológico de Massachusetts. Actualmente está a cargo de un consorcio de fabricantes (debidamente llamado "El Consorcio X") y es mantenido por ellos. El Sistema de Ventanas X (que a partir de ahora abreviaremos como "X"6 tiene revisiones cada pocos años, conocidas como lanzamientos. La última revisión ha sido X11R6, o sexto lanzamiento7. El número 11 indica la versión oficial pero no ha habido cambios en los últimos años y tampoco hay planes para cambiarla en un futuro próximo. Al ser cliente y servidores programas diferentes, es posible ejecutar cada uno en en máquinas completamente diferentes. Además de constituir un método estándar para aplicaciones gráficas, es posible ejecutar un programa en una máquina remota (Qué es esto que hay en mi pantalla? Al arrancar X, varios programas son ejecutados. Primero, arranca el servidor. Luego, generalmente arrancan varios clientes. Desgraciadamente no hay un estándar común entre las diferentes distribu- _____________________________________________1 N.T.: En inglés, salir del gestor de ventanas 2N.T.: En inglés, salir de X. 3N.T.: En inglés, ingreso en el sistema o autenticación. 4N.T.: En inglés, xterm del sistema o terminal X del sistema. 5N.T.: En inglés, salir. 6Existen varias formas de referirse al Sistema de Ventanas X. Una forma que aunque común es incorrecta es "X Window" o "Ventanas X". 7N.T.: La palabra inglesa es "release". Por ello los lanzamientos se diferencian añadiendo una R y el núme* *ro correspondiente. _______________________________________________________________________________________________________________5.3. >* *Qué es esto que hay @ _______________________________________________________________________________________________________________ Figura 5.1 Ejemplo comentado de una pantalla X estándar. En este ejemplo el usuario está ejecutando_twm._El_reloj_estándar_ha_sido_sustituído_por_uno_transparente_llamado_oclock.______________ _______________________________________________________________________________________________________________ ciones. Es bastante probable que entre los clientes se encuentre un gestor de ventanas, bien fvwm o twm, un intérprete de comandos, xterm, y un reloj, xclock. 5.3.1 XClock _______________________________________________________________________________________________________________ xclock [-digital] [-analog] [-update segundos] [-hands color] _______________________________________________________________________________________________________________ Primero explicaremos el más simple: xclock funciona exáctamente como se puede esperar. Marca los segundos, minutos y horas en una ventana pequeña. Ni usar los botones del ratón, ni escribir en la ventana xclock produce efecto alguno- eso es todo lo que hace. >O quizá no? En realidad hay varias opciones diferentes que permiten hacer que el programa se comporte de modos diferentes. Así, por ejemplo, "xclock -digital" crea un reloj digital. "xclock -update 1" hace que el segundero se mueva cada segundo y "xclock -update 5" _______________________________________________________________________________________________________________38 * * @ hace que se mueva cada cinco segundos. Para obtener más información sobre las opciones de xclock puede consultar la página del manual correspondiente_"man xclock" . Si piensa ejecutar varias copias de xclock, probablemente debería consultar la Sección 6.4 (Multitarea) para saber como se ejecutan a la vez que sus otros programas. (Si ejecuta una copia de xclock en primer plano_que_es_la_forma usual en la que se ejecuta un programa_y quiere salir de él, basta teclear |_Ctrl-c_|.) 5.3.2 XTerm La ventana que muestra el prompt del intérprete de comandos (podrá ver algo parecido a /home/larry$) es controlada por un programa llamado xterm. xterm es un programa engañosamente complicado. A primera vista, no parece que haga mucho pero realmente hace muchísimo trabajo. xterm emula una terminal de forma que las aplicaciones de modo texto de Unix funcionen correctamente. También mantiene en memoria información de forma que se pueden consultar comandos usados previamente. (Para ver como hace uso de esto, refiérase a la Sección 5.6.3.) Gran parte de este libro está dedicada a aprender como usar el interprete de comandos de Unix que se encuentra dentro de la ventana xterm. Para poder escribir en la xterm, generalmente es necesario mover el cursor (que posiblemente aparece en forma de "X" o de flecha) al interior de la ventana xterm. De todos modos este comportamiento es dependiente del gestor de ventanas. Uno de los modos en los que se puede arrancar un programa bajo X es a través de una xterm. Al tratarse los programas X de programas Unix estándar, pueden ser arrancados a través de un intérprete de comandos como el de las xterms. Para evitar bloquear la xterm ejecutando un programa largo desde ella, generalmente se prefiere arrancar los programas X en segundo plano. Para consultar este tema puede referirse a la Sección 6.4. 5.4 Gestores de ventanas Bajo Linux, los gestores de ventanas más comunes son dos. El primero, llamado twm que viene de "Tab Window Manager". Es un programa mayor que el segundo, fvwm. (fvwm viene de "F(?) Virtual Window Manager"_el autor nunca explicó que significaba la "f"8.). Ambos gestores de ventanas son altamente configurables lo cual impide dar instrucciones específicas sobre que teclas usar para hacer algo en particular. Si le interesa saber algo sobre la configuración de twm, refiérase a la Sección 9.2.1. La configuraci*** **'on de fvwm se describe en la Sección 9.2.2. 5.4.1 Cuando se crean nuevas ventanas Hay tres tipos de cosas que un gestor de ventanas puede hacer cuando se crea una nueva ventana. Es posible_configurar_el_gestor_de_ventanas_de_manera_que aparezca la forma de la ventana, permitiéndole 8N. del T.: En el Linux Journal N.o 43, Noviembre 1997, hay una entrevista a Robert Nation, págs. 46-47, y é* *ste dice que la "F"está por"Feeble"(Gracias José Luis Gurpegui por la aclaración.) _______________________________________________________________________________________________________________5.4. G* *estores de ventanas @ colocarla en la posición que prefiera en la pantalla. Este modo se llama colcación manual. Si ve aparecer la forma de la ventana, puede moverla con el ratón y colocarla presionando el botón izquierdo. A veces es posible que el gestor de ventanas las coloque por sí mismo. Se trata de la colocación aleatoria. Finalmente, a veces, la aplicación pregunta por el lugar preciso en el que el quiere que se situe. También el gestor de ventanas puede configurarse de forma que siempre sitúe las ventanas de ciertas aplicaciones en lugares fijos. (Así por ejemplo, se puede especificar que xclock siempre aparezca en la esquina superior derecha de la pantalla.) 5.4.2 Foco El gestor de ventanas controla otras cosas importantes. Lo que probablemente le interesa más es el foco. El foco del servidor determina que ventana recibe los carácteres introducidos mediante el teclado. Generalmente, en X, el foco es determinado por la posición del cursor del ratón. Si mueve el cursor del ratón dentro de una ventana xterm9, esa xterm recibe los caracteres tecleados. Se trata de un comportamiento diferente al de otros sistemas de ventanas como, Windows de Microsoft, OS/2, o Macintosh, donde debe pinchar con el ratón en una ventana para que adquiera el foco. Generalmente bajo X, si el cursor del ratón se sale de una ventana, se pierde el foco y le resultará imposible escribir en ella. Debe notar, sin embargo, que es posible configurar tanto twm como fvwm de forma que para cambiar el foco necesite pinchar la ventana correspondiente, y pinchar fuera para desenfocarla, de forma que se comporten igual que Windows de Microsoft. Una de dos, trate de averiguar como funciona su gestor de ventanas probando o consulte la documentación local. 5.4.3 Moviendo ventanas Otro aspecto de X que es altamente configurable es el método para mover ventanas. Yo tengo configurados tres métodos para mover ventanas en twm. El más obvio es mover el cursor del ratón sobre la barra del título y arrastrar la ventana. Desgraciadamente, la configuración permite definir el movimiento usando cualquiera de los tres botones10 (Para arrastrar, sitúe el cursor sobre la barra del título, y mantenga presionado el botón del ratón correspondiente mientras se mueve). Lo más probable es que su configuración use el botón izquierdo para mover ventanas. Otra forma de mover ventanas puede ser manteniendo una tecla_pulsada_mientras mueve el ratón. Así, en mi caso, si mantengo pulsada la tecla |_Alt_|y muevo el cursor sobre una ventana, puedo arrastrarla usando el boton izquierdo de mi ratón. Por supuesto, para ver como funciona en su caso puede probar igual que antes o referirse a la documentación local. Alternativamente, si quiere tratar de interpretar los ficheros de configuración de_los_gestores_de_ventanas_puede_referirse_a_la Sección 9.2.1 para twm o 9.2.2 para fvwm. 9Qué cree que "cp d*w /backup" puede haber hecho? 47 _______________________________________________________________________________________________________________48 * * @ 6.1.1 >Qué ocurre realmente ? Buena pregunta. De hecho, hay un par de carácteres especiales interceptados por el shell, bash. El carácter "*" , un asterisco, dice "cambia esta palabra con todos los ficheros que se ajusten a esta es- pecificación". Así, el comando "cp data* /backup" , como el de arriba, cambia a "cp data-new data1 dat* *a2 data5 /backup" antes de ejecutarse. Para ilustrar esto, introduciré un comando nuevo, echo. echo es un comando extremadamente simple; repite, o muestra, cualquier parámetro. De este modo: /home/larry$ echo Hola! Hola! /home/larry$ echo Como se encuentra? Como se encuentra? /home/larry$ cd report /home/larry/report$ ls -F 1993-1 1994-1 data1 data5 1993-2 data-new data2 /home/larry/report$ echo 199* 1993-1 1993-2 1994-1 /home/larry/report$ echo *4* 1994-1 /home/larry/report$ echo *2* 1993-2 data2 /home/larry/report$ Como se puede ver, el shell expande el comodín y pasa todos los ficheros al programa que se va a ejecutar. Esto plantea una pregunta interesante: >qué ocurre si no hay ficheros que se ajusten a la especificación del comodín? Pruebe "echo /rc/fr*og" y bash pasará literalmente la especificación del comodín al programa. Otros shells, como tcsh, en vez de pasar el comodín literalmente, contestarán No match. Aquí está el mismo comando ejecutado bajo tcsh: mousehouse>echo /rc/fr*og echo: No match. mousehouse> La última pregunta que podría hacerse es, >qué pasa si quisiera mostrar data*, en vez de la lista de nombres? Bien, tanto en bash como en tcsh, sólo se debe incluir la cadena entre comillas: /home/larry/report$ echo "data*" mousehouse>echo "data*" data* Ó bien data* /home/larry/report$ mousehouse> 6.1.2 El signo de interrogación Además del asterisco, el shell también interpreta un signo de interrogación como un carácter especial. Un signo de interrogación coincidirá con un carácter, y sólo uno. Por ejemplo, "ls /etc/* *??" mostrará todos los ficheros de dos letras en el directorio /etc. _______________________________________________________________________________________________________________6.2. G* *anar tiempo con bash @ 6.2 Ganar tiempo con bash 6.2.1 Editando la línea de comandos _______ A veces, escribe un comando largo a bash y, antes de pulsar |_Intro_|, se da cuenta de que ha cometido un error al escribirlo. Se puede simplemente borrar todo y volver a teclear correctamente, pero Como se pueden ver todos los ficheros? 6.3.1 Algunos conceptos de Unix El sistema operativo Unix facilita mucho a los programas el uso del terminal. Cuando un programa escribe algo en la pantalla, está usando algo llamado salida estándar. Salida estándar, en inglés standard output o stdout, es la manera que tiene el programa de escribirle cosas al usuario. El nombre por el que se indica un programa es entrada estándar (stdin). Es posible que un programa se comunique con el usuario sin usar la entrada o salida estándar, pero la mayoría de los comandos que se tratan en este libro usan stdin y stdout. Por ejemplo, el comando ls imprime una lista de los directorios en la salida estándar, que está normalmente "conectada" al terminal. Un comando interactivo, como el shell, bash, lee los comandos de la entrada estándar. Un programa también puede escribir en el error estándar, ya que es muy fácil hacer que la salida estándar apunte a cualquier lugar aparte del terminal. El error estándar (stderr) está casi siempre conectado al terminal para que alguna persona pueda leer el mensaje. En esta sección, examinaremos tres modos de enredarse con la entrada y salida estándar: redi- reccionar la salida, redireccionar la entrada, y las tuberías. 6.3.2 Redireccionar la salida Un aspecto muy importante de Unix es la posibilidad de redireccionar la salida. Esto permite que, en vez de ver los resultados de un comando, los salvemos en un fichero o los enviemos directamente a una impresora. Por ejemplo, para redireccionar la salida del comando "ls /usr/bin" , se coloca un signo ">" al final de la línea, y se indica el fichero donde dejar la salida: /home/larry$ ls /home/larry$ ls -F /usr/bin > listado /home/larry$ ls listado /home/larry$ Como se puede ver, en vez de escribir los nombres de todos los ficheros, el comando crea un fichero totalmente nuevo en el directorio actual. Echemos un vistazo a este fichero usando el comando cat. Si se recuerda, cat era un comando bastante inútil que copiaba lo que se escribía (entrada estándar) al terminal (salida estándar). cat también imprime un fichero en la salida estándar si se indica el fichero como parámetro: /home/larry$ cat listado _______________________________________________________________________________________________________________6.3. L* *a entrada estándar y@ .. /home/larry$ La salida exacta del comando "ls /usr/bin" aparece en el contenido de listado. Por ahora todo bien, sin embargo no resuelve el problema original.3 A pesar de todo, cat hace algunas cosas interesantes cuando se redirecciona su salida. >Qué hace el comando "cat listado > fichero" ? Normalmente, el "> fichero" dice "coge toda la salida del comando y ponla en fichero". La salida del comando "cat listado" es el fichero listado. Así hemos inventado un nuevo (y no tan eficiente) método de copiar ficheros. >Qué ocurre con el comando "cat > zorro" ? cat lee cada línea_escrita_en el terminal (entrada estándar) y la imprime de vuelta (salida estándar) hasta que lee |_Ctrl-d_|. En este caso, la salida estándar se ha redireccionado al fichero zorro. Ahora cat sirve como un editor rudimentario: /home/larry$ cat > zorro El rapido zorro marron salta sobre el descuidado perro. pulsa Ctrl-d Ahora se ha creado el fichero zorro que contiene la frase "El rapido zorro marron salta sobre el de- scuidado perro". Un último uso del versátil comando cat es concatenar ficheros. cat imprimirá cada fichero dado como parámetro, uno despues de otro. El comando "cat listado zorro" imprimirá el listado del directorio /usr/bin, y luego la tonta frase. Así, el comando "cat listado zorro > listyzorro" creará un nuevo fichero conteniendo los contenidos de listado y zorro. 6.3.3 Redireccionar la entrada Así como cuando se redirecciona la salida estándar, es posible redireccionar la entrada. En lugar de que un programa lea su entrada desde el teclado, la leerá desde un fichero. Como redireccionar la entrada está relacionado con redireccionar la salida, parece natural que "<" sea el carácter para redireccionar la entrada. Éste también se usa después del comando que se desee ejecutar. Esto es generalmente útil si se tiene un fichero de datos y un comando que espera sus datos desde la entrada estándar. Muchos comandos permiten especificar un fichero sobre el cual operar, así que en las actividades diarias el "<" no se usa tanto como otras técnicas. 6.3.4 Las tuberías Muchos comandos Unix producen gran cantidad de información. Por ejemplo, es normal que un comando como "ls /usr/bin" produzca más salida que la que se puede ver en pantalla. Para que se pueda ver toda la información de un comando como "ls /usr/bin" , es necesario usar otro comando_Unix__llamado_more4.__more_parará_cada vez que la pantalla se llene de información. Por 3Para lectores impacientes, el comando que se debe usar es more. Sin embargo, hay que hablar un poco sobre algo más antes de llegar ahí. 4Se llama more porque ese es el indicador que originalmente mostraba: "--more--". En varias versiones de Linux el comando more es identico a un comando más avanzado que hace todo lo que more puede hacer y más aún. Como demostración de que los programadores de ordenadores son malos cómicos, llamaron a este nuevo programa "less". _______________________________________________________________________________________________________________52 * * @ ejemplo, "more < /etc/rc" mostrará el fichero /etc/rc como lo haría "cat /etc/rc" , excepto que more permite leerlo. more también admite el comando "more /etc/rc" , y esa es la forma normal de invocarlo. Sin embargo, eso no ayuda al problema de que "ls /usr/bin" muestre más información de la que se pueda ver. "more < ls /usr/bin" no funciona_ temp-ls /home/larry$ more temp-ls .. /home/larry$ rm temp-ls Pero, Unix propone una forma más limpia de hacerlo. Se puede usar el comando "ls /usr/bin _ more" . El carácter "_" es una tubería. Como una tubería de agua, una tubería Unix controla el flujo. En vez de agua, se controla el flujo de información. Los filtros son programas muy útiles para usarse en conjunción con las tuberías. Un filtro es un programa que lee la entrada estándar, la cambia de alguna manera, y la saca por la salida estándar. more es un filtro_lee los datos que coge de la entrada estándar y los muestra por la salida estándar pantalla a pantalla, permitiendo leer el fichero. more no es un gran filtro porque su salida no se puede enviar a otro programa. Otros filtros incluyen los programas cat, sort, head, y tail. Por ejemplo, si se quiere leer sólo las primeras diez líneas de la salida de ls, se puede usar "ls /usr/bin _ head" . 6.4 Multitarea 6.4.1 Usando el control de trabajos Control de trabajos se refiere a la habilidad de poner procesos (esencialmente, otra palabra para programas) en background (segundo plano) y ponerlos de vuelta en foreground (primer plano). Esto es como decir, que se quiere ser capaz de ejecutar algo mientras se hacen otras cosas, pero que estén ahí otra vez cuando se les quiera decir algo o pararlos. En Unix, la principal herramienta para el control de procesos es el shell_seguirá la pista de los procesos por usted, si se aprende como hablar su lenguaje. Las dos palabras más importantes en ese lenguaje son fg, para primer plano, y bg, para segundo plano. Para entender como funcionan, use el comando yes en el indicador del sistema. /home/larry$ yes Esto produce el maravilloso efecto de desplazar una larga columna de yes por la parte_izquierda_de la pantalla, tan rápido que no se pueden seguir5. Para pararlo, se podría pulsar |_Ctrl-c_|y matarlo, _____________________________________________5 Hay buenas razones para que este extraño comando exista. Ciertos comandos esperan una confirmación _un "si" ([y]es en inglés) a una pregunta. El comando yes permite al programador automatizar la respuesta a esas preguntas. _______________________________________________________________________________________________________________6.4. M* *ultitarea @ ________ pero esta vez Ud. oprimirá |_Ctrl-z_|. Parece haberse detenido, pero habrá un mensaje antes del indicador de sistema, más o menos parecido a este: [1]+ Stopped yes Significa que el trabajo yes se ha suspendido en el segundo plano. Se puede hacer que siga ejecutándose tecleando fg en el indicador de sistema, que lo pondrá en primer plano otra vez. Si se desea, se pueden hacer otras cosas antes, mientras está suspendido. Pruebe unos cuantos ls o algo antes de ponerlo en primer plano nuevamente. Una vez que ha vuelto al primer plano, las yes empezarán a salir otra vez, tan rápido como antes. No hay que preocuparse de que si mientras ha estado suspendido ha "almacenado" más yes para enviarlas a la pantalla: cuando un trabajo se suspende,_el programa entero no se ejecuta hasta que se lo vuelva de vuelta a la vida. (Ahora pulse |_Ctrl-c_|para matarlo de veras). Pongamos aparte el mensaje que obtuvimos del shell: [1]+ Stopped yes El número entre corchetes es el número de trabajo de este proceso, y se usará cuando se necesite referenciarlo específicamente. (Naturalmente, desde el momento que tengamos en ejecución múltiples trabajos, se necesita un modo de acceder a cada uno). El "+" siguiente indica que ése es el "trabajo actual" _ esto es, el proceso más reciente que se ha movido del primer plano al segundo. Si se tecleara "fg" , se pondría el trabajo con el "+" en primer plano otra vez. (Más sobre esto después, cuando se discuta la ejecución de múltiples trabajos a la vez). La palabra Stopped significa que el trabajo está "parado". El trabajo no está muerto, pero actualmente no se ejecuta. Linux lo ha guardado en un estado especial de suspendido, listo para saltar a la acción cuando alguien lo solicite. Finalmente, el yes es el nombre del trabajo que se ha detenido. Antes de seguir adelante, matemos este trabajo y lo arrancamos otra vez de forma diferente. El comando se llama kill y se usa del siguiente modo: /home/larry$ kill %1 [1]+ Stopped yes /home/larry$ Ese mensaje sobre el proceso que indica "parado" otra vez induce a error. Para saber si aún está vivo (eso es, tanto en ejecución como congelado en un estado suspendido), teclee "jobs" : /home/larry$ jobs [1]+ Terminated yes /home/larry$ Ahora ya lo sabe: /dev/null Si lee la sección sobre la redirección de entrada y salida, sabrá que se está enviando la salida de yes a un fichero especial llamado /dev/null. /dev/null es un agujero negro que come cualquier salida que se le envíe (se puede imaginar ese torrente de yes saliendo por detrás del ordenador y perforando un agujero en la pared, si eso le hace feliz). Despues de teclear esto, no se recuperará el indicador de sistema, pero tampoco saldrá esa columna de yes. Sin embargo la salida se está enviando_a_/dev/null,_el trabajo aún se ejecuta en primer plano. Como siempre, se puede suspender pulsando |_Ctrl-z_|. Hágalo ahora para volver al indicador del sistema. /home/larry$ yes > /dev/null ["yes" se ejecuta, y solamente se ha pulsado Ctrl-z] [1]+ Stopped yes >/dev/null /home/larry$ Hmm. . . >hay alguna forma de ponerlo en ejecución en segundo plano, mientras deja el indicador del sistema para trabajar de forma interactiva? El comando para hacer eso es bg: /home/larry$ bg [1]+ yes >/dev/null & /home/larry$ Ahora, deberá tener confianza en mí sobre esto: después de teclear bg, el trabajo "yes > /dev/null" habrá continuado con su ejecución otra vez, pero esta vez en segundo plano. De hecho, si hace al- guna cosa en el prompt, como ls u otros, se dará cuenta que su máquina se ha ralentizado un poco (/dev/null [ahora esta en primer plano. Imagine que pulso Ctrl-c para terminarlo] /home/larry$ Bueno, se acabó. Ahora, ejecute unos cuantos trabajos simultáneamente, como estos: /home/larry$ yes > /dev/null & [1] 1024 /home/larry$ yes _ sort > /dev/null & [2] 1026 _______________________________________________________________________________________________________________6.4. M* *ultitarea @ /home/larry$ yes _ uniq > /dev/null [y aqui, pulse Ctrl-z para suspenderlo, por favor] [3]+ Stopped yes _ uniq >/dev/null /home/larry$ La primera cosa que le debe llamar la atención de estos comandos es la terminación "&" al final de los dos primeros. Poner un "&" después del comando indica al shell que los ejecute_en_segundo_ plano desde el principio. (Es una forma de evitarse tener que ejecutar el programa, pulsar |_Ctrl-z_|, y luego teclear "bg" .) Así, estos dos comandos han empezado a ejecutarse en segundo plano. El tercero está suspendido e inactivo en este momento. Se puede dar cuenta de que la máquina se ha vuelto más lenta, ya que los que se están ejecutando requieren un poco de tiempo de CPU. Cada uno indica su número de trabajo. Los dos primeros también muestran sus números de identificación de proceso, o PID, despues del número de trabajo. Los PIDs normalmente no son algo que se necesite conocer, pero a veces viene bien. Matemos el segundo, ya que creo que está ralentizando su máquina. Se puede teclear "kill %2" , pero eso sería demasiado fácil. Por el contrario, haga esto: /home/larry$ fg %2 yes _ sort >/dev/null [pulse Ctrl-c para matarlo] /home/larry$ Como esto demuestra, fg toma parámetros empezando con "%" . De hecho, se podría teclear sólo esto: /home/larry$ %2 yes _ sort >/dev/null [pulse Ctrl-c para matarlo] /home/larry$ Esto funciona por que el shell automáticamente interpreta un número de trabajo como una petición para poner ese trabajo en primer plano. Se puede indicar los números de trabajo con otros números precedidos por un "%". Ahora teclee "jobs" para ver cuáles trabajos quedan en ejecución: /home/larry$ jobs [1]- Running yes >/dev/null & [3]+ Stopped yes _ uniq >/dev/null /home/larry$ El "-" indica que ese trabajo número 1 es segundo en la lista para ser puesto en el primer plano, si sólo se teclea "fg" sin dar parámetros. El "+" indica que el trabajo especificado es el primero en la lista_un "fg" sin parámetros pondrá al trabajo número 3 en el primer plano. Sin embargo, se puede acceder a él llamándolo, si se desea, mediante: _______________________________________________________________________________________________________________56 * * @ /home/larry$ fg %1 yes >/dev/null [ahora pulse Ctrl-z para suspenderlo] [1]+ Stopped yes >/dev/null /home/larry$ Al cambiar al trabajo número 1 y luego suspenderlo han cambiado las proridades de todos los trabajos de usuario. Esto se puede ver con el comando jobs: /home/larry$ jobs [1]+ Stopped yes >/dev/null [3]- Stopped yes _ uniq >/dev/null /home/larry$ ________ Ahora los dos están parados (porque los dos se han suspendido con |_Ctrl-z_|), y el número 1 es el siguiente en la lista a entrar en el primer plano por defecto. Esto es así porque se le puso en el primer plano manualmente, y luego fue suspendido. El "+" siempre se refiere al trabajo más reciente que ha sido suspendido del primer plano. Se puede continuar con su ejecución otra vez: /home/larry$ bg [1]+ yes >/dev/null & /home/larry$ jobs [1]- Running yes >/dev/null [3]+ Stopped yes _ uniq >/dev/null /home/larry$ Fíjese que ahora está en ejecución, y el otro trabajo se ha movido en la lista y tiene el "+" . Ahora matémoslos para que el sistema no esté permanentemente ralentizado por procesos que no hacen nada. /home/larry$ kill %1 %3 [3] Terminated yes _ uniq >/dev/null /home/larry$ jobs [1]+ Terminated yes >/dev/null /home/larry$ Aparecerán varios mensajes sobre la terminación de los trabajos_nada muere tranquilamente, al parecer. La figura 6.1 de la página 59 muestra un breve resumen de lo que se debe saber acerca del control de trabajos. 6.4.2 Teoría del control de trabajos Es importante entender que el control de procesos lo hace el shell. No hay ningún programa en el sistema llamado fg; por eso, fg, bg, &, jobs, y kill son internos al shell6. (A veces kill es un programa_independiente;_en_el_shell_bash_usado_por Linux pertenece al shell). Esto es una forma 6N. del T.: En el original pone "shell-builtins", eso es que se compilan dentro del shell. _______________________________________________________________________________________________________________6.5. C* *onsolas virtuales: como@ lógica de hacerlo: ya que cada usuario quiere su propio espacio de control de trabajos, y cada usuario ya tiene su propio shell, es más fácil que el shell siga la pista de los trabajos usuario. Por otro lado, cada número de trabajo de usuario sólo tiene significado para ese usuario: mi trabajo número [1] y su trabajo número [1] son probablemente dos procesos totalmente diferentes. De hecho, si se está conectado más de una vez, cada uno de los shells tendrá datos únicos sobre el control de trabajos, así como también un usuario puede tener dos trabajos diferentes con el mismo número ejecutándose en dos shells diferentes. La manera segura de referenciarlos es usar el número IDentificador de Proceso (PID). Estos números abarcan todo el sistema _ cada proceso tiene su propio (y único) número. Dos usuarios diferentes pueden referenciar un proceso por su PID y saber que están hablando sobre el mismo proceso ( /dev/null" en segundo plano, se ejecuta "ps" , y se busca el yes. Luego se teclea "kill PID" 8 . Si empieza a programar en C con su sistema Linux, pronto aprenderá que el control de trabajos del shell es sólo una versión interactiva de las llamadas a las funciones fork y execl. Esto es demasiado complejo para explicarlo aquí, pero sería útil recordarlo después cuando se esté programando y se quieran ejecutar múltiples procesos desde un simple programa. 6.5 Consolas virtuales: como estar en varios lugares a la vez Linux soporta consolas virtuales. Son una manera de hacer que su simple máquina aparezca como múltiples terminales, todos conectados al mismo núcleo Linux. Por fortuna, usar las consolas virtuales es una de las cosas más simples en Linux: hay "hot keys"9 para cambiar_entre las consolas rápidamente. Para probarlo, hay que conectarse al sistema, pulsar la tecla |_Alt_|izquierda, y pulsar _____________________________________________7 Esto sólo tiene sentido para ciertos programas que no tienen que hablar con el usuario a través del teclado. 8En general, es más fácil matar el número del trabajo en vez de usar PIDs. 9N.T.: No he creido apropiado traducir este término, ya que muchos usuarios saben a lo que se refiere. De todas formas para el que no lo sepa, esto es, una simple combinación de teclas que hace un cierto trabajo. _______________________________________________________________________________________________________________58 * * @ _____ |_F2_ |(esto es, la tecla de función número 2)10 11. Se encontrará con otro indicador para conectarse. No se alarme: ahora está en la consola virtual (VC) número 2. Conéctese y haga algunas cosas _ unos cuantos ls o lo_que_sea _ para confirmar_ que es un shell real. Ahora puede volver a la VC número_1, pulsando el |_Alt_|izquierdo y |_F1_.| O se puede mover a una tercera VC, de la forma obvia (|_Alt-F3_)|. Generalmente los sistemas Linux vienen con cuatro VC activadas por defecto. Esto se puede incrementar a ocho; estos temas se cubrirán en The Linux System Administrator's Guide. Ello implica editar uno o dos ficheros en el directorio /etc. Sin embargo, cuatro deben ser suficientes para la mayoría de las personas. Una vez las haya usado, las VC probablemente se convertirán en una herramienta indispensable para tener varias cosas ejecutándose a la vez. Por ejemplo, yo normalmente ejecuto Emacs en la VC 1 (y hago la mayor parte de mi trabajo ahí), mientras tengo un programa de comunicaciones en la VC 3 (así puede coger o dejar ficheros via modem mientras trabajo, o ejecutar programas en máquinas remotas), y mantengo un shell en la VC 2 sólo en caso de que tenga que ejecutar algo sin involucrar a la VC 1. _____________________________________________10 Hay que asegurarse de que esto se hace desde consolas en modo texto: si se está ejecutando X Window u otra aplicación gráfica, probablemente no funcionará, sin embargo corre el rumor de que pronto se podrá camb* *iar entre las consolas virtuales en X Window de Linux. _________________________ 11N. del T.: De hecho al momento de la traducción, la combinación es |_Ctrl-Alt-tecla-de-función|_. _______________________________________________________________________________________________________________6.5. C* *onsolas virtuales: como@ _______________________________________________________________________________________________________________ Figura_6.1_Resumen_de_comandos_y_teclas_usados_para_el_control_de_trabajos.____________________________________ fg %no_trabajo Este es un comando del shell que devuelve un trabajo al primer plano. Para saber cuál es éste por defecto, se teclea "jobs" y se busca el que tiene el +. Parámetros: número de trabajo opcional. El trabajo por defecto se identifica con el +. & Cuando se añade un & al final de la línea de comandos, indica al comando que se ejecute en segundo plano automáticamente. Este trabajo está entonces sujeto a todos los métodos usuales para el control de trabajos aquí detallados. bg %no_trabajo Este es un comando del shell que manda a un trabajo suspendido ejecutarse en segundo plano. Para saber cual es éste por defecto, se teclea "jobs" y se busca el que tiene el +. Parámetros: número de trabajo opcional. El trabajo por defecto se identifica con el +. kill %no_trabajo PID Este es un comando del shell que obliga a un trabajo en segundo plano, ya sea suspendido o en ejecución, a terminar. Se debe siempre especificar el número de trabajo o PID, y si se están usando números de trabajo, no hay que olvidar poner el %. Parámetros: El número de trabajo (a continuación del %) o el PID (no es necesario el %). Se puede especificar más de un proceso o trabajo en una línea. jobs Este comando del shell lista información sobre los trabajos que están en ese momento en ejecución o suspendidos. A veces también dice cuáles son los que acaban de salir o han terminado. ________ |_Ctrl-c_| Este es el carácter genérico de interrupción. Normalmente, si se pulsa mientras un programa se está ejecutando en primer plano, matará al programa (puede que haya que hacerlo varias veces). Sin embargo, no todos los programas responderán a este método de terminación. ________ |_Ctrl-z_| Esta combinación de teclas normalmente suspende un programa, puede que algunos programas lo ignoren. Una vez suspendido, el trabajo se puede reiniciar en el segundo plano o se puede matar. _______________________________________________________________________________________________________________ _______________________________________________________________________________________________________________60 * * @ Capítulo 7 Pequeños programas potentes better !pout !cry better watchout lpr why santa claus town cat /etc/passwd >list ncheck list ncheck list cat list _ grep naughty >nogiftlist cat list _ grep nice >giftlist santa claus town who _ grep sleeping who _ grep awake who _ egrep 'bad_good' for (goodness sake) - be good " 7.1 El poder de Unix El poder de Unix1 se esconde en pequeños comandos que no parecen ser muy útiles cuando se utilizan por separado, pero combinados con otros (directa o indirectamente) proporcionan un entorno mucho más potente y flexible que la mayoría de los otros sistemas operativos. Los comandos de los que hablaremos en este capítulo son entre otros: sort, grep, more, cat, wc, spell, diff, head, y tail. Veremos lo que cada una de las utilidades hace por separado y luego daremos algunos ejemplos de como utilizarlos conjuntamente2. _____________________________________________1 N. del T.: El cookie de apertura de este capítulo es la traducción a comandos Unix de una canción de na* *vidad: "Santa Claus is coming to town" (escrita por H. Gillespie, J. F. Coots) 2Nótese que los resúmenes de los comandos en este capítulo no son extensos. Para conocer cada una de los* * opciones, 61 _______________________________________________________________________________________________________________62 * * @ 7.2 Trabajando con ficheros Junto a comandos como cd, mv, y rm que ya se vieron en el Capítulo 4, hay otros comandos que trabajan con ficheros pero no con los datos contenidos en ellos. Estos son touch, chmod, du, y df. Ninguno de ellos se preocupa por lo que contiene el fichero_simplemente modifican algunas de las informaciones que Unix guarda acerca del fichero. Estos comandos manipulan: o Los registros de tiempo. Todo fichero tiene tres fechas asociadas a él.3 Las tres fechas son las siguientes: creación del fichero, última modificación (cuando se produjo el último cambio en el fichero), y último acceso (cuando se produjo la última lectura del fichero). o El dueño. Cada fichero en Unix pertenece a un único propietario. o El grupo. Cada fichero tiene también asociados un grupo de usuarios. El grupo más usual para los ficheros de usuario se denomina users, que es al cual, por lo general, pertenecen todos los usuarios con cuenta en el sistema. o Los permisos. Cada fichero tiene ciertos permisos (también llamados "privilegios") asociados a él, que indican a Unix quién puede acceder a ese fichero, cambiarlo o en el caso de ser un programa, ejecutarlo. Cada uno de estos permisos puede ser establecido por separado para el dueño, el grupo, y el resto de usuarios. _______________________________________________________________________________________________________________ touch fichero1 fichero2 . . . ficheroN _______________________________________________________________________________________________________________ touch actualiza los registros de fecha y hora con la fecha y hora actual de los ficheros indicados en la linea de comandos. Si el fichero no existe, touch lo creará. También es posible especificar la fecha y hora a registrar en la información de los ficheros_consulte la página del manual (comando man) para más información sobre touch. _______________________________________________________________________________________________________________ chmod [-Rfv] modo fichero1 fichero2 . . . ficheroN _______________________________________________________________________________________________________________ El comando que se utiliza para modificar los permisos de un fichero es el chmod4. Antes de meternos en como utilizar este comando, veamos primero que permisos hay en Unix. Cada fichero tiene asociados un grupo de permisos. Estos permisos le indican al sistema operativo quien puede leer, escribir o ejecutar como programa el fichero. (A continuación, se explica como puede un usuario hacer estas cosas. Un programa ejecutado por un usuario puede hacer las mismas cosas que las que _____________________________________________ vea la página del manual correspondiente con el comando man. 3Los antiguos sistemas de ficheros de Linux sólo almacenaban una fecha, ya que derivaban de Minix. Si se utiliza alguno de estos sistemas de ficheros, parte de la información no estará disponible_y las operaciones que se rea* *licen sobre ellas serán inútiles. 4N. del T.: Abreviatura de change mode, cambiar modo. _______________________________________________________________________________________________________________7.2. T* *rabajando con ficheros @ le estén permitidas al propio usuario; esto puede suponer un problema de seguridad, si se desconoce lo que hace cada programa en particular.) Unix reconoce tres tipos diferentes de individuos: primero, el propietario del fichero (y la persona que puede utilizar el comando chmod sobre ese fichero). Segundo, el "grupo". El grupo de la mayoría de los ficheros normales de un usuario del sistema será "users". (Para ver el grupo de un fichero en particular, utilizar "ls -l fichero" .) Por último, está el "resto" que no son ni propietarios ni pertenecen al grupo, denominados "otros"5 De esta forma, por ejemplo, un fichero puede tener permisos de lectura y escritura para el propietario, permiso de lectura para el grupo y ningún tipo de permisos para otros. O por alguna razón, un fichero puede tener permisos de lectura/escritura para el grupo y otros, pero * *Qué hay en un ficher@ de tiempo. uptime muestra el promedio de carga del último minuto y de los cinco y diez últimos minutos. Si este promedio de carga se aproxima a cero indica que el sistema ha estado relativamente desocupado; por el contrario si el promedio es cercano al uno indica que el sistema ha estado casi completamente utilizado pero en ningún momento sobrecargado. Los promedios de carga altos son el resultado de la ejecución simultánea de varios programas. Extraordinariamente, uptime es uno de los pocos comandos de Unix que Qué hay en un fichero? Principalmente hay dos comandos en Unix para listar ficheros, cat y more. Sobre ambos ya se habló en el Capítulo 6. _______________________________________________________________________________________________________________ cat [-nA] [fichero1 fichero2 . . . ficheroN] _______________________________________________________________________________________________________________ cat no es un comando de uso amigable_no espera a que el usuario acabe de leer el fichero, y se utiliza generalmente en contextos de tuberías. Aunque pueden utilizarse algunas opciones muy útiles del comando, por ejemplo, "n" numera todas las líneas del fichero, y "A" mostrará los carácteres de control como carácteres normales en lugar de hacer (posiblemente) cosas extrañas en la pantalla. (Recuerde que para ver las opciones más curiosas y quizá "menos útiles" utilice el comando man: _____________________________________________11 N. del T.: literalmente es como preguntar al sistema >quién soy yo? _______________________________________________________________________________________________________________66 * * @ "man cat" .) Si no se especifican ficheros en la línea de comandos, cat aceptará la entrada desde stdin12. _______________________________________________________________________________________________________________ more [-l] [+número_línea] [fichero1 fichero2 . . . ficheroN] _______________________________________________________________________________________________________________ more es más útil, y además es el comando recomendado para ver ficheros de texto ASCII. La _________ única opción interesante es "l" , que indica al comando que no se desea interpretar el carácter |_Ctrl-L_| como carácter de "nueva página". El comando comenzará en la línea número_línea especificada. Al ser more un comando interactivo, hemos resumido a continuación las órdenes más comunes: _____________________ | Barra espaciadora |Pasar a la siguiente pantalla de texto. |____________________ | ____ |_d_|Pasar 11 líneas de pantalla, o aproximadamente la mitad de una pantalla normal: 25 líneas. ____ | / |Busca una expresión regular. La construcción de una expresión regular puede ser muy compli- |___| cada_por_lo que es recomendable teclear simplemente el texto a buscar. Por ejemplo, /sapo |_Intro_|buscará la primera_ocurrencia_de "sapo" en el fichero a partir de la posición actual. La misma tecla seguida por un |_Intro_|buscará la siguiente ocurrencia de la última expresión buscada. ____ |_n_|Buscará la próxima aparición de la expresión regular especificada. _______ |_:|_|_nP|asar al siguiente fichero, en caso de que se especifique más de un fichero en la línea de comandos. _______ |_:|_|_pP|asar al fichero anterior. ____ |_q_|Terminar more. _______________________________________________________________________________________________________________ head [-líneas] [fichero1 fichero2 . . . ficheroN] _______________________________________________________________________________________________________________ head mostrará las primeras diez líneas de los ficheros especificados, o las primeras diez líneas de la stdin si no se especifica ningún fichero en la línea de comandos. Cualquier opción numérica se tomará como el número de líneas a mostrar, por ejemplo "head -15 rana" mostrará las primeras quince líneas del fichero rana. _______________________________________________________________________________________________________________ tail [-líneas] [fichero1 fichero2 . . . ficheroN] _______________________________________________________________________________________________________________ Como head, tail mostrará solo una parte del fichero, en este caso el final del fichero, las últimas diez líneas del fichero, o que provengan de la stdin. tail también acepta la opción de especificar el_número_de_líneas,_como_en_el_caso_anterior. 12N. del T.: standard input, entrada estándar, generalmente entrada de datos por teclado. _______________________________________________________________________________________________________________7.5. C* *omandos de edición @ _______________________________________________________________________________________________________________ file [fichero1 fichero2 . . . ficheroN] _______________________________________________________________________________________________________________ El comando file intenta identificar que tipo de formato tiene un fichero en particular. Debido a que no todos los ficheros tienen extensión o otras formas de identificarlos fácilmente, este comando realiza algunas comprobaciones rudimentarias para intentar comprender exactamente que contiene el fichero. Hay que tener cuidado ya que es bastante posible que file realice una identificación incorrecta. 7.5 Comandos de edición Esta sección trata de los comandos que alteran un fichero, realizando sobre el fichero operaciones concretas o mostrando estadísticas del mismo. _______________________________________________________________________________________________________________ grep [-nvwx] [-número] expresión [fichero1 fichero2 . . . ficheroN ] _______________________________________________________________________________________________________________ Uno de los comandos más útiles de Unix es el grep13, utilizado para buscar expresiones en un fichero de texto. La forma más sencilla de usarlo es: /home/larry$ cat animales Los animales son unas criaturas muy interesantes. Uno de mis animales favoritos es el tigre, una temible bestia con grandes colmillos. Tambien me gusta el leon--- realmente increible! /home/larry$ grep igre animales el tigre, una temible bestia con grandes colmillos. /home/larry$ Una de los problemas de esta forma de usarlo, es que simplemente muestra las líneas que contienen la palabra a buscar, no aporta información acerca de donde buscar en el fichero, es decir el número de línea. Pero dependiendo de lo que se pretenda puede ser hasta más que suficiente, por ejemplo si se buscan los errores de la salida de un programa, se puede probar "a.out _ grep error" , donde "a.out" es el nombre del programa. Cuando es necesario conocer donde están las palabras a buscar, es decir el número de línea, hay que utilizar la opción "n" . Si lo que se desea es ver todas las líneas donde no se encuentra la expresión especificada, entonces utilice la opción "v" . Otra posibilidad que ofrece el grep es la búsqueda de partes de una palabra, como en el ejemplo anterior que "igre" se equiparó con "tigre" . Para buscar sólo palabras completas hay que pasarle al grep la opción "w" , y para líneas completas la opción es "x" . ____Si_no_se_especifica_ningún_fichero_(por_ejemplo: "grep igre" ), grep examinará la stdin. 13N. del T.: Abreviatura de generalized regular expression parser, analizador general de expresiones regulares. _______________________________________________________________________________________________________________68 * * @ _______________________________________________________________________________________________________________ wc [-clw] [fichero1 fichero2 . . . ficheroN ] _______________________________________________________________________________________________________________ El comando wc14 simplemente cuenta el número de palabras, líneas y carácteres en los ficheros pasados como parámetros. Si no se especifica ningún fichero, operará sobre la stdin. Los tres parámetros, "clw" , indican el elemento a contar: carácteres, líneas y "w" para palabras. Por ejemplo, "wc -cw" contará el número de carácteres y palabras, pero no el número de líneas. Si no se indica ningún parámetro wc cuenta todo: palabras, líneas y carácteres. Se puede utilizar wc para saber el número de ficheros de un directorio: "ls _ wc -w" . Si se desea saber el número de ficheros que acaban en .c, entonces ejecute "ls *.c _ wc -w" . _______________________________________________________________________________________________________________ spell [fichero1 fichero2 . . . ficheroN] _______________________________________________________________________________________________________________ spell es el corrector ortográfico más sencillo de Unix generalmente para inglés americano15. spell es un filtro, igual que la mayoría de los comandos que hemos comentado antes, que toma el fichero de texto ASCII y devuelve todas las palabras que considera erróneas. spell opera sobre los ficheros especificados, y si no se incluye ninguno, entonces utiliza la stdin. También es posible que esté disponible en su máquina ispell, que es un corrector ortográfico un poco más sofisticado. ispell ofrece diversos vocabularios y un menú más manejable en caso de ejecutarlo con un fichero en la línea de comandos. También puede ejecutarse como un filtro si no se especifica ningún fichero. La forma de trabajar con ispell es bastante obvia, pero si necesita más ayuda consulte la página del manual correspondiente: "man ispell" . _______________________________________________________________________________________________________________ cmp fichero1 [fichero2] _______________________________________________________________________________________________________________ cmp compara dos ficheros. El primero debe ser obligatoriamente pasado como parámetro, mien- tras que el segundo puede ser pasado como un segundo parámetro o leído desde la entrada estándar. cmp es muy sencillo, y simplemente dice donde se diferencian los dos ficheros. _______________________________________________________________________________________________________________ diff fichero1 fichero2 _______________________________________________________________________________________________________________ Uno de los comandos estándar más complejos de Unix es el diff. La versión GNU de diff tiene hasta Los animales son una criaturas muy nteresantes. Uno de mis animales favoritos es > 3c4 < Tambien me gusta el leon--- realmente increible! ---- > Tambien me gusta el leon--- realmente increible! /home/larry$ Como puede observarse, diff no devuelve nada cuando los dos ficheros son iguales. Pero cuando hemos comparado dos ficheros diferentes, se muestra una cabecera de sección, "1c1,2" indicando que ha comparando la línea 1 del fichero de la izquierda, rana, con las líneas 1-2 de perro y las diferencias que ha encontrado. Luego ha comparado la línea 3 de rana con la línea 4 de perro. Aunque pueda parecer extraño que compare diferentes números de línea, es bastante eficiente ya que es posible que pueda haber algún retorno de línea de más en alguno de los ficheros. _______________________________________________________________________________________________________________ gzip [-v#] [fichero1 fichero2 . . . ficheroN] gunzip [-v] [fichero1 fichero2 . . . ficheroN] zcat [fichero1 fichero2 . . . ficheroN] _______________________________________________________________________________________________________________ Estos tres programas se utilizan para comprimir y descomprimir datos. gzip, o GNU Zip, es un programa que lee de los ficheros originales y devuelve ficheros más pequeños, borra los ficheros especificados en la línea de comandos y los reemplaza con ficheros que tienen el mismo nombre pero con .gz añadido a su nombre. _______________________________________________________________________________________________________________ tr cadena1 cadena2 _______________________________________________________________________________________________________________ _______________________________________________________________________________________________________________70 * * @ El comando de "traducción de caracteres" opera sobre la entrada estándar_no acepta un nombre de fichero como parámetro. Reemplaza todas las ocurrencias de cadena1 en la entrada con la cadena2. En comparación con llamadas tan sencillas como "tr rana sapo" , tr puede aceptar comandos más complejos. Por ejemplo, hay una forma rápida de convertir los carácteres en minúscula por otros en mayúscula : /home/larry$ tr -:lower:] [:upper:] Esta es una frase RARA. ESTA ES UNA FRASE RARA. tr es relativamente complejo y se usa normalmente en pequeños programas shell, como filtro. Capítulo 8 Editando archivos con Emacs FUNNY SOMETHING OR OTHER 8.1 >Qué es Emacs? Para obtener algo en una computadora, necesita una forma de introducir texto en los archivos, y una manera de cambiar el texto que ya está en los archivos. Un editor es un programa para este tipo de tareas. emacs es uno de los editores más populares, en parte porque es muy fácil para un principiante hacer trabajos con él. (El editor de Unix clásico, el vi, se trata en el Apendice A.) Para aprender emacs, tiene que encontrar un archivo de texto (letras, números, etc.) cópielo a su directorio de usuario 1 (no queremos modificar el archivo original, si éste contiene información importante), y luego llame a Emacs con el archivo: /home/larry$ emacs LEAME (Por supuesto, si decide copiar /etc/rc, /etc/inittab, o cualquier otro archivo, sustituya ese nombre de archivo por LEAME. Por ejemplo, si "cp /etc/rc ~/rc" , entonces "emacs rc" .) "Llamar" a Emacs puede tener efectos diferentes dependiendo en dónde lo haga. Desde una consola que muestra sólo caracteres de texto Emacs se apoderará de toda la consola. Si lo llama desde X, Emacs abrirá su propia ventana. Asumiré que lo está haciendo desde una consola de texto, pero todo sucede de la misma manera en la versión de X, lógicamente _simplemente sustituya la palabra "ventana" en los lugares en donde lea "pantalla". Pero qué es un buffer?" Cuando Emacs trabaja sobre un archivo, no trabaja realmente sobre el archivo en sí. En vez de eso, copia los contenidos del archivo en un área de trabajo especial de Emacs llamada buffer, donde puede modificar el contenido. Cuando ha acabado de trabajar, debe decirle a Emacs que guarde los buffers _ en otras palabras, que escriba el contenido de los buffers en el archivo correspondiente. Hasta que haga esto, el archivo permanece sin cambiar, y el contenido de los buffers existe únicamente dentro de Emacs. Con esto en mente, prepárese a insertar su primer carácter en el buffer. Hasta ahora, todo lo que hemos hecho ha sido "no destructivo", este es un gran momento. Puede escoger cualquier carácter que quiera, pero si quiere hacer esto con estilo, yo sugiero usar una bonita y sólida, "X" mayúscula. Mientras lo teclea, eche un vistazo al principio de la línea de modo al pie de la pantalla. Cuando cambia los buffer de modo que sus contenidos no sean iguales que los del archivo sobre el disco, Emacs muestra dos asteriscos a principios de la línea de modo, para hacerle saber que el buffer ha sido modificado: --**- Emacs: algun_archivo.txt (Fundamental)--Top------------------------ Estos dos asteriscos se muestran tan pronto como modifica el buffer, y permanecen visibles hasta que guarde el buffer. Puede guardar_los_buffer_muchas veces_durante_una sesión de edición _el comando para hacerlo es simplemente |_C-x_C-s_ |(presione |_Control_ |y pulse "x" y "s" mientras la mantiene apretada, Y qué hay del puntero? Bien, resulta que ha colocado un puntero cada vez que ha movido el cursor, porque "puntero" simplemente se refiere a su ubicación actual en el buffer. En términos formales, el puntero es el punto donde se insertará el texto si escribe algo. Al colocar la marca, y luego moverse al final del bloque, ha definido un bloque de texto. Este bloque es conocido como la región. La región siempre significa el área entre la marca y el puntero. El sólo hecho de definir la región no la deja disponible para pegar. Tiene que decirle a Emacs ______________________________________________ 4Ocasionalmente, un C-g no es suficiente para persuadir a emacs que realmente quiere interrumpir lo que hace. Simplemente insista, y |____n|ormalmente Emacs volverá a un modo más cuerdo. 5Sobre algunos terminales, ________|_C-SPCno|funciona. Para estas máquinas, debe usar ______|_C-@.| _______________________________________________________________________________________________________________8.7. B* *uscar y reemplazar @ que lo copie para poder ser capaz de pegarlo. Para copiar_la_región,_asegúrese de que la marca y el puntero están correctamente establecidos, y teclee |_M-w__.|Ahora_ha_sido grabada por Emacs. Para pegarlo en alguna otra parte, simplemente vaya allí y teclee ||C-y_||. Esto es conocido como tirar el texto en el buffer. ______ _______ Si quiere mover el texto de la región a alguna otra parte, teclee |_C-w_ |en vez de |_M-w__.| Esto matará la región _todo_el_texto dentro de ella desaparecerá._De hecho, se ha guardado del mismo modo que si hubiera usado |_M-w__.| Puede tirar de nuevo con ||C-y_||, como siempre. El lugar donde emacs guarda todo este texto es conocido como el círculo de muerte. Algunos editores lo llaman el "porta papeles" o el "buffer de pegado". ______ Existe otra manera para cortar y pegar: cuando usa |_C-k_ |para matar hasta el final de una línea, el texto matado se guarda en el círculo de muerte. Si mata más de una línea seguida, se guardarán todas juntas en el círculo de muerte, para que la próxima tirada pegue_todas_las líneas al mismo tiempo. Por ello, casi siempre es más_rápido_usar repetidas veces |_C-k_ |para matar algún texto, que establecer la marca y el puntero y usar |_C-w_ |. Sin embargo, de una u otra manera funcionará. Es realmente una cuestión de preferencia personal cómo lo hace. 8.7 Buscar y reemplazar Hay varias maneras para buscar texto en Emacs. Muchas son más bien complejas, y no merece la pena tratarlas aquí. La más fácil y la más entretenida es usar isearch. "Isearch" se refiere a "incremental search" (búsqueda incremental). Supongamos que quiere buscar la cadena "tábano" en el siguiente buffer: Yo estaba temeroso que nos quedáramos sin gasolina, cuando mi tácito pasajero exclamó ``Auch un aguijón! Hay un tábano aquí dentro! ''. Debería moverse al comienzo del buffer, o por lo menos a_algún_punto que sabe que está antes de la primera aparición de la palabra, "tábano", y teclear |_C-s_|. Eso le pondrá en el modo de búsqueda isearch. Ahora comience a escribir la palabra que está buscando, "tábano". Pero tan pronto como escribe la "t", ve que Emacs ha saltado a la primera aparición de "t" en el buffer. Si la cita de arriba es todo el contenido del buffer, entonces la primera "t" es de la palabra "temeroso". Ahora escriba la "á' de "tábano", y Emacs saltará sobre "tácito", que contiene la primer ocurrencia de "tá". Y finalmente, "b" consigue "tábano", sin haber tenido que escribir la palabra entera. Lo que hace en una isearch es definir una cadena para buscarla. Cada vez que agrega un carácter al final de la cadena, el número de posibles cadenas se reduce, hasta que haya escrito lo suficiente para definir la cadena_singularmente._ Una vez que ha encontrado la palabra, puede salir de la búsqueda con |_Intro_|o cualquiera de los comandos normales de_movimiento._Si piensa que la cadena que buscas esta atrás en el buffer, entonces debería usar |_C-r_|, que hace isearch hacia atrás. ______ Si encuentra una palabra, pero no es la que buscaba, entonces presione |_C-s_|nuevamente mientras todavía esté en la búsqueda. Esto le moverá hasta la próxima palabra coincidente, cada_vez_que_ lo haga. Si no existe una próxima palabra, dirá que la búsqueda fracasó, pero si presiona |_C-s_| _______________________________________________________________________________________________________________78 * * @ nuevamente en este punto,_la búsqueda volverá a comenzar desde el principio del buffer. Se puede decir lo opuesto de |_C-r_|_comienza al final del buffer. Intente introducir un buffer de texto en inglés_y_haga_un isearch para la cadena "the". Primero teclee todos los "the" que quiera y luego use |_C-s_|para ir a todas las apariciones. Note que también aparecerán palabras como " them", dado que también contiene la subcadena "the". Para buscar un único "the", deberá agregar un espacio al final de la cadena de búsqueda. Puede_agregar_ nuevos caracteres a la cadena en cualquier punto de la búsqueda, después tiene que presionar_|_C-s_|_ repetidamente_para encontrar las próximas palabras coincidentes. Puede usar también la |_Retroceso__|_ o ||Supr_ ||para quitar caracteres de la cadena en cualquier punto de la búsqueda, y presionando |_Intro_| sale de la búsqueda, dejándole en la última coincidencia. Emacs también permite reemplazar todas las apariciones de una cadena con alguna nueva ca- dena _ esto es__conocido_ como query-replace (preguntar-reemplazar). Para invocarlo, teclee query-replace y |_Intro_|. Como se hace terminación automática_sobre el nombre del comando, una vez que has escrito "query-re', puede simplemente presionar |_Tab_ |para terminarlo. Digamos que desea reemplazar todas las ocurrencias de "tábano" por_"mosca"._En el prompt "Query replace: "(preguntar-reemplazar), escriba "tábano", y presione |_Intro_|. Entonces aparecerá el prompt nuevamente, y deberá introducir "mosca". Entonces Emacs recorrerá el buffer, parando a cada aparición de la palabra "tábano", y preguntando si quiere reemplazarla. Simplemente presione en cada instancia " y" o "n", por "Yes" o "No', hasta que termine. Si no entiende esto mientras lo lee, pruébelo. 8.8 >Qué es lo que ocurre realmente? Realmente, todas_estas_teclas ligadas que ha aprendido son los atajos a funciones de Emacs. Por ejemplo, ||C-p_ ||es una manera abreviada de decirle a Emacs que ejecute la función interna previous-line (línea_previa)._ Sin embargo, todas estas funciones internas pueden_ser llamadas por el nombre,_usando_|_M-x__|. Si_olvida_que previous-line está ligado a ||C-p_,||puede escribir simplemente |_M-x__|previous-line_|_Intro_|, y se_moverá_una línea hacia arriba. Pruebe esto ahora, para que comprenda como |_M-x__|previous-line y ||C-p_ ||son realmente la misma cosa. El diseñador de Emacs comenzó desde la base hacia arriba, primero definió un lote completo de funciones internas, y entonces les asoció o ligó ciertas teclas_a_las_más comúnmente usadas. A veces es más fácil llamar a una función explícitamente_con_|_M-x__|que recordar a qué tecla está liga* *da. La función query-replace, por ejemplo, está ligada a ||M-%__ ||en algunas versiones de Emacs. Pero >quién puede recordar tan rara combinación?_A_menos que use query-replace muy frecuentemente, es más fácil simplemente llamarla con |_M-x__|. La mayoría de las teclas que pulsa son letras, cuya función es ser insertadas en el texto del buffer. Cada una de esas teclas está ligada a la función self-insert-command,_que_no hace nada más que insertar la letra en el buffer. Las combinaciones que usan la tecla |_Control_ |con una letra generalmente_están ligadas a funciones que hacen otras cosas, como mover el cursor. Por ejemplo, |_C-v_|está ligada a una función llamada scroll-up (avanzar página), que mueve el buffer una _______________________________________________________________________________________________________________8.9. P* *idiendo ayuda a Emacs @ pantalla hacia arriba (lo que quiere decir que su posición en el buffer se mueve hacia abajo, por supuesto). Si alguna vez quisiera realmente insertar un carácter de Control en el buffer, entonces, >cómo lo haría? Después de todo, los caracteres de Control son caracteres ASCII, aunque rara vez usados, y puede querer tenerlos en un archivo. Hay una manera para_impedir_que los caracteres de Control sean interpretados como comandos por Emacs. La tecla ||C-q_6||está ligada a una función especial llamada quoted-insert (insertar lo citado). Todo lo que quoted-insert hace es leer la próxima tecla e insertarla literalmente en el buffer, sin tratar de interpretarla como un comando. Así es cómo puede poner los caracteres de_Control_en sus archivos usando Emacs. -mode que pone el buffer_actual_en ese modo. Entonces, para averiguar más sobre este modo mayor, tecleé |_C-h_m__|, que consigue ayuda sobre el modo mayor actual del buffer en que está. Hay un modo_ligeramente_más útil llamado_text-mode_ (modo texto, que tiene los_comandos_ especiales |_M-S__|, para centrar párrafo, y |_M-s_,|que_invoca_centrar línea._|_M-S__|, a propósito, significa exactamente lo que piensa: mantenga pulsadas la |_Meta__|y la tecla |_Shift_|, y presiona "S". ____Pero_no me tome la palabra en esto _cree un nuevo buffer, póngalo en modo texto, y teclee |_C-h_m__|. Puede que no entienda todo lo que Emacs le diga cuando lo haga, pero debería ser capaz de conseguir sacar alguna información útil de ello. Esto es una introducción_a_algunos de los modos más comúnmente usados. Si los usa, asegúrese de que teclea en cada uno |_C-h_m__|alguna vez, para averiguar más sobre cada modo. 8.11 Modos de programación 8.11.1 Modo C Si usa Emacs para programar en el lenguaje C, puede conseguir que él le haga toda la indentación automáticamente. Los archivos cuyos nombres terminan en .c o .h se abrirán automáticamente en el modo c. Esto significa que ciertos comandos_especiales_de edición, útiles para escribir programas en C, están disponibles. En el modo C, |_Tab__|está ligado a c-indent-command (indentar comandos c). Esto significa que_presionando_la tecla |_Tab_ |no inserta realmente un carácter de Tabulación. En cambio, si presiona |_Tab_ |en cualquier parte de una línea, Emacs automáticamente indenta esta línea correctamente para su ubicación en el programa. Esto implica que Emacs sabe algo sobre la sintaxis de C, (aunque nada sobre semántica _(rotar '(a b c d e)) _______ entonces puede recuperar ese comando anterior tecleando ||M-p__||en el prompt. Aquí no debería ser necesario volver a escribir expresiones largas en el prompt de Scheme _habitúese a usar la historia de entrada y ahorrará mucho tiempo. Emacs conoce bastantes lenguajes de programación: C, C++, Lisp, y Scheme son simplemente algunos. Generalmente, sabe cómo indentarlos de forma intuitiva. 8.11.3 Modo de correo _________ También puede editar y enviar correo en Emacs. Para entrar en un buffer de_correo,_teclee |_C-x_m__|. Necesita llenar los campos To: (A:) y Subjet: (Asunto:), y entonces use |_C-n_ |para ir, por debajo de la línea de separación, al cuerpo del mensaje (que está vacío cuando comienza por primera vez). No cambie o borre la línea de separación, o sino Emacs no será capaz de enviar su correo _use _______________________________________________________________________________________________________________8.12. * *Como ser más eficien@ esa línea para distinguir el encabezamiento del correo, que le dice dónde enviar el correo, de los contenidos del mensaje. Puede escribir lo que quiera_por_debajo_de la línea de separación. Cuando esté listo para enviar el mensaje, simplemente teclee |_C-c_C-c_,|y Emacs lo enviará y hará que el buffer de correo desaparezca. 8.12 Como ser más eficiente aún Los usuarios experimentados de Emacs son fanáticos de la eficiencia. suponía que |_M-f_ |es forward-word (una palabra___ hacia delante)? |_C-b_ |es backward-char (un carácter hacia_atrás)._ >Supone qué hace |_M-b__|? Sin embargo, esto no es todo, puede avanzar una frase cada vez con |_M-e_ |, siempre que escriba sus frases de modo que haya siempre dos espacios después del punto final_(de_otra manera Emacs no puede distinguir donde termina una frase y comienza la siguiente). |_M-a__|es backward-sentence (una frase atrás). ______ ____Si_ve que usa repetidamente_|_C-f_|para llegar al final de la línea, averg"uéncese,_y asegúrese de usar |_C-e_|en su lugar, y |_C-a_|para ir al_principio_de la línea. Si usa muchos_|_C-n_ |para bajar pantallas de texto, averg"uéncese mucho, y usa |_C-v_|siempre._Si usa repetidamente ||C-p_ ||para avanzar pantallas, no se atreva a enseñar la cara, y use |_M-v__|en su lugar. Si se está acercando al final de una línea y se da cuenta de que hay una palabra_mal_tecleada____ o de que se ha olvidado alguna en algún lugar anterior de la línea, no use la |_Retroceso__|o ||Supr_ || para volver a ese punto. Eso requeriría_volver_a_escribir_porciones enteras de texto perfecto. En vez de eso, use combinaciones de |_M-b__|,_|_C-b_,|y |_C-f_|para moverse a la ubicación precisa del error, arréglelo, y entonces use |_C-e_|para moverse al fin de la línea nuevamente. Cuando tiene que escribir un nombre de archivo, nunca teclee el nombre completo. Solamente escriba_lo_suficiente_para identificarlo singularmente, y deje que Emacs termine el trabajo presionando |_Tab_ |o ||Espacio_.||>Por qué teclear de más cuando puede derrochar ciclos de CPU en su lugar? Si escribe_algún_tipo de texto simple, y de algún modo su auto-llenando (auto-filling)lo ha fastidi- ado, use ||M-q__||, que es rellenado de párrafo en los modos de texto comunes. Esto "ajustará" el párrafo_en_el que está, como si hubiese sido llenado línea a línea, pero sin tener que liarse hacié* *ndolo a mano. ||M-q__||trabajará desde dentro del párrafo, o desde su comienzo o final. ________ A veces es útil usar |_C-x_u_,|(undo (deshacer)), que tratará de "deshacer" el (los) último(s) cambio(s) que hizo. Emacs decidirá cuanto deshacer; habitualmente decide muy inteligentemente. Llamándolo repetidamente deshará más y más, hasta que Emacs no pueda recordar qué cambios se _______________________________________________________________________________________________________________84 * * @ hicieron. 8.13 Personalizando Emacs " significa mantener pulsada_la_tecla_|_Control_ |mientras se presiona . Así mismo, ""M-" indica la tecla |_Meta__|. Todo eso está muy_bien,_>pero cómo supe que el nombre de la función era "goto-line"?. Puedo saber que quiero ligar |_C-c_l_|a alguna función que pregunta por un número de línea y mueve el cursor a esa línea, pero >cómo hice para averiguar el nombre de esa función? Aquí es donde intervienen las facilidades de ayuda de Emacs. Una vez que ha decidido qué tipo de función busca, puede usar Emacs para rastrear su nombre exacto. He aquí una manera rápida_y sucia para hacerlo: puesto que Emacs completa los nombres de función, simplemente escriba_|_C-h_f_| (que es describe-function (describir función), recuérdelo), y entonces presione |_Tab_ |sin escribir nada más. Esto pide a Emacs que complete la cadena vacía _en otras palabras, ls /usr/lib/emacs/19.19/lisp/*scheme* /usr/lib/emacs/19.19/lisp/cmuscheme.el /usr/lib/emacs/19.19/lisp/cmuscheme.elc /usr/lib/emacs/19.19/lisp/scheme.el /usr/lib/emacs/19.19/lisp/scheme.elc /usr/lib/emacs/19.19/lisp/xscheme.el /usr/lib/emacs/19.19/lisp/xscheme.elc Resulta que el interfaz ofrecido por cmuscheme me gusta mucho más que el que ofrece xscheme, pero el que Emacs usará por defecto es xscheme. >Cómo puedo hacer que Emacs actúe de acuerdo con mi preferencia?. Puse esto en mi .emacs: ;; note cómo la expresión puede quebrarse en dos líneas. Lisp ;; ignora los espacios en blanco, generalmente: (autoload 'run-scheme "cmuscheme" "Corre un Scheme inferior, de la forma que me gusta."t) La función autoload (auto carga) toma el nombre de una función (citada con "'", por razones que tienen que ver con cómo funciona Lisp) y le dice a Emacs que esta función está definida en un determinado archivo. El archivo es el segundo argumento, una cadena (sin la extensión .el o .elc) indicando el nombre del archivo a buscar en la trayectoria de carga load-path. Los argumentos restantes son opcionales, pero necesarios en este caso: el tercer argumento es una cadena de documentación para la función, de modo que si llama a describe-function (describir- _______________________________________________________________________________________________________________88 * * @ función), consigue alguna información útil. El cuarto_argumento_le dice a Emacs que esta función autocargable puede ser llamada interactivamente (esto es, usando |_M-x__|). Esto es muy importante en este caso, porque uno debería poder teclear M-x run-scheme para comenzar un proceso de scheme que se ejecuta bajo Emacs. Ahora que run-scheme ha sido definido como una función autocargable, >qué sucede cuando tecleo M-x run-scheme?. Emacs mira la función run-scheme, ve que está establecida para ser autocargable, y carga el archivo nombrado por la autocarga (en este caso, cmuscheme). El archivo compilado cmuscheme.elc existe, así que Emacs lo cargará. Ese archivo debe definir la función run-scheme, o habrá un error de autocarga. Por suerte, define run-scheme, así que todo va sin tropiezos, y consigo mi interfaz preferida de Scheme10. Una autocarga es como una promesa a Emacs, de que cuando llegue el momento, puede encontrar la función especificada en el archivo en el que le dice que mire. A cambio, consigue algún control sobre lo que se carga. También, la autocarga ayuda a reducir el tamaño de Emacs en la memoria, al no cargar ciertas características hasta que se pidan. Muchos comandos no están definidos realmente como funciones cuando Emacs se inicia. Más bien, están simplemente preparados para autocargarse desde cierto archivo. Si nunca invoca el comando, nunca se carga. Este ahorro de espacio es vital para el funcionamiento de Emacs: si cargara todos los archivos disponibles en la biblioteca Lisp, Emacs tomaría veinte minutos simplemente para arrancar, y una vez hecho, podría ocupar la mayor parte de la memoria disponible en su máquina. No se preocupe, no tiene que establecer todas estas autocargas en su .emacs; ya se tomaron en cuenta cuando Emacs se desarrolló. 8.14 Averiguando más No le he contado todo lo que se puede saber sobre Emacs. De hecho, no creo haberle contado siquiera un 1% de lo que se puede saber sobre Emacs. Aunque sabe suficiente para proseguir, todavía hay montones de comodidades y trucos que ahorran tiempo que debería averiguar. La mejor forma de hacerlo es esperar hasta que vea que necesita algo, y buscar entonces una función que lo haga. La importancia de estar cómodo con las facilidades de ayuda en línea de Emacs no puede enfati- zarse lo suficiente. Por ejemplo, suponga que quiere poder insertar los contenidos de algún archivo en un buffer que ya está trabajando sobre un archivo diferente, para que el buffer contenga a am- bos. Si intuyese que hay un comando llamado insert-file (insertar archivo), tendría razón. Para verificar su acertada suposición, teclee C-h f. En el prompt del minibuffer, introduzca el nombre de una función sobre la que quiera ayuda. Puesto que sabe que hay terminación automática en los nombres de funciones,_y_puede suponer que el comando que busca comienza con "insert", escriba insert y presiona |_Tab_.|Esto le muestra todos los nombres de función que comienzan con "insert", e "insert-file' es uno de ellos. De este modo completa el nombre de función y lee sobre como trabaja, y entonces usa M-x insert-file._Si se está preguntando si también está ligado a una tecla, escribe C-h w insert-file |_Intro_|, y averíg"uelo. Cuanto más sepa de las facilidades de ayuda de Emacs, más fácilmente podrá _____________________________________________10 A propósito, cmuscheme era la interfaz de la que hablaba antes, en la sección sobre el trabajo con Scheme, * *así que si quiere usar algo de este manual, necesita asegurarse de que ejecuta cmuscheme. _______________________________________________________________________________________________________________8.14. * *Averiguando más @ hacer preguntas a Emacs acerca de sí mismo. La capacidad de hacerlo, combinada con un espíritu de exploración y un deseo de aprender nuevas formas de hacer las cosas, puede acabar por ahorrarle mucho tecleado. Para pedir una copia del manual de usuario de Emacs (Emacs user's manual) y/o el manual de Programación en Emacs Lisp (Emacs Lisp Programming manual), debe escribir a: Free Software Foundation 675 Mass Ave Cambridge, MA 02139 USA Ambos manuales se distribuyen electrónicamente con Emacs, en una forma legible usando el lector de documentación Info (C-h i), pero puede encontrar más fácil tratar con freeware que con las versiones en línea. Además, sus precios son bastantes razonables, y el dinero va a una buena causa_Cuales son algunas de las cosas que interesaría personalizar? Esto es algo que creo que el 90% de los usuarios de Bash han puesto en su .bashrc: alias ll="ls -l" Este comando define un alias de shell llamado ll que "expande" el comando normal de shell "ls -l" cuando se invoca por el usuario. De modo que, asumiendo que Bash ha leído este comando del fichero .bashrc, podemos teclear ll para conseguir el efecto de "ls__-l"_ con solo la mitad de pulsaciones. Lo que ocurre es que cuando tecleamos "ll" y pulsamos |_Intro_|, Bash lo intercepta, lo reemplaza por "ls -l" , y ejecuta éste en su lugar. No hay ningún programa llamado ll en el sistema, pero el shell automáticamente traduce el alias a un programa válido. Hay algunos alias de ejemplo en la figura 9.1.3. Puede ponerlos en su propio .bashrc. Uno especialmente interesante es el primero. Con él, cada vez que alguien teclea "ls" , automaticamente tiene una opción "-F" añadida. (El alias no intenta expandirse a sí mismo otra vez). Este es un modo muy común de añadir opciones que se usan constantemente al llamar a un programa. Nótese los comentarios con el caracter "#" en la figura 9.1.3. Cada vez que aparece un "#" , el shell ignora el resto de la línea. Quizá haya notado unas cuantas cosas sueltas sobre los ejemplos. Primero, me he dejado las comillas en algunos de los alias_como pu. Estrictamente hablando, las comillas no son necesarias cuando sólo se tiene una palabra a la derecha del signo igual. _______________________________________________________________________________________________________________9.1. P* *ersonalización del b@ _______________________________________________________________________________________________________________ Figura_9.1_Algunos_alias_de_ejemplo_para_bash._________________________________________________________________ alias ls="ls -F" # muestra los caracteres al final del listado alias ll="ls -l" # ls especial alias la="ls -a" alias ro="rm *~; rm .*~" # este borra las copias de seguridad creadas por Emacs alias rd="rmdir" # ahorra teclas! alias md="mkdir" alias pu=pushd # pushd, popd, y dirs no estan incluidos en este alias po=popd # manual---quiza quiera echarles un vistazo alias ds=dirs # en la pagina man de Bash # estos solo son atajos de teclado alias to="telnet cs.oberlin.edu" alias ta="telnet altair.mcs.anl.gov" alias tg="telnet wombat.gnu.ai.mit.edu" alias tko="tpalk kold@cs.oberlin.edu" alias tjo="talk jimb@cs.oberlin.edu" alias mroe="more" # correcion ortografica! alias moer="more" alias email="emacs -f rmail" # mi lector de correo alias ed2="emacs -d floss:0 -fg ""grey95"" -bg ""grey50""" # asi llamo a Emacs _______________________________________________________________________________________________________________ Pero no hace daño poner comillas, así que no me dejéis crearos malos hábitos. Ciertamente habrá que usarlas si se va a crear un alias de un comando con opciones y/o argumentos: alias rf="refrobnicate -verbose -prolix -wordy -o foo.out" Además, el último alias tiene algún entrecomillado gracioso: alias ed2="emacs -d floss:0 -fg ""grey95"" -bg ""grey50""" Como es fácil suponer, he querido pasar entrecomillados dentro de las opciones, así que tengo que anteponerles una contrabarra para que bash no crea que ya ha llegado al final del alias. Finalmente, he creado dos alias de dos errores de escritura comunes, "mroe" y "moer", apuntando al comando que pretendía escribir, more. Los alias no interfieren con el paso de argumentos a un programa. Lo siguiente funciona bien: /home/larry$ mroe hurd.txt De hecho, saber como crear sus propios alias es probablemente por lo menos la mitad de las personalizaciones que hará jamás. Experimente un poco, descubra cuáles son los comandos largos que teclea frecuentemente, y cree alias para ellos. De esta manera, le resultará más confortable trabajar con el prompt del shell. 9.1.4 Variables de entorno Otra cosa que uno hace frecuentemente en .bashrc es definir variables de entorno. Y >qué son las variables de entorno? Vamos a mirarlo desde otra dirección: Supongamos que está leyendo la _______________________________________________________________________________________________________________94 * * @ documentación del programa fruggle, y se encuentra con una de estas expresiones: Fruggle normalmente busca su fichero de configuración, .frugglerc, en el directorio raíz del usuario. Sin embargo si la variable de entorno FRUGGLEPATH indica un nombre de archivo diferente, mirará ahí en su lugar. Cada programa se ejecuta en un entorno, y ese entorno es definido por el shell que llamó al programa1. Se puede decir que el entorno existe "dentro" del shell. Los programadores tienen una rutina especial para interrogar al entorno, y el programa fruggle usa esa rutina. Comprueba el valor de la variable de entorno FRUGGLEPATH. Si esa variable no está definida, sencillamente usará el archivo .frugglerc del directorio raíz. Si está definida, usará el valor de esa variable (que debe ser el nombre de un archivo que fruggle pueda usar) en lugar del archivo por defecto .frugglerc. Así es como se puede cambiar el entorno en bash: /home/larry$ export PGPPATH=/home/larry/secrets/pgp Hay que pensar en el comando export con este significado: "Por favor exporta esta variable fuera del entorno donde estaré llamando programas, de modo que su valor sea visible para ellos." Realmente hay razones para llamarlo export, como se verá después. Esta variable en particular es usada por el infame programa de encriptación mediante clave pública de Phil Zimmerman, pgp. Por defecto, pgp usa el directorio raíz como lugar para encontrar determinados archivos que necesita (que contienen claves de encriptación), y también un lugar para guardar archivos temporales que crea mientras está en marcha. Al darle este valor a la variable PGPPATH, le he dicho que use el directorio /home/larry/secrets/pgp en lugar de /home/larry. He tenido que leer el manual de pgp para encontrar el nombre exacto de la variable y lo que hace, pero es bastante estándar el uso del nombre del programa en mayúsculas, seguido del sufijo "PATH". También es útil saber como preguntar al entorno: /home/larry$ echo $PGPPATH /home/larry/.pgp /home/larry$ Nótese el "$" ; se precede la variable de entorno con un signo de dólar para extraer el valor de la variable. Si lo hubiera escrito sin el signo de dólar, echo simplemente habría mostrado su(s) argumento(s): /home/larry$ echo PGPPATH PGPPATH /home/larry$ El "$" se usa para evaluar variables de entorno, pero sólo lo hace dentro del contexto del shell_ o_sea,_cuando_el_shell_está_interpretando._ >Cuando está el shell interpretando? Bueno, cuando se 1Ahora se puede comprobar porqué los shells son tan importantes. Cómo iban a saber lo que un terminal podía soportar y lo que no? Y >como podían emplear nuevas características sin convertir los viejos terminales en inservibles? En Unix, la respuesta a estas cuestiones fue /etc/termcap . /etc/termcap es una lista de todos los terminales que un sistema conoce, y como controlan el cursor. Si un administrador de sistema consigue un terminal nuevo, todo lo que tiene que hacer es añadir una entrada para ese terminal en /etc/termcap en lugar de recompilar todo el Unix. A veces es incluso más simple. Al pasar el tiempo, el vt100 de Digital Equipment Corporation se convirtió en un pseudo-estándar, y muchos nuevos terminales fueron construidos para que pudieran emularlo, o comportarse como si fueran un vt100. Bajo Linux, el valor de TERM es a veces console, un clónico de vt-100 con algunas características añadidas. Otra variable, PATH, es tambien crucial para el funcionamiento correcto del shell. Aquí está la mía: /home/larry$ env _ grep ^PATH PATH=/home/larry/bin:/bin:/usr/bin:/usr/local/bin:/usr/bin/X11:/usr/TeX/bin /home/larry$ _______________________________________________________________________________________________________________96 * * @ El PATH es una lista, separada por el carácter dos puntos ":", de los directorios_donde el shell buscará el nombre del programa a ejecutar. Cuando yo tecleo "ls" y pulso |_Intro_|, por ejemplo, Bash primero busca en /home/larry/bin, un directorio que he hecho para guardar los programas que escribo. Pero yo no he escrito ls (de hecho, Dónde se habrá activado la variable anterior? El archivo /etc/profile sirve como una especie de .bash_profile global, común a todos los usuarios. Tener un archivo centralizado como este hace más sencillo para el administrador del sistema añadir un directorio nuevo al PATH de todo el mundo, sin que cada uno tenga que hacerlo individualmente. Si se incluye el path antiguo en el nuevo, no se perderán ninguno de los directorios que el sistema ya haya preparado. También se puede controlar como aparece el prompt. Esto se consigue mediante la variable de entorno PS1. Personalmente, quiero un prompt que me indique el path del directorio actual_así es "como lo hago en mi .bashrc: export PS1='$PWD"$ ' Como se puede ver, en realidad se usan dos variables. La que se activa es PS1, y toma el valor de PWD, que puede ser interpretada como "Print Working Directory" (imprime el directorio de trabajo) o "Path to Working Directory"(trayectoria al directorio de trabajo). Pero la evaluación de PWD tiene lugar entre apóstrofos agudos. Estos apóstrofos sirven para evaluar la expresión en su interior, la cual a su vez evalúa la variable PWD. Si sólo hubieramos hecho "export PS1=$PWD" , nuestro prompt nos habría mostrado constantemente el path del directorio de trabajo en el momento en que PS1 fué activada, en lugar de actualizarse constantemente mientras cambiamos de directorios. Bueno, es un poco confuso, y no muy importante en realidad. Sólo hay que tener en cuenta que se necesita esa clase de apóstrofos si se quiere mostrar el directorio actual en el prompt. Quizá se prefiera "export PS1='$PWD>'" , o incluso el nombre del sistema: export PS1=`hostname`'>' Diseccionemos este ejemplo un poco más. Aquí se usa un nuevo tipo de literal, el apóstrofo grave. Esta clase de literal no protege nada _de hecho, 'hostname' no aparece en ninguna parte del prompt cuando intentamos arrancarlo. Lo que sucede realmente es que se evalúa el comando dentro de los apóstrofos graves, y el resultado se guarda en lugar del nombre del comando entrecomillado. _______________________________________________________________________________________________________________98 * * @ Probemos con "echo `ls`" o "wc `ls`" . A medida que se consiga más experiencia usando el shell, esta técnica se hace más y más potente. Hay mucho más por comentar de como se configura el fichero .bashrc, y aquí no hay bastante espacio para hacerlo. Se puede aprender más leyendo la página man de bash, o preguntando a usuarios experimentados. Aquí hay un .bashrc completo para poder estudiarlo; es razonablemente estándar, aunque el path es un poco largo. # Algunas cosas al azar: ulimit -c unlimited export history_control=ignoredups export PS1='$PWD>' umask 022 # paths específicos de aplicaciones: export MANPATH=/usr/local/man:/usr/man export INFOPATH=/usr/local/info export PGPPATH=$-HOME"/.pgp # PATH principal: homepath=$-HOME":~/bin stdpath=/bin:/usr/bin:/usr/local/bin:/usr/ucb/:/etc:/usr/etc:/usr/games pubpath=/usr/public/bin:/usr/gnusoft/bin:/usr/local/contribs/bin softpath=/usr/bin/X11:/usr/local/bin/X11:/usr/TeX/bin export PATH=.:$-homepath":$-stdpath":$-pubpath":$-softpath" # Técnicamente, las llaves no eran necesarias, porque los dos puntos son # delimitadores válidos; pero las llaves son una buena costumbre, # y no hacen daño. # alias alias ls="ls -CF" alias fg1="fg %1" alias fg2="fg %2" alias tba="talk sussman@tern.mcs.anl.gov" alias tko="talk kold@cs.oberlin.edu" alias tji="talk jimb@totoro.bio.indiana.edu" alias mroe="more" alias moer="more" alias email="emacs -f vm" alias pu=pushd alias po=popd alias b="~/.b" alias ds=dirs alias ro="rm *~; rm .*~" alias rd="rmdir" alias ll="ls -l" alias la="ls -a" alias rr="rm -r" _______________________________________________________________________________________________________________9.2. L* *os ficheros de inicio de@ alias md="mkdir" alias ed2="emacs -d floss:0 -fg ""grey95"" -bg ""grey50""" function gco - gcc -o $1 $1.c -g " 9.2 Los ficheros de inicio de X Window Mucha gente prefiere trabajar dentro de un entorno gráfico, y para las máquinas bajo Unix eso suele significar usar X. Si se está acostumbrado al Macintosh o al Microsoft Windows, puede costar un poco acostumbrarse al sistema X Window, especialmente al modo en que se configura. Con Macintosh o Microsoft Windows, se personaliza el entorno desde dentro: si se quiere cambiar el fondo, por ejemplo, se pulsa con el ratón sobre el nuevo color en algún programa gráfico especial de configuración. En X, las opciones por defecto del sistema se controlan mediante ficheros de texto, que se editan directamente_en otras palabras, se escribe el nombre del color en un fichero para cambiar el color del fondo. No se puede negar que este método no es tan llano como el de algunos sistemas de ventanas comerciales. Creo que esta tendencia a permanecer basado en texto, incluso en un entorno gráfico, tiene mucho que ver con el hecho de que X fué creado por un puñado de programadores que simple- mente no estaban tratando de escribir un software que pudieran usar sus abuelos. Esta tendencia puede cambiar en futuras versiones de X (por lo menos así lo espero3), pero por ahora, hay que aprender como entenderse con unos cuantos ficheros de texto más. Por lo menos nos da un control muy flexible y preciso de nuestra configuración. Aquí están los ficheros más importantes para configurar X: .xinitrc Un script arrancado por X cuando se inicia. .twmrc Leido por el gestor de X Window, twm. .fvwmrc Leido por el gestor de X Window, fvwm. Todos estos ficheros deberían estar en el directorio $HOME, si es que existen. .xinitrc es una macro de shell muy simple que se ejecuta cuando invocamos a X. Puede hacer cualquiera de las cosas que pueden hacer otras macros de shell, pero por supuesto su uso principal es arrancar varios programas de X y establecer parámetros del sistema de ventanas. El último comando en .xinitrc es usualmente el nombre de un gestor de ventanas a ejecutar, por ejemplo /usr/bin/X11/twm. >Qué tipo de cosas nos gustaría poner en .xinitrc? Quizá algunas llamadas al programa xsetroot, para hacer que la ventana de fondo (escritorio) y el ratón tengan el aspecto que de- seamos. Llamadas a xmodmap, que informa al servidor4 de como interpretar las señales del teclado. _____________________________________________3 N. del T.: Yo también ;-) 4El "servidor" sólo se refiere al proceso principal en la máquina, con el que todos los demás programas * *de X tienen que comunicar para usar la pantalla. Estos otros programas se conocen como "clientes", y todo el paquete se llama _______________________________________________________________________________________________________________100 * * @ O cualquier otro programa que se quiera iniciar cada vez que se arranque X (por ejemplo, xclock). Aquí está una parte de mi .xinitrc; el suyo seguramente será distinto, así que hay que tomárselo sólo como ejemplo: #!/bin/sh # La primera línea le dice al sistema operativo que shell usar para # interpretar esta macro. La macro en sí misma debe estar marcada como # ejecutable; se puede hacer con "chmod +x ~/.xinitrc". # xmodmap es un programa que informa al servidor X de como interpretar las # señales del teclado. Es *definitivamente* aconsejable aprender como # funciona. Se puede probar con "man xmodmap", "xmodmap -help", # "xmodmap -grammar", y otras opciones. # No garantizo que las expresiones abajo escritas signifiquen nada en tu # sistema (ni siquiera garantizo que signifiquen algo en el mío): xmodmap -e 'clear Lock' xmodmap -e 'keycode 176 = Control_R' xmodmap -e 'add control = Control_R' xmodmap -e 'clear Mod2' xmodmap -e 'add Mod1 = Alt_L Alt_R' # xset es un programa para establecer otros parámetros del servidor X: xset m 3 2 & # parámetros del ratón xset s 600 5 & # preferencias del salvapantallas xset s noblank & # lo mismo xset fp+ /home/larry/x/fonts # para cxterm # Para aprender más, "xset -help". # Ordena al servidor X que sobreponga fish.cursor sobre fish.mask, y use # el patrón resultante como cursor del ratón: xsetroot -cursor /home/lab/larry/x/fish.cursor /home/lab/larry/x/fish.mask & # Un placentero patrón y color de fondo: xsetroot -bitmap /home/lab/larry/x/pyramid.xbm -bg tan # para hacer: xrdb aquí? Y que hay del fichero .Xdefaults? # Hay que mirar "man xsetroot", o "xsetroot -help" para más # información sobre el programa usado arriba. # Un programa cliente, el imponente reloj circular de color de Jim Blandy: /usr/local/bin/circles & # Quizá os gustaría tener un reloj en la pantalla a todas horas? /usr/bin/X11/xclock -digital & _____________________________________________ "sistema cliente-servidor". _______________________________________________________________________________________________________________9.2. L* *os ficheros de inicio de@ # Permite a programas cliente de X ejecutándose en occs.cs.oberlin.edu # mostrarse a sí mismos aquí, y lo mismo para juju.mcs.anl.gov: xhost occs.cs.oberlin.edu xhost juju.mcs.anl.gov # Se puede simplemente decirle al servidor X que permita usar aquí # a clientes que estén ejecutándose en cualquier otra máquina, # pero esto es un agujero en la seguridad -- N 1 larry Tue Aug 30 18:11 10/211 "Sapos!" N 2 larry Tue Aug 30 18:12 9/191 & El símbolo petición de órdenes del programa mail es un "et a la inglesa" ("&"_).__Acepta_un par de órdenes sencillas, y muestra una breve pantalla de ayuda si se pulsa "?" seguido de |_Intro_|. Las órdenes básicas de mail son: _______________________________________________________________________________________________________________10.2. * *Noticias más que de @ t lista-de-mensajes Mostrar los mensajes en la pantalla. d lista-de-mensajes Borrar los mensajes. s lista-de-mensajes fichero Guardar los mensajes en fichero. r lista-de-mensajes Responder a los mensajes_esto es, comenzar a escribir un nuevo mensaje di- rigido a quien fuera que envió los mensajes referidos. q Salir y guardar los mensajes que no hayan sido borrados en un fichero llamado mbox en el directorio raíz del usuario. >Qué es una lista-de-mensajes? Consiste en una lista de números separados por espacios, o incluso un rango de los mismos como "2-4" (lo que es equivalente a "2 3 4"). Así mismo se puede introducir el nombre del remitente, de este modo la orden t sam mostrará todos los mensajes provinientes de Sam. Si se omite la lista-de-mensajes, se supone que la orden se refiere al último mensaje mostrado. Leer el correo con el programa mail presenta varios inconvenientes. El primero es que si un mensaje es más largo que la pantalla, qué es eso de .plan y .project? Son ficheros que existen en el directorio raíz de un usuario y que se muestran cuando se le hace finger. Cada uno puede crear sus propios ficheros .plan y .project _la única restricción es que sólo se muestra la primera línea del fichero .project. Además, todo el mundo debe tener permisos de búsqueda (la "x" de ejecución) del directorio raíz del usuario en cuestión ("chmod a+x ~/") y debe ser posible para todo el mundo leer los ficheros .plan y .project ("chmod a+r ~/.plan ~/.project" ). 10.4 Uso remoto de sistemas _______________________________________________________________________________________________________________ telnet sistema-remoto _______________________________________________________________________________________________________________ _______________________________________________________________________________________________________________10.5. * *Intercambio de ficheros @ La forma más habitual de usar un sistema Unix remoto es con telnet. telnet es normalmente un programa muy sencillo de usar: /home/larry$ telnet lionsden Trying 128.2.36.41... Connected to lionsden Escape character is '^]'. lionsden login: Como puede verse, despues de teclear "telnet" , se nos presenta un mensaje de acceso al sistema remoto. Podemos introducir cualquier nombre de usuario (. Entonces podemos teclear "quit" y |_Intro_|y la conexión con el otro_sistema_será cerrada y el programa telnet finalizará. (Si cambiáramos de idea, simplemente pulsando |_Intro_|volveríamos al sistema remoto). Si se están usando las X, se puede crear un nuevo xterm para el otro sistema al que estamos saltando. Con la orden "xterm -title "lionsden" -e telnet lionsden &" crearemos una nueva ventana xterm que automáticamente ejecute telnet. (Si eso se hace con frecuencia, probablemente será deseable crear un alias o un programa de shell que lo haga automáticamente.) 10.5 Intercambio de ficheros _______________________________________________________________________________________________________________ ftp sistema-remoto _______________________________________________________________________________________________________________ La manera usual de intercambiar ficheros entre sistemas Unix es ftp, acrónimo que proviene de file transfer protocol (protocolo de transferencia de ficheros). Tras ejecutar la orden ftp, se nos pedirá que nos identifiquemos, de forma muy parecida a con telnet. Después de hacerlo aparece un símbolo de petición de órdenes especial: el símbolo ftp. La orden "cd" funciona de la manera habitual, pero en el sistema remoto: cambia de directorio en el otro sistema. De la misma forma, la orden "ls" lista los ficheros en el sistema remoto. Las dos órdenes más importantes son "get" y "put" . get transfiere un fichero del sistema remoto al local, y put lleva un fichero del sistema local al remoto. Ambas órdenes tienen efecto en el directorio local en el que se haya arrancado ftp y en el directorio remoto en el que se esté en ese momento (que se puede haber cambiado con la orden "cd" ). Un problema habitual con ftp es la distinción entre ficheros de texto y binarios. ftp es un protocolo muy antiguo, y antes tenía ventajas suponer que los ficheros que se transferían eran de texto. El comportamiento por omisión de algunas versiones de ftp es ése, lo que significa que los _______________________________________________________________________________________________________________116 * * @ programas que se envíen o reciban se corromperán. Por seguridad conviene usar la orden "binary" antes de empezar a transferir ficheros. Para salir de ftp se usa la orden "bye" . 10.6 Viajando por la telaraña La Telaraña Mundial (World Wide Web), o WWW, es un uso muy popular de la Internet. Consiste en un conjunto de páginas, cada una con su propia URL_Localizador Uniforme de Recursos asociado. Los URLs son simpáticas secuencias de caracteres de la forma . Las páginas están por lo general escritas en HTML (Lenguaje de Composición de Hipertexto). El HTML permite al autor de un documento enlazar ciertas palabras, frases, o imágenes, con otros documentos que se hallen en cualquier lugar de la telaraña. Cuando un usuario lee un documento, puede moverse rápidamente a otro picando en una palabra clave o en un botón y se le mostrará el otro documento en cuestión_que posiblemente esté a miles de kilómetros del primero. _______________________________________________________________________________________________________________ netscape [url] _______________________________________________________________________________________________________________ El navegador más popular de Linux es netscape; se trata de un navegador comercial que vende (y regala) Netscape Communications Corporation. netscape sólo funciona con las X. netscape trata de ser tan fácil de usar como sea posible y utiliza el conjunto de widgets Motif para lograr una apariencia muy a lo Microsoft Windows. El conocimiento básico para poder usar netscape es que las palabras azules subrayadas son enlaces, así como muchas de las imágenes. (Se puede averiguar cuales imágenes son enlaces picando en ellas.) Picando en esas palabras con el botón izquierdo del ratón, aparece una nueva página. Linux soporta muchos navegadores más, incluyendo el navegador original lynx. lynx es un navegador orientado a texto_no muestra ninguna imagen que es con lo que actualmente se relaciona al Web_pero funciona sin las X. _______________________________________________________________________________________________________________ lynx [url] _______________________________________________________________________________________________________________ Es un poco más complicado aprender a usar lynx, pero normalmente se le coge el truco después de jugar un rato con las flechas del cursor. Las flechas hacia arriba y hacia abajo nos mueven entre los enlaces de una página. La flecha hacia la derecha sigue el enlace seleccionado (resaltado)._ La flecha hacia la izquierda vuelve a la página anterior. Para salir de lynx, se debe pulsar |_q_|. lynx tiene muchas órdenes más_consúltese la página del manual. Capítulo 11 Comandos divertidos Bueno, la mayoría de la gente que tiene que ver con los comandos de UNIX expuestos en este capítulo no estarán de acuerdo con este título. "y dice que son divertidos?" Sí, Vd. ha visto un ejemplo del humor de los hackers1. Además, mírelo desde el lado positivo: no hay comandos del MS-DOS equivalentes a éstos. Si los necesita, tiene que adquirirlos por separado, y nunca sabrá como será su interfaz. Aquí hay un útil _y económico_ valor añadido, <Por qué `más o menos' ? Porque, por supuesto, Vd. tiene que recordar que todos los parámetros son procesados por el intérprete de comandos, y esos encantadores metacaracteres sufren una expansión. Así, un test como "-name foo*" no devolverá lo que Vd. desea, y Vd. debería escribir cualquiera de los dos "-name foo" o "-name "foo*"" . Este es probablemente uno de los más comunes errores cometidos por usuarios descuidados, así que escríbalo en letras GRANDES en su pantalla. Otro problema es que, como con ls, no se reconocen los puntos al principio del nombre del archivo. Para hacer frente a esto, puede usar el test "-path patrón " el cual no se preocupa acerca de los puntos y barras inclinadas cuando compara la ruta del fichero considerado con patrón. 11.1.5 Acciones Hemos dicho que las acciones son aquellas que realmente hacen algo. Bueno, "-prune" más bien no hace nada, es decir, al descender el árbol de directorios (a menos que se le agregue "-depth" ). Se la encuentra usualmente junto con "-fstype" , para elegir entre varios sistemas de ficheros a aquellos que deberían examinarse. Las otras acciones pueden ser divididas en dos amplias categorías; Acciones que imprimen algo. La más obvia de estas _y en realidad, la acción por defecto de find- es "-print" que imprime el nombre del(os) fichero(s) que concuerde(n) con las otras condiciones en la línea de comandos, y devuelve verdadero. Una variante sencilla de "-print" es "-fprint archivo " , en la cual se usa archivo en vez de la salida estándar; otra es "-ls" lista el fichero en uso en el mismo formato que "ls -dils" ; "-printfformato " se comporta más o menos como la función de C printf(), para que se pueda especificar que formato debería tener la salida, y "-fprintf archivo formato " hace lo mismo, pero escribiéndolo en archivo. Estas acciones también devuelven verdadero. _____________________________________________8 N.T.: timestamp _______________________________________________________________________________________________________________122 * * @ Acciones que ejecutan algo. Su sintaxis es un poco extraña y su uso está muy extendido, por lo que, por favor, considérelas. "-exec comando ";" ejecuta el comando, y la acción devuelve verdadero si el estado retornado por el comando es 0, lo que significa que la ejecución fue correcta. La razón para el "";" es bastante lógica: find no sabe donde termina el comando, y el truco de poner la acción ejecutable al final del comando no es aplicable. Bueno, la mejor manera para señalar el final del comando es usar el caracter que usa el intérprete de comandos para este fin, que es ";" , pero, por supuesto, un punto y coma solo en la línea de comandos sería "comido"por el intérprete de comandos y nunca llegaría a find, así que tienen que ser precedidos de escape. La segunda cosa a recordar es como especificar el nombre del fichero en uso dentro del comando, ya que probablemente Vd. hizo todo el esfuerzo al construir la expresión para hacer algo, y no sólo para ver la hora. Esto se hace por medio de la cadena de caracteres "{}" . Algunas versiones antiguas de find requieren que coloque las llaves entre espacios en blanco _no muy práctico si Vd. necesita, por ejemplo, la ruta entera y no sólo el nombre del fichero_ pero con el find de GNU podría ser cualquier lugar de la cadena de caracteres que compone el comando. (>Y no debería estar precedido de escape o entrecomillado?, seguramente se estará preguntando. Asombrosamente, yo nunca tuve que hacer esto ni bajo tcsh ni bajo bash (sh no considera - y " como carácteres especiales, así que no es ni mucho menos un problema). Mi idea es que los intérpretes de comandos "saben" que -" no es una opción que tenga sentido, por tanto no intentan expandirlas, afortunadamente para find que puede obtenerla intacta. "-ok comando ";" se comporta como "-exec" , con la diferencia que para cada fichero selec- cionado se pregunta al usuario que confirme el comando; si la respuesta empieza por y o Y, se ejecuta, de otra manera no, y la acción devuelve falso. 11.1.6 Operadores Hay una cierta cantidad de operadores; aquí hay una lista, en orden de prioridad decreciente. \( expr \) Fuerza el orden de prioridad. Los paréntesis deben, por supuesto, estar entre comillas, ya que también son muy significativos para el intérprete de comandos. ! expr -not expr Cambia el verdadero valor de la expresión, esto es, si expr es verdadera, se vuelve falsa. El signo de exclamación no tiene que ser precedido de escape, porque está seguido por un espacio en blanco. expr1 expr2 expr1 -a expr2 expr1 -and expr2 Todas corresponden con la operación lógica AND. El caso más común es el primero, en el cual está implícita. expr2 no se evalua, si expr1 es falsa. expr1 -o expr2 _______________________________________________________________________________________________________________11.1. * *find, el buscador de fic@ expr1 -or expr2 corresponden a la operación lógica OR. expr2 no es evaluada, si expr1 es verdadera. expr1 , expr2 es la declaración de lista; ambas expr1 y expr2 se evaluan (junto con todos los efectos secundarios, Y por qué el /dev/null en el comando? Es un truco para forzar al grep a escribir el fichero del nombre donde se ha encontrado un emparejamiento. El comando grep se aplica a cada fichero con una invocación diferente, y, por tanto no cree que sea necesario mostrar a la salida el nombre del fichero. Pero ahora hay dos ficheros, esto es: __piggies 9N.T.: to pipe 10N.T.: core file _______________________________________________________________________________________________________________124 * * @ Es útil para ver quién tiene esos archivos que atascan el sistema de ficheros. Note el uso de "-xdev" ; como sólo estamos interesados en un sistema de ficheros, no es necesario descender otro sistema de ficheros montado bajo /home. 11.1.8 Una última palabra Tenga en mente que find es un comando que consume mucho tiempo, ya que tiene que acceder a cada uno de los nodos-i del sistema para realizar su operación. Por lo tanto, es sabio combinar cuantas operaciones sean posibles en una única invocación de find, especialmente en las tareas de `mantenimiento interno' que usualmente se administran mediante un trabajo de la tabla de tareas planificadas. Un ejemplo informativo es el siguiente: supongamos que queremos borrar los ficheros que acaban en .BAK y cambiar la protección de todos los directorios a 771 y todos los ficheros que acaban en .sh a 755. Y quizás temgamos montado el sistema de ficheros NFS en un enlace telefónico, y no querramos examinar los ficheros ahí. (>Por qué escribir tres comandos diferentes? La manera más efectiva para realizar la tarea es ésta: $ find . "( -fstype nfs -prune ") -o " "( -type d -a -exec chmod 771 -" "; ") -o " "( -name "*.BAK" -a -exec /bin/rm -" "; ") -o " "( -name "*.sh" -a -exec chmod 755 -" "; ") Parece feo (no? count=nbl pretende copiar sólo nbl bloques de la entrada, cada uno de los tamaños dados por "ibs" . Esta opción, junto con la previa, se vuelve útil si, por ejemplo, Vd. tiene un fichero corrupto y quiere recuperar cuanto sea posible de él. Vd. debe omitir la parte ilegible y copiar lo que resta. conv=conversión,[conversión. . . ] transforma el fichero de la manera que se especifica en sus argumen- tos. Transformaciones posibles son "ascii" , que convierte de EBCDIC a ASCII; "ebcdic" y "ibm" , las cuales realizan una conversión inversa () _sobreescribirán sus ficheros cuando no esté prestando atención. Incluso el más inofensivo de los comandos puede convertirse en siniestro: /home/larry/report$ cp report-1992 report-1993 backups puede convertirse fácilmente en desastre: /home/larry/report$ cp report-1992 report-1993 o El autor también recomienda, a partir de su propia experiencia personal, no hacer limpieza de ficheros a altas horas de la madrugada. >Que su estructura de directorios parece un poco desordenada a la 1:32am? Déjelo estar _un poco de desorden nunca ha dañado un ordenador. o Sígale la pista a su directorio actual. A veces, el prompt que está usando no muestra en que directorio está usted trabajando, y el peligro acecha. pwd /etc mousehouse> ls /tmp passwd mousehouse> rm passwd La anterior serie de comandos podría hacer muy infeliz al usuario, al ver como eliminaron el fichero de contraseñas de su sistema. qué es un error? Un ejemplo de error es si le pide al ordenador que calcule "5+3" y contesta "7". Aunque este es un ejemplo trivial de que puede ir mal, la mayoría de los errores en programas de computadoras se relacionan con la aritmética en alguna forma extremadamente extraña. _____________________________________________1 Un foro de discusión internacional en Usenet, que trata sobre la administración de computadoras Unix. 2Bug: (polilla, fam. bicho). Se denomina así a los errores que aparecen en un programa. Cuenta la leyenda que cuando los ordenadores eran unos monstruos llenos de válvulas, que ocupaban habitaciones enteras, un técnico que trataba de resolver un error en el Mark II de Harvard detectó que la causa era una polilla de verdad que se hab***'* *ia colado entre las válvulas y provocaba pequeños cortocircuitos al revolotear de un lado a otro. _______________________________________________________________________________________________________________12.3. * *No es fallo tuyo @ 12.3.1 Cuando hay un error Si la computadora da una respuesta errónea (Cómo ejecutó el programa en cuestión?, o, si era un error del núcleo, >qué estaba haciendo en ese momento?. o Toda la información complementaria. Por ejemplo, el comando w puede no mostrar el proceso actual para ciertos usuarios. No diga simplemente, "w no funciona para cierto usuario". El error podría ocurrir debido a que el nombre del usuario tiene ocho caracteres de longitud, o cuando está accediendo a través de la red. En su lugar diga, "w no muestra el proceso actual para el usuario greenfie cuando accede a través de la red". o Y recuerde, sea amable. La mayoría de la gente trabaja en el software libre por el gusto de hac- erlo, y porque tienen un gran corazón. No los amargue_la comunidad Linux ha desilusionado ya a demasiados desarrolladores, y aún es pronto en la vida del Linux. Apéndice A Introducción a vi vi (pronunciado "vi ai" en inglés, o "uve i") es en realidad el único editor que se puede encontrar en prácticamente cualquier instalación de Unix. Este editor fue escrito originalmente en la Universidad de California en Berkeley y se puede encontrar versiones en casi cualquier edición de Unix, incluído Linux. Al principio cuesta un poco acostumbrarse a él, pero tiene muchas características muy potentes. En general, recomendamos que un nuevo usuario aprenda Emacs, que generalmente es más fácil de usar. Sin embargo, la gente que usa más de una plataforma o que encuentra que no le gusta Emacs, puede estar interesada en aprender vi. ___ Es necesaria una breve reseña histórica de vi para comprender cómo la tecla |_k_|puede significar mover el cursor arriba una línea y porqué hay tres diferentes modos de uso. Si no le apetece aprender a usar el editor, los dos tutoriales le llevarán de ser un crudo principiante hasta tener el suficiente conocimiento del grupo de comandos que usted puede llegar a usar. El capítulo también incluye una guía de comandos, que sirve de útil referencia para tenerla cerca del terminal. Incluso si vi no se convierte en su editor de texto normal, el conocimiento de su uso no será desperdiciado. Es casi seguro que el sistema de Unix que use tendrá alguna variante del editor vi. Puede ser necesario usar vi mientras instala otro editor, como Emacs. Muchas herramientas de Unix, aplicaciones y juegos usan un subconjunto del grupo de comandos de vi. A.1 Una rápida historia de Vi Los editores de texto en la antig"uedad funcionaban en modo de una línea y se usaban típicamente desde terminales no inteligentes de impresión. Un editor típico que operaba en este modo es Ed. El editor es potente y eficiente, y usa una cantidad muy pequeña de recursos del sistema, y funcionaba con las pantallas de aquel entonces. vi ofrece al usuario una alternativa visual con un grupo de comandos notablemente amplio comparado con ed. vi como lo conocemos hoy comenzó como el editor de línea ex. De hecho, ex se ve como un modo especial de edición en vi, aunque ahora lo contrario es verdad. El componente visual de ex puede ser iniciado desde la línea de comando usando el comando vi, o desde dentro de ex. 133 _______________________________________________________________________________________________________________134 * * @ El editor ex/vi fue desarrollado en la universidad de California en Berkeley por William Joy. Originalmente se suministraba como una utilidad no soportada hasta su inclusión oficial en la dis- tribución del Unix AT&T System V. Se ha ido haciendo cada vez más popular, incluso con la competencia de los modernos editores de pantalla completa. Debido a la popularidad de vi existen muchas variantes clónicas y se pueden encontrar varias versiones para la mayoría de los sistemas operativos. No es el propósito de este capítulo el incluir todos los comandos disponibles bajo vi o sus variantes. Muchos clones han aumentado y modificado el comportamiento original de vi. La mayoría de los clones no soportan todos los comandos originales de vi. Si tiene un buen conocimiento de trabajo con ed entonces vi presenta una curva de aprendiza- je más suave. Aunque usted no tenga ninguna intención de usar vi como su editor regular, el conocimiento básico de vi solamente puede serle una ventaja. A.2 Rápido tutorial de Ed El propósito de esta guía es que usted empiece a usar ed. ed está diseñado para ser fácil de usar, y requiere poco entrenamiento para comenzar. La mejor manera de aprender es practicando, así que siga las instrucciones y pruebe el editor antes de descontar sus ventajas prácticas. A.2.1 Crear un fichero ed sólo puede editar un fichero a la vez. Siga el siguiente ejemplo para crear su primer fichero de texto usando ed. /home/larry$ ed a Este es mi primer fichero de texto usando Ed. Esto es divertido de verdad. . w primero.txt q /home/larry$ Ahora puede verificar el contenido del fichero usando la utilidad de concatenación de Unix. /home/larry$ cat primero.txt El ejemplo anterior ha mostrado un número de puntos_importantes. Cuando invoca ed como en el ejemplo tendrá un fichero vacío. La tecla |_a_|se usa para añadir texto al fichero. Para finalizar la sesión de entrada de texto,_se usa un punto ___|_.|en la primera columna del texto. Para salvar el texto_a un fichero, la tecla |_w_ |se usa en combinación con el nombre del fichero y finalmente la tecla |_q_|se usa para salir del editor. _______________________________________________________________________________________________________________A.2. R* *ápido tutorial de Ed@ La observación más importante es que hay dos modos de operación. Al principio el editor está en modo de comandos. Un comando se define por caracteres, para asegurarse de cuales son las intenciones del usuario, ed usa un modo de texto, y un modo de comando. A.2.2 Editar un fichero existente Para añadir una línea de texto a un fichero existente siga el siguiente ejemplo: /home/larry$ ed primero.txt a Esta es una nueva linea de texto. . w q Si comprueba el fichero con cat verá que hay una nueva línea insertada entre las dos líneas originales. >Cómo supo ed dónde poner la nueva línea de texto?. ___ Cuando ed lee el fichero, se acuerda de cual es la línea actual. El comando |_a_|añadirá el texto ___ después de la línea actual. ed también puede poner el texto antes de la línea actual con la tecla |_i|_ . El efecto será la inserción del texto antes de la línea actual. Ahora es fácil ver que ed opera en el texto línea por línea. Todos los comandos se pueden aplicar a una línea elegida. Para añadir una línea de texto al final de un fichero. /home/larry$ ed primero.txt $a La ultima linea de texto. . w q ____ El modificador de comandos ||$_||le dice a ed que añada la línea después_de la última línea. Pa* *ra añadir la línea despues de la primera línea el modificador sería |_1_|. Ahora tenemos la posibilidad de seleccionar la línea para añadir una línea de texto después del número de línea o insertar una * *línea antes del número de línea. ____ >Cómo sabemos lo que hay en la línea actual? El comando |_p_|muestra el contenido de la línea actual. Si quiere hacer que la línea actual sea la línea 2, y a la vez quiere ver el contenido de esa línea entonces haga lo siguiente. /home/larry$ ed primero.txt 2p q _______________________________________________________________________________________________________________136 * * @ A.2.3 Números de línea en detalle ____ Ha visto cómo mostrar el contenido de la línea actual, usando el comando |_p_|. También sabemos que hay modificadores del número de línea para los comandos. Para ver el texto de la segunda línea, 2p Hay algunos modificadores especiales_que se refieren a posiciones que pueden cambiar durante el tiempo que edita un fichero. El ||$_||es la última línea del texto. Para ver la última línea, $p El número de línea actual usa un simbolo de modificador especial ___|_.|. Para mostrar la línea actual usando un modificador, .p Esto puede parecer innecesario, aunque es muy útil en el contexto de los grupos de números de línea. Para mostrar el contenido del texto desde la línea 1 a la línea 2, se le debe pasar el alcance. 1,2p El primer número se refiere a la línea de comienzo y el segundo se refiere a la última línea. La línea actual será por consiguiente el segundo número del grupo de líneas. Si quiere mostrar el contenido del fichero desde el comienzo hasta la línea actual, 1,.p Para mostrar el contenido desde la línea actual hasta el final del fichero, .,$p Todo lo que queda es mostrar el contenido de todo el fichero, y esto queda como un ejercicio para usted. >Cómo puede borrar las dos primeras líneas del fichero? 1,2d ____ El comando |_d_|borra el texto línea por línea. Si usted quisiera borrar el contenido completo, lo haría con: 1,$d _______________________________________________________________________________________________________________A.3. R* *ápido tutorial de Vi@ Si usted ha hecho muchos cambios y no quiere salvar los contenidos del fichero, lo mejor es salir del editor sin escribir el fichero antes. La mayoría de los usuarios no usan ed como el principal editor. Los editores más modernos ofrecen una pantalla completa de edición y grupos de comandos más flexibles. ed ofrece una buena introducción a vi y ayuda a explicar cómo se originaron los comandos de vi. A.3 Rápido tutorial de Vi El propósito de este tutorial es que comience a usar el editor vi. Este tutorial asume que no tiene ninguna experiencia con vi, así que le mostraremos los diez comandos más basicos de vi. Estos comandos fundamentales son suficientes para realizar la mayoría de sus necesidades de edición, y puede expandir su vocabulario de vi cuanto necesite. Se recomienda que tenga un ordenador para practicar, según avanza con el tutorial. A.3.1 Ejecutar vi Para ejecutar vi, simplemente tiene que teclear las letras vi seguidas del nombre de fichero que desea crear. Verá una pantalla con una columna de tildes (~) en el lado izquierdo. vi está ahora en modo de comando. Cualquier cosa que teclee será interpretado como un comando, no como texto que usted desea escribir. Para introducir texto, tiene que teclear un comando. Los dos comandos de entrada básicos son los siguientes: i insertar texto a la izquierda del cursor. a añadir texto a la derecha del cursor. Dado que está al comienzo de un fichero vacío, no importa cual de estos usar. Escriba uno de ellos, y después teclee el siguiente texto (un poema de Augustus DeMorgan encontrado en The Unix Programming Environment por B.W. Kernighan y R. Pike): Las pulgas grandes tienen pequeñas pulgas sobre sus espaldas para que les muerdan. Y las pulgas pequeñas tienen pulgas mas pequeñas y as'i hasta el infinito. Y las pulgas grandes, a su vez, tienen pulgas mas grandes sobre las que estar; Mientras que estas de nuevo tienen otras mas grandes aun, y mas grandes aun, y asi. ______ Fíjese que tiene que pulsar la tecla |_Esc_|para finalizar la inserción y volver al modo de comando. _______________________________________________________________________________________________________________138 * * @ A.3.2 Comandos de movimiento del cursor h mueve el cursor un espacio a la izquierda. j mueve el cursor un espacio abajo. k mueve el cursor un espacio arriba. l mueve el cursor un espacio a la derecha. Estos comandos se pueden repetir manteniendo la tecla pulsada. Intente mover_el_cursor por el texto ahora. Si intenta un movimiento imposible, por ejemplo, pulsar la tecla |_k_|cuando el cursor está en la línea superior, la pantalla parpadeará momentaneamente o el terminal sonará. No se preocupe, no muerde, y su fichero no saldrá dañado. A.3.3 Borrar texto x borra el carácter que hay en el cursor. dd borra la línea donde está el cursor. ___ Mueva el cursor a la primera línea_y_póngalo de modo que esté bajo la n. Pulse la letra |_x_|, y la n desaparecerá._ Ahora pulse la letra |_i|_para cambiarse al modo de inserción y vuelva a teclear la n. Pulse |_Esc_|cuando haya terminado. A.3.4 Salvar un fichero :w salvar (escribir al disco). :q salir. ______ Asegúrese de que está en modo de comando pulsando la tecla |_Esc_|. Ahora pulse :w. Esto salvará su trabajo escribiéndolo a un fichero de disco. ____ El comando para salir de vi es |_q_|. Si quiere combinar el salvar y salir, escriba :wq. También hay una abreviación para :wq _ ZZ. Dado que gran parte del trabajo de programación consiste en ejecutar un programa, encontrar algún problema y llamar el programa en el editor para hacer algún pequeño cambio, y luego volver a salir del editor para ejecutar el programa otra vez, ZZ será un comando que usará a menudo. (En realidad, ZZ no es un sinónimo exacto de :wq _ si no ha hecho ningún cambio al fichero que está editando desde la ultima vez que lo salvo, ZZ simplemente saldrá del editor mientras que :wq salvará (redundantemente) el fichero antes de salir.) Si usted se lo ha cargado todo sin esperanzas_y simplemente quiere volver a empezarlo todo, puede teclear :q! (recuerde pulsar la tecla |_Esc_|primero). Si omite el !, vi no le permitirá salir sin salvar. A.3.5 >Qué viene a continuación? Los diez comandos que acaba de aprender deberían ser suficientes para su trabajo. Sin embargo, solamente ha rozado la superficie del editor vi. Hay comandos para copiar material de un lugar del fichero a otro, para mover material de un lugar a otro, para mover material de un fichero a otro, para ajustar el editor a sus gustos personales, etc. Con todo, hay unos 150 comandos. _______________________________________________________________________________________________________________A.4. T* *utorial avanzado de Vi @ A.4 Tutorial avanzado de Vi La ventaja y la potencia de vi está en la habilidad de usarlo con éxito con sólo saber unos pocos comandos. La mayoría de los usuarios de vi se sienten un poco incómodos al principio, sin embargo después de algún tiempo se encuentran ávidos de mayor conocimiento de los comandos disponibles. El siguiente tutorial asume que el usuario ha completado el tutorial rápido (arriba) y por lo tanto se siente a gusto con vi. Este tutorial expone algunas de las características más poderosas de ex/vi desde copiar texto hasta la definición de macros. Hay una sección sobre ex y los parámetros para ajustar el editor a su gusto. Este tutorial describe los comandos, en vez de llevarle grupo por grupo. Se recomienda que usted disponga de algún tiempo para probar los comandos en algún texto de ejemplo, que se pueda permitir destruir. Este tutorial no expone todos los comandos de vi, aunque se cubren los más comúnmente usados y aún otros adicionales. Aunque usted elija usar otro editor de texto, se espera que apreciará vi y lo que ofrece a quienes deciden usarlo. A.4.1 Movimiento La funcionalidad más básica de un editor es el mover el cursor por el texto. Aquí están los comandos de movimiento. h mueve el cursor un espacio a la izquierda. j mueve el cursor una línea hacia abajo. k mueve el cursor una línea hacia arriba. l mueve el cursor un espacio a la derecha. Algunas implementaciones también permiten el uso de las teclas de cursor para mover el cursor. w mueve al principio de la siguiente palabra. e mueve al final de la siguiente palabra. E mueve al final de la siguiente palabra antes de un espacio. b mueve al principio de la palabra anterior. 0 mueve al principio de la línea actual. ^ mueve a la primera palabra de la línea actual. $ mueve al final de la línea. mueve al principio de la siguiente línea. - mueve al principio de la línea anterior. G mueve al final del fichero. 1G mueve al principio del fichero. nG mueve a la línea n. G muestra el número de línea actual. % va al paréntesis correspondiente. H mueve a la línea superior en pantalla. M mueve a la línea de en medio de la pantalla. L mueve al final de la pantalla. n_ mueve el cursor a la columna n. _______________________________________________________________________________________________________________140 * * @ El texto se desplaza automáticamente cuando el cursor alcanza la parte superior o inferior de la pantalla. También hay comandos que permiten controlar el desplazamiento del texto. f desplaza una pantalla hacia delante. b desplaza una pantalla hacia atrás. d desplaza media pantalla hacia abajo. u desplaza media pantalla hacia arriba Los comandos anteriores controlan el movimiento del cursor. Algunos de los comandos usan un modificador de comandos en la forma de un número que precede al comando. Esta característica normalmente repite el comando ese número de veces. Para mover el cursor ocho posiciones a la izquierda. 8l mueve el cursor 8 posiciones a la izquierda. Si desea introducir un número de espacios delante de un texto, podría usar el modificador_de comandos con el comando insertar. Introduzca_el número de repeticiones (n) y después |_i|_seguido por el espacio y luego pulse la tecla |_Esc_|. ni inserta algún texto y lo repite n veces. ____ Los comandos que tratan con líneas usan el modificador para referirse al número de línea. El |_G_| es un buen ejemplo. 1G mueve el cursor a la primera línea. vi tiene un voluminoso grupo de comandos que se puede usar para mover el cursor por el texto. vi también puede posicionar el cursor en una línea desde la línea de comandos. vi +10 mi_fichero.tex Este comando abre el fichero llamado mi_fichero.tex y pone el cursor 10 líneas más abajo del comienzo del fichero. Pruebe los comandos de esta sección. Muy poca gente los recuerda todos en una sola sesión. La mayor parte de los usuarios solamente utiliza una parte de estos comandos. Ahora se puede mover, pero >cómo modificar el texto? A.4.2 Modificación del texto El propósito es cambiar el contenido del fichero y vi ofrece un amplio conjunto de comandos para ayudarnos en este proceso. Esta sección se concentra en añadir texto, cambiar el texto existente y borrar texto. Al final de esta sección usted tendrá el conocimiento para crear cualquier fichero de texto que desee. Las secciones restantes se concentran en comandos más especializados y convenientes. _______ Cuando usted teclea nuevo texto puede introducir varias líneas usando la_tecla_|_Intro_|._Si hay que corregir un error tipográfico mientras introduce texto, puede usar la tecla |_Retroceso__|para mover el cursor sobre el texto. Las varias implementaciones de vi se comportan de manera diferente. Algunas _______________________________________________________________________________________________________________A.4. T* *utorial avanzado de Vi @ simplemenente mueven el cursor hacia atrás y el texto sigue viéndose y es aceptado. Otras borran el texto cuando pulsa la tecla de borrado. Otras versiones incluso permiten usar las teclas de cursores para mover el cursor mientras se está en modo de entrada de_texto._ Este modo de funcionamiento no es el normal_de_vi.__Si_el texto es visible y usa la tecla |_Esc_|mientras está en la línea en la que pulsó |_Retroceso__|, entonces el texto que hay después del cursor se borrará. Use el editor para acostumbrarse a este comportamiento. a Añadir texto a partir de la posición actual del cursor. A Añadir al final de la línea. i Insertar texto a la izquierda del cursor. I Insertar texto a la izquierda del primer caracter que no sea espacio en la línea actual. o Abrir una nueva línea y añade texto debajo de la línea actual. O Abrir una nueva línea y añade texto encima de la línea actual. vi tiene un pequeño grupo de comandos para borrar texto que se pueden mejorar con el uso de modificadores. x Borrar el caracter que está debajo del cursor. dw Borrar desde la posición actual al final de la palabra. dd Borrar la línea actual. D Borrar desde la posición actual al final de la línea. Los modificadores se pueden usar para aumentar la potencia de los comandos. Los siguientes ejemplos son un subgrupo de las posibilidades. nx Borrar n caracteres desde el que está bajo el cursor. ndd Borrar n líneas. dnw Borrar n palabras (igual que ndw). dG Borrar desde la posición actual hasta el final del fichero. d1G Borrar desde la posición actual hasta el principio del fichero. d$ Borrar desde la posición actual al final de la línea. (Esto es igual que D). dn$ Borrar desde la línea actual al final de la enésima línea. La lista de comandos anterior muestra que la operación de borrado puede ser muy útil. Esto se hace patente cuando se aplica_en_combinación con los comandos de movimiento de cursor. Hay que hacer notar que el comando |_D_ |ignora los modificadores que se le apliquen. En ocasiones usted puede necesitar deshacer los cambios al texto. Los siguientes comandos recuperan el texto que había antes de hacer cambios. u Deshacer el último comando. U Deshacer todos los cambios ocurridos en la línea actual. :e! Editar otra vez. Recupera el estado del fichero desde la última vez que se salvó. vi no sólo le permite deshacer_cambios, también puede dar la vuelta al comando "deshacer". Por ejemplo,_si usamos el_comando_|_5dd_ |para borrar 5 líneas, se pueden recuperar usando el comando |_u_|. Si usted usa |_u_|una vez más, las 5 líneas desaparecerán de nuevo. vi ofrece comandos que permiten que se hagan cambios al texto sin tener que borrar y volver a escribir: _______________________________________________________________________________________________________________142 * * @ rc Reemplazadelecaracterrbajoeelccursorhconalasletrai"c".seMueveuelscursoraaelal modificador de repetició* *n, por ejemplo: 2rc. R Sobreescribe el texto con el nuevo texto.. cw Cambia el texto de la palabra actual. c$ Cambia el texto desde la posición actual al final de la línea. cnw Cambia las siguientes n palabras. (Igual que ncw). cn$ Hacer cambios hasta el final de la enésima línea. C Hacer cambios hasta el final de la línea actual. cc Hacer cambios en la línea actual. s Sustituye el texto que escriba por el caracter actual. ns Sustituye el texto que escriba por los siguientes n caracteres. Las series de comandos_de_cambio que permiten que se introduzca un grupo de carácteres se terminan con la tecla |_Esc_|. _____ El comando |_cw_ |empieza en la posición actual en la palabra y termina al final de la palabra. Cuando use un comando de cambio que especifica la distancia sobre la que se aplicará el cambio, vi pondrá un $ en la última posición de carácter. El nuevo texto puede sobrepasar o no llegar a la longitud original de texto. A.4.3 Copiar y mover bloques de texto El movimiento de texto supone la combinación de un número de comandos para conseguir el propósito final. Esta sección introduce los buffers1 con y sin nombre junto a los comandos que cortan y pegan el texto. La copia de texto se realiza en tres pasos principales: 1. Copia del texto a un buffer. 2. Movimiento del cursor al lugar de destino. 3. Pegar (poner) el texto en el buffer de edición. El buffer de edición no es sino el propio fichero en el que usted está trabajando. ___ Para Copiar texto al buffer sin nombre use el comando |_y_|. yy Mueve una copia de la línea actual al buffer sin nombre. Y Mueve una copia de la línea actual al buffer sin nombre. nyy Mueve las siguientes n lineas al buffer sin nombre. nY Mueve las siguientes n líneas al buffer sin nombre. yw Mueve una palabra al buffer sin nombre. ynw Mueve n palabras al buffer sin nombre. nyw Mueve n palabras al buffer sin nombre. ______y$_____Mueve_el_texto_desde_la_posición_actual al final de la línea al buffer sin nombre. 1N. del T.: "buffer"es una palabra inglesa que se refiere a un espacio reservado en memoria para guardar alguna información temporalmente. En este caso se usan buffers para almacenar una copia temporal del texto que usted desea copiar o mover. _______________________________________________________________________________________________________________A.4. T* *utorial avanzado de Vi @ El buffer sin nombre es un buffer temporal que puede ser fácilmente afectado por otros comandos comunes. Hay ocasiones en las cuales necesitamos mantener el contenido de un buffer durante un período más extenso de tiempo. En este caso se usaría un buffer con nombre. vi tiene 26 buffers con nombre. Los buffers usan las letras del alfabeto como el_nombre_de identificación. Para distinguir un comando de un buffer con nombre, vi usa el caracter |_"_|. Cuando use un buffer con nombre de letra minúscula los contenidos se sobre escriben, mientras que el uso del nombre en letra mayúscula añade el nuevo texto al contenido actual. "ayy Mueve la línea actual al buffer con nombre a. "aY Mueve la línea actual al buffer con nombre a. "byw Mueve la palabra actual al buffer con nombre b. "Byw Añade la palabra actual al contenido del buffer b. "by3w Mueve las siguientes 3 palabras al buffer b. ____ Use el comando |_p_|para pegar el contenido del buffer al buffer de edición. p Pegar del buffer sin nombre a la DERECHA del cursor. P Pegar del buffer sin nombre a la IZQUIERDA del cursor. nP Pegar n copias del buffer sin nombre a la IZQUIERDA del cursor. "aP Pegar del buffer con nombre "a" a la DERECHA del cursor. "b3P Pegar 3 copias del buffer con nombre "b" a la IZQUIERDA del cursor. Cuando use vi dentro de un xterm tiene otra opción para copiar texto. Marque el bloque de texto que desea copiar arrastrando el cursor del ratón sobre el texto. Si mantiene pulsado el botón izquierdo del ratón y arrastra el ratón desde el comienzo al final, invertirá el vídeo del texto. Esta operación automáticamente coloca el texto en un buffer reservado para el servidor de X Window. Para pegar el texto, pulse el botón de enmedio. Acuérdese de poner vi en modo de inserción dado que la entrada de texto se podría interpretar como comandos y el resultado sería cuando menos desagradable. Usando la misma técnica se puede copiar una sola palabra haciendo doble click con el botón izquierdo del ratón sobre la palabra. Solamente se copiará esa única palabra. Para pegarla se usa el mismo procedimiento que ateriormente. Los contenidos del buffer sólo cambian cuando se marca otro bloque de texto. Para mover un bloque de texto son necesarios tres pasos. 1. Borrar el texto para ponerlo en un buffer con o sin nombre. 2. Mover el cursor a la posición de destino. 3. Pegar el buffer. El proceso es el_mismo_que el de copia con un solo cambio en el primer paso para borrar. Cuando se usa el comando |_dd_|, la línea se borra y se coloca en el buffer sin nombre. Luego puede poner el contenido del mismo modo que lo hizo cuando copió el texto en la posición deseada. "add Borrar la línea y ponerla en el buffer con nombre a. "a4dd Borrar cuatro líneas y ponerlas en el buffer con nombre a. dw Borrar una palabra y ponerla en el buffer sin nombre. Vea la sección sobre el modificado de texto para ver más ejemplos de borrado de texto. _______________________________________________________________________________________________________________144 * * @ En el caso de que el sistema falle, el contenido de todos los buffers se pierde excepto el contenido de los buffers de edición, que se puede recuperar (ver comandos Útiles). A.4.4 Búsqueda y cambio de texto vi dispone de varios comandos para búsqueda. Usted puede buscar desde un solo carácter hasta una expressión completa. ___ ___ Los dos comandos principales de búsqueda basados en caracteres son |_f_|y |_t_|. fc Encuentra el siguiente caracter c. Se mueve a la derecha del siguiente. Fc Encuentra el siguiente caracter c. Se mueve a la izquierda del anterior. tc Se mueve a la DERECHA al caracter anterior al siguiente c. Tc SevmueveearlasIZQUIERDAialocaracternqueesiguesaldceanterior.vi(Enealgunassto es lo mismo que Fc). ; Repite el último comando f,F,t,T. , Igual que (;) pero cambiando la dirección del comando original. Si el caracter que usted buscaba no se encuentra, vi emitirá un pitido o le dará otro tipo de señal (tal vez un parpadeo de toda la pantalla). vi le permite buscar una cadena de texto en el buffer de edición. /tira Busca hacia la derecha y abajo la siguiente instancia de "tira". ?tira Busca hacia la izquierda y arriba la siguiente instancia de "tira". n Repite el último comando / o ?. N Repite el último comando / o ? en la dirección opuesta. ____ ___ Cuando use los comandos ||/_||or |_?_|, la última línea en la parte baja de la pantalla se vaciará. _______ Introduzca en esa línea la tira de caracteres que desea buscar y pulse |_Intro_|. ____ ___ La tira en el comando ||/_||or |_?_|puede ser una expresión regular. Una expresión regular puede ser una descripción de un conjunto de tiras. La descripción se construye usando texto entremezclado con caracteres especiales. Los caracteres especiales de una expresión regular son . * [ ] ^ $. . Vale por cualquier carácter excepto el carácter de nueva línea. " Tecla de "escape" para cualquier caracter especial. * Vale por 0 o más instancias del caracter anterior. [ ] Busca exactamente uno de los caracteres incluídos entre los corchetes. ^ El caracter que sigue a ^ debe estar al principio de la línea. $ El caracter que precede a $ se busca al final de la línea. [^] Busca cualquier cosa que no se encuentre despues de ^ dentro de los corchetes. [-] Busca un rango de caracteres. El único modo de acostumbrarse a usar las expresiones regulares es usándolas. A continuación mostramos varios ejemplos de uso: _______________________________________________________________________________________________________________A.4. T* *utorial avanzado de Vi @ c.ch Coincide con coche, cacho, cochera, etc. c".pe Coincide con c.pe, c.per, etc. sto*p Coincide con stp, stop, stoop, etc. car.*n Coincide con cartón, carrillón, carmen, etc. xyz.* Coincide con xyz al final de la línea. ^Los Encuentra cualquier línea que empiece con Los. abcdef$ Encuentra cualquier línea que termine con abcdef. ^Solo$ Coincide con cualquier línea que sólo tenga la palabra "Solo". p[aiue]so Coincide con paso, piso, puso, peso. Ver[D-F] Coincide con VerD, VerE, VerF. Ver[^1-9] Coincide con Ver siempre que a continuación NO haya un número. the[ir][re] Coincide con their, therr, there, theie. [A-Za-z][A-Za-z]* Coincide con cualquier palabra. vi usa el modo de comandos de ex para llevar a cabo búsquedas y sustituciones. Todos los comandos que empiezan con dos puntos son comandos en modo ex. Los comandos de búsqueda y sustitución permiten que se usen expresiones regulares sobre un rango de líneas y sustituir la tira de caracteres que se busca. El usuario puede pedir confirmación antes de que se realice la sustitución. Merece la pena hacer una revisión de la representación de los números de línea en el tutorial de ed. :,s///g Comando general. :1,$s/los/Los/g Buscar el fichero entero y sustituir los por Los. :%s/the/The/g % siginifica el fichero entero (igual que arriba). :.,5s/^.*//g Borra el contenido de la línea actual hasta la quinta. :%s/los/Los/gc Sustituye "los" con "Los" preguntando antes de hacer la operación. :%s/^....//g Borra los primeros cuatro carácteres de cada línea. El comando de búsqueda_es muy potente cuando se combina con las expresiones regulares. Si no se incluye la directiva |_g_|entonces el cambio sólo se aplica a la primera instancia que se encuentre en cada línea. En ocasiones usted quiere usar los caracteres de búsqueda en los caracteres de sustitución. Se puede reescribir todo el comando en la línea pero vi permite que los caracteres de sustitución incluyan algunos caracteres especiales. :1,5s/ayuda/&ndo/g Sustituye ayuda por ayudando en las cinco primeras líneas. :%s/ */&&/g Duplica el número de espacios entre palabras. El uso de la tira de caracteres completa_para búsqueda_tiene sus límites y por lo tanto vi usa los paréntesis en secuencia de escape ||(_||y ||)_||para seleccionar el rango de la sustitución. El uso de ____ un dígito en secuencia de escape |_1_|identifica el rango en el orden de la definición y la sustitución se puede hacer. :s/"^"(.*"):.*/"1/g Borra todo despues de e incluyendo los dos puntos. :s/"(.*"):"(.*")/"2:"1/g Da la vuelta a las palabras a los dos lados de los dos puntos. vi ofrece comandos muy potentes que muchos editores de texto modernos no tienen o no pueden _______________________________________________________________________________________________________________146 * * @ ofrecer. El coste de esta potencia suele ser también el principal argumento en contra de vi. Los comandos pueden ser difíciles de aprender y leer. Sin embargo, la mayoría de las cosas buenas suelen ser un poco extrañas al principio. Con un poco de práctica y tiempo, los comandos de vi se convertirán en una segunda naturaleza para Ud.. Apéndice B The GNU General Public License GNU GENERAL PUBLIC LICENSE Version 2, June 1991 Copyright Oc 1989, 1991 Free Software Foundation, Inc. 675 Mass Ave, Cambridge, MA 02139, USA Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. Preamble The licenses for most software are designed to take away your freedom to share and change it. By contrast, the GNU General Public License is intended to guarantee your freedom to share and change free software_to make sure the software is free for all its users. This General Public License applies to most of the Free Software Foundation's software and to any other program whose authors commit to using it. (Some other Free Software Foundation software is covered by the GNU Library General Public License instead.) You can apply it to your programs, too. When we speak of free software, we are referring to freedom, not price. Our General Public Licenses are designed to make sure that you have the freedom to distribute copies of free software (and charge for this service if you wish), that you receive source code or can get it if you want it, that you can change the software or use pieces of it in new free programs; and that you know you can do these things. To protect your rights, we need to make restrictions that forbid anyone to deny you these rights or to ask you to surrender the rights. These restrictions translate to certain responsibilities for you if you distribute copies of the software, or if you modify it. For example, if you distribute copies of such a program, whether gratis or for a fee, you must give the recipients all the rights that you have. You must make sure that they, too, receive or can get the source code. And you must show them these terms so they know their rights. We protect your rights with two steps: (1) copyright the software, and (2) offer you this license 147 _______________________________________________________________________________________________________________148 * * @ which gives you legal permission to copy, distribute and/or modify the software. Also, for each author's protection and ours, we want to make certain that everyone understands that there is no warranty for this free software. If the software is modified by someone else and passed on, we want its recipients to know that what they have is not the original, so that any problems introduced by others will not reflect on the original authors' reputations. Finally, any free program is threatened constantly by software patents. We wish to avoid the danger that redistributors of a free program will individually obtain patent licenses, in effect making the program proprietary. To prevent this, we have made it clear that any patent must be licensed for everyone's free use or not licensed at all. The precise terms and conditions for copying, distribution and modification follow. Terms and Conditions 0. This License applies to any program or other work which contains a notice placed by the copyright holder saying it may be distributed under the terms of this General Public License. The "Program", below, refers to any such program or work, and a "work based on the Program" means either the Program or any derivative work under copyright law: that is to say, a work containing the Program or a portion of it, either verbatim or with modifications and/or translated into another language. (Hereinafter, translation is included without limitation in the term "modification".) Each licensee is addressed as "you". Activities other than copying, distribution and modification are not covered by this License; they are outside its scope. The act of running the Program is not restricted, and the output from the Program is covered only if its contents constitute a work based on the Program (independent of having been made by running the Program). Whether that is true depends on what the Program does. 1. You may copy and distribute verbatim copies of the Program's source code as you receive it, in any medium, provided that you conspicuously and appropriately publish on each copy an appropriate copyright notice and disclaimer of warranty; keep intact all the notices that refer to this License and to the absence of any warranty; and give any other recipients of the Program a copy of this License along with the Program. You may charge a fee for the physical act of transferring a copy, and you may at your option offer warranty protection in exchange for a fee. 2. You may modify your copy or copies of the Program or any portion of it, thus forming a work based on the Program, and copy and distribute such modifications or work under the terms of Section 1 above, provided that you also meet all of these conditions: a. You must cause the modified files to carry prominent notices stating that you changed the files and the date of any change. b. You must cause any work that you distribute or publish, that in whole or in part contains or is derived from the Program or any part thereof, to be licensed as a whole at no charge to all third parties under the terms of this License. _______________________________________________________________________________________________________________149 c. If the modified program normally reads commands interactively when run, you must cause it, when started running for such interactive use in the most ordinary way, to print or display an announcement including an appropriate copyright notice and a notice that there is no warranty (or else, saying that you provide a warranty) and that users may redistribute the program under these conditions, and telling the user how to view a copy of this License. (Exception: if the Program itself is interactive but does not normally print such an announcement, your work based on the Program is not required to print an announcement.) These requirements apply to the modified work as a whole. If identifiable sections of that work are not derived from the Program, and can be reasonably considered independent and separate works in themselves, then this License, and its terms, do not apply to those sections when you distribute them as separate works. But when you distribute the same sections as part of a whole which is a work based on the Program, the distribution of the whole must be on the terms of this License, whose permissions for other licensees extend to the entire whole, and thus to each and every part regardless of who wrote it. Thus, it is not the intent of this section to claim rights or contest your rights to work written entirely by you; rather, the intent is to exercise the right to control the distribution of derivative or collective works based on the Program. In addition, mere aggregation of another work not based on the Program with the Program (or with a work based on the Program) on a volume of a storage or distribution medium does not bring the other work under the scope of this License. 3. You may copy and distribute the Program (or a work based on it, under Section 2) in object code or executable form under the terms of Sections 1 and 2 above provided that you also do one of the following: a. Accompany it with the complete corresponding machine-readable source code, which must be distributed under the terms of Sections 1 and 2 above on a medium customarily used for software interchange; or, b. Accompany it with a written offer, valid for at least three years, to give any third party, for a charge no more than your cost of physically performing source distribution, a complete machine-readable copy of the corresponding source code, to be distributed under the terms of Sections 1 and 2 above on a medium customarily used for software interchange; or, c. Accompany it with the information you received as to the offer to distribute corresponding source code. (This alternative is allowed only for noncommercial distribution and only if you received the program in object code or executable form with such an offer, in accord with Subsection b above.) The source code for a work means the preferred form of the work for making modifications to it. For an executable work, complete source code means all the source code for all modules it contains, plus any associated interface definition files, plus the scripts used to control com- pilation and installation of the executable. However, as a special exception, the source code distributed need not include anything that is normally distributed (in either source or binary _______________________________________________________________________________________________________________150 * * @ form) with the major components (compiler, kernel, and so on) of the operating system on which the executable runs, unless that component itself accompanies the executable. If distribution of executable or object code is made by offering access to copy from a designated place, then offering equivalent access to copy the source code from the same place counts as distribution of the source code, even though third parties are not compelled to copy the source along with the object code. 4. You may not copy, modify, sublicense, or distribute the Program except as expressly provid- ed under this License. Any attempt otherwise to copy, modify, sublicense or distribute the Program is void, and will automatically terminate your rights under this License. However, parties who have received copies, or rights, from you under this License will not have their licenses terminated so long as such parties remain in full compliance. 5. You are not required to accept this License, since you have not signed it. However, nothing else grants you permission to modify or distribute the Program or its derivative works. These actions are prohibited by law if you do not accept this License. Therefore, by modifying or distributing the Program (or any work based on the Program), you indicate your acceptance of this License to do so, and all its terms and conditions for copying, distributing or modifying the Program or works based on it. 6. Each time you redistribute the Program (or any work based on the Program), the recipient automatically receives a license from the original licensor to copy, distribute or modify the Program subject to these terms and conditions. You may not impose any further restrictions on the recipients' exercise of the rights granted herein. You are not responsible for enforcing compliance by third parties to this License. 7. If, as a consequence of a court judgment or allegation of patent infringement or for any other reason (not limited to patent issues), conditions are imposed on you (whether by court order, agreement or otherwise) that contradict the conditions of this License, they do not excuse you from the conditions of this License. If you cannot distribute so as to satisfy simultaneously your obligations under this License and any other pertinent obligations, then as a consequence you may not distribute the Program at all. For example, if a patent license would not permit royalty-free redistribution of the Program by all those who receive copies directly or indirectly through you, then the only way you could satisfy both it and this License would be to refrain entirely from distribution of the Program. If any portion of this section is held invalid or unenforceable under any particular circumstance, the balance of the section is intended to apply and the section as a whole is intended to apply in other circumstances. It is not the purpose of this section to induce you to infringe any patents or other property right claims or to contest validity of any such claims; this section has the sole purpose of protecting the integrity of the free software distribution system, which is implemented by public license practices. Many people have made generous contributions to the wide range of software distributed through that system in reliance on consistent application of that system; it is up to the author/donor to decide if he or she is willing to distribute software through any other system and a licensee cannot impose that choice. _______________________________________________________________________________________________________________151 This section is intended to make thoroughly clear what is believed to be a consequence of the rest of this License. 8. If the distribution and/or use of the Program is restricted in certain countries either by patents or by copyrighted interfaces, the original copyright holder who places the Program under this License may add an explicit geographical distribution limitation excluding those countries, so that distribution is permitted only in or among countries not thus excluded. In such case, this License incorporates the limitation as if written in the body of this License. 9. The Free Software Foundation may publish revised and/or new versions of the General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. Each version is given a distinguishing version number. If the Program specifies a version number of this License which applies to it and "any later version", you have the option of following the terms and conditions either of that version or of any later version published by the Free Software Foundation. If the Program does not specify a version number of this License, you may choose any version ever published by the Free Software Foundation. 10. If you wish to incorporate parts of the Program into other free programs whose distribution conditions are different, write to the author to ask for permission. For software which is copyrighted by the Free Software Foundation, write to the Free Software Foundation; we sometimes make exceptions for this. Our decision will be guided by the two goals of preserving the free status of all derivatives of our free software and of promoting the sharing and reuse of software generally. NO WARRANTY 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRAN- TY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRAN- TY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIM- ITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PER- FORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRIT- ING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CON- SEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES _______________________________________________________________________________________________________________152 * * @ OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSI- BILITY OF SUCH DAMAGES. How to Apply These Terms to Your New Programs If you develop a new program, and you want it to be of the greatest possible use to the public, the best way to achieve this is to make it free software which everyone can redistribute and change under these terms. To do so, attach the following notices to the program. It is safest to attach them to the start of each source file to most effectively convey the exclusion of warranty; and each file should have at least the "copyright" line and a pointer to where the full notice is found. one line to give the program's name and an idea of what it does. Copyright Oc 19yy name of author This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FIT- NESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, Also add information on how to contact you by electronic and paper mail. If the program is interactive, make it output a short notice like this when it starts in an interactive mode: Gnomovision version 69, Copyright Oc 19yy name of author Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. This is free software, and you are welcome to redistribute it under certain conditions; type `show c' for details. The hypothetical commands `show w' and `show c' should show the appropriate parts of the General Public License. Of course, the commands you use may be called something other than `show w' and `show c'; they could even be mouse-clicks or menu items_whatever suits your program. You should also get your employer (if you work as a programmer) or your school, if any, to sign a "copyright disclaimer" for the program, if necessary. Here is a sample; alter the names: _______________________________________________________________________________________________________________153 Yoyodyne, Inc., hereby disclaims all copyright interest in the program `Gnomovision' (which makes passes at compilers) written by James Hacker. signature of Ty Coon, 1 April 1989 Ty Coon, President of Vice This General Public License does not permit incorporating your program into proprietary pro- grams. If your program is a subroutine library, you may consider it more useful to permit linking proprietary applications with the library. If this is what you want to do, use the GNU Library General Public License instead of this License. _______________________________________________________________________________________________________________154 * * @ Apéndice C The GNU Library General Public License GNU LIBRARY GENERAL PUBLIC LICENSE Version 2, June 1991 Copyright Oc 1991 Free Software Foundation, Inc. 675 Mass Ave, Cambridge, MA 02139, USA Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. [This is the first released version of the library GPL. It is numbered 2 because it goes with version 2 of the ordinary GPL.] Preamble The licenses for most software are designed to take away your freedom to share and change it. By contrast, the GNU General Public Licenses are intended to guarantee your freedom to share and change free software-to make sure the software is free for all its users. This license, the Library General Public License, applies to some specially designated Free Soft- ware Foundation software, and to any other libraries whose authors decide to use it. You can use it for your libraries, too. When we speak of free software, we are referring to freedom, not price. Our General Public Licenses are designed to make sure that you have the freedom to distribute copies of free software (and charge for this service if you wish), that you receive source code or can get it if you want it, that you can change the software or use pieces of it in new free programs; and that you know you can do these things. To protect your rights, we need to make restrictions that forbid anyone to deny you these rights or to ask you to surrender the rights. These restrictions translate to certain responsibilities for you if you distribute copies of the library, or if you modify it. 155 _______________________________________________________________________________________________________________156 * * Ap*@ For example, if you distribute copies of the library, whether gratis or for a fee, you must give the recipients all the rights that we gave you. You must make sure that they, too, receive or can get the source code. If you link a program with the library, you must provide complete object files to the recipients so that they can relink them with the library, after making changes to the library and recompiling it. And you must show them these terms so they know their rights. Our method of protecting your rights has two steps: (1) copyright the library, and (2) offer you this license which gives you legal permission to copy, distribute and/or modify the library. Also, for each distributor's protection, we want to make certain that everyone understands that there is no warranty for this free library. If the library is modified by someone else and passed on, we want its recipients to know that what they have is not the original version, so that any problems introduced by others will not reflect on the original authors' reputations. Finally, any free program is threatened constantly by software patents. We wish to avoid the danger that companies distributing free software will individually obtain patent licenses, thus in effect transforming the program into proprietary software. To prevent this, we have made it clear that any patent must be licensed for everyone's free use or not licensed at all. Most GNU software, including some libraries, is covered by the ordinary GNU General Public License, which was designed for utility programs. This license, the GNU Library General Public License, applies to certain designated libraries. This license is quite different from the ordinary one; be sure to read it in full, and don't assume that anything in it is the same as in the ordinary license. The reason we have a separate public license for some libraries is that they blur the distinction we usually make between modifying or adding to a program and simply using it. Linking a program with a library, without changing the library, is in some sense simply using the library, and is analogous to running a utility program or application program. However, in a textual and legal sense, the linked executable is a combined work, a derivative of the original library, and the ordinary General Public License treats it as such. Because of this blurred distinction, using the ordinary General Public License for libraries did not effectively promote software sharing, because most developers did not use the libraries. We concluded that weaker conditions might promote sharing better. However, unrestricted linking of non-free programs would deprive the users of those programs of all benefit from the free status of the libraries themselves. This Library General Public License is intended to permit developers of non-free programs to use free libraries, while preserving your freedom as a user of such programs to change the free libraries that are incorporated in them. (We have not seen how to achieve this as regards changes in header files, but we have achieved it as regards changes in the actual functions of the Library.) The hope is that this will lead to faster development of free libraries. The precise terms and conditions for copying, distribution and modification follow. Pay close attention to the difference between a "work based on the library" and a "work that uses the library". The former contains code derived from the library, while the latter only works together with the library. Note that it is possible for a library to be covered by the ordinary General Public License rather than by this special one. _______________________________________________________________________________________________________________157 Terms and Conditions for Copying, Distribution and Modifi- cation 0. This License Agreement applies to any software library which contains a notice placed by the copyright holder or other authorized party saying it may be distributed under the terms of this Library General Public License (also called "this License"). Each licensee is addressed as "you". A "library" means a collection of software functions and/or data prepared so as to be conve- niently linked with application programs (which use some of those functions and data) to form executables. The "Library", below, refers to any such software library or work which has been distributed under these terms. A "work based on the Library" means either the Library or any derivative work under copyright law: that is to say, a work containing the Library or a portion of it, either verbatim or with modifications and/or translated straightforwardly into another language. (Hereinafter, translation is included without limitation in the term "modification".) "Source code" for a work means the preferred form of the work for making modifications to it. For a library, complete source code means all the source code for all modules it contains, plus any associated interface definition files, plus the scripts used to control compilation and installation of the library. Activities other than copying, distribution and modification are not covered by this License; they are outside its scope. The act of running a program using the Library is not restricted, and output from such a program is covered only if its contents constitute a work based on the Library (independent of the use of the Library in a tool for writing it). Whether that is true depends on what the Library does and what the program that uses the Library does. 1. You may copy and distribute verbatim copies of the Library's complete source code as you receive it, in any medium, provided that you conspicuously and appropriately publish on each copy an appropriate copyright notice and disclaimer of warranty; keep intact all the notices that refer to this License and to the absence of any warranty; and distribute a copy of this License along with the Library. You may charge a fee for the physical act of transferring a copy, and you may at your option offer warranty protection in exchange for a fee. 2. You may modify your copy or copies of the Library or any portion of it, thus forming a work based on the Library, and copy and distribute such modifications or work under the terms of Section 1 above, provided that you also meet all of these conditions: a. The modified work must itself be a software library. b. You must cause the files modified to carry prominent notices stating that you changed the files and the date of any change. c. You must cause the whole of the work to be licensed at no charge to all third parties under the terms of this License. _______________________________________________________________________________________________________________158 * * Ap*@ d. If a facility in the modified Library refers to a function or a table of data to be supplied by an application program that uses the facility, other than as an argument passed when the facility is invoked, then you must make a good faith effort to ensure that, in the event an application does not supply such function or table, the facility still operates, and performs whatever part of its purpose remains meaningful. (For example, a function in a library to compute square roots has a purpose that is entirely well-defined independent of the application. Therefore, Subsection 2d requires that any application-supplied function or table used by this function must be optional: if the application does not supply it, the square root function must still compute square roots.) These requirements apply to the modified work as a whole. If identifiable sections of that work are not derived from the Library, and can be reasonably considered independent and separate works in themselves, then this License, and its terms, do not apply to those sections when you distribute them as separate works. But when you distribute the same sections as part of a whole which is a work based on the Library, the distribution of the whole must be on the terms of this License, whose permissions for other licensees extend to the entire whole, and thus to each and every part regardless of who wrote it. Thus, it is not the intent of this section to claim rights or contest your rights to work written entirely by you; rather, the intent is to exercise the right to control the distribution of derivative or collective works based on the Library. In addition, mere aggregation of another work not based on the Library with the Library (or with a work based on the Library) on a volume of a storage or distribution medium does not bring the other work under the scope of this License. 3. You may opt to apply the terms of the ordinary GNU General Public License instead of this License to a given copy of the Library. To do this, you must alter all the notices that refer to this License, so that they refer to the ordinary GNU General Public License, version 2, instead of to this License. (If a newer version than version 2 of the ordinary GNU General Public License has appeared, then you can specify that version instead if you wish.) Do not make any other change in these notices. Once this change is made in a given copy, it is irreversible for that copy, so the ordinary GNU General Public License applies to all subsequent copies and derivative works made from that copy. This option is useful when you wish to copy part of the code of the Library into a program that is not a library. 4. You may copy and distribute the Library (or a portion or derivative of it, under Section 2) in object code or executable form under the terms of Sections 1 and 2 above provided that you accompany it with the complete corresponding machine-readable source code, which must be distributed under the terms of Sections 1 and 2 above on a medium customarily used for software interchange. If distribution of object code is made by offering access to copy from a designated place, then offering equivalent access to copy the source code from the same place satisfies the requirement _______________________________________________________________________________________________________________159 to distribute the source code, even though third parties are not compelled to copy the source along with the object code. 5. A program that contains no derivative of any portion of the Library, but is designed to work with the Library by being compiled or linked with it, is called a "work that uses the Library". Such a work, in isolation, is not a derivative work of the Library, and therefore falls outside the scope of this License. However, linking a "work that uses the Library" with the Library creates an executable that is a derivative of the Library (because it contains portions of the Library), rather than a "work that uses the library". The executable is therefore covered by this License. Section 6 states terms for distribution of such executables. When a "work that uses the Library" uses material from a header file that is part of the Library, the object code for the work may be a derivative work of the Library even though the source code is not. Whether this is true is especially significant if the work can be linked without the Library, or if the work is itself a library. The threshold for this to be true is not precisely defined by law. If such an object file uses only numerical parameters, data structure layouts and accessors, and small macros and small inline functions (ten lines or less in length), then the use of the object file is unrestricted, regardless of whether it is legally a derivative work. (Executables containing this object code plus portions of the Library will still fall under Section 6.) Otherwise, if the work is a derivative of the Library, you may distribute the object code for the work under the terms of Section 6. Any executables containing that work also fall under Section 6, whether or not they are linked directly with the Library itself. 6. As an exception to the Sections above, you may also compile or link a "work that uses the Library" with the Library to produce a work containing portions of the Library, and distribute that work under terms of your choice, provided that the terms permit modification of the work for the customer's own use and reverse engineering for debugging such modifications. You must give prominent notice with each copy of the work that the Library is used in it and that the Library and its use are covered by this License. You must supply a copy of this License. If the work during execution displays copyright notices, you must include the copyright notice for the Library among them, as well as a reference directing the user to the copy of this License. Also, you must do one of these things: a. Accompany the work with the complete corresponding machine-readable source code for the Library including whatever changes were used in the work (which must be distributed under Sections 1 and 2 above); and, if the work is an executable linked with the Library, with the complete machine-readable "work that uses the Library", as object code and/or source code, so that the user can modify the Library and then relink to produce a modified executable containing the modified Library. (It is understood that the user who changes the contents of definitions files in the Library will not necessarily be able to recompile the application to use the modified definitions.) b. Accompany the work with a written offer, valid for at least three years, to give the same user the materials specified in Subsection 6a, above, for a charge no more than the cost _______________________________________________________________________________________________________________160 * * Ap*@ of performing this distribution. c. If distribution of the work is made by offering access to copy from a designated place, offer equivalent access to copy the above specified materials from the same place. d. Verify that the user has already received a copy of these materials or that you have already sent this user a copy. For an executable, the required form of the "work that uses the Library"must include any data and utility programs needed for reproducing the executable from it. However, as a special exception, the source code distributed need not include anything that is normally distributed (in either source or binary form) with the major components (compiler, kernel, and so on) of the operating system on which the executable runs, unless that component itself accompanies the executable. It may happen that this requirement contradicts the license restrictions of other proprietary libraries that do not normally accompany the operating system. Such a contradiction means you cannot use both them and the Library together in an executable that you distribute. 7. You may place library facilities that are a work based on the Library side-by-side in a single library together with other library facilities not covered by this License, and distribute such a combined library, provided that the separate distribution of the work based on the Library and of the other library facilities is otherwise permitted, and provided that you do these two things: a. Accompany the combined library with a copy of the same work based on the Library, uncombined with any other library facilities. This must be distributed under the terms of the Sections above. b. Give prominent notice with the combined library of the fact that part of it is a work based on the Library, and explaining where to find the accompanying uncombined form of the same work. 8. You may not copy, modify, sublicense, link with, or distribute the Library except as expressly provided under this License. Any attempt otherwise to copy, modify, sublicense, link with, or distribute the Library is void, and will automatically terminate your rights under this License. However, parties who have received copies, or rights, from you under this License will not have their licenses terminated so long as such parties remain in full compliance. 9. You are not required to accept this License, since you have not signed it. However, nothing else grants you permission to modify or distribute the Library or its derivative works. These actions are prohibited by law if you do not accept this License. Therefore, by modifying or distributing the Library (or any work based on the Library), you indicate your acceptance of this License to do so, and all its terms and conditions for copying, distributing or modifying the Library or works based on it. 10. Each time you redistribute the Library (or any work based on the Library), the recipient automatically receives a license from the original licensor to copy, distribute, link with or modify the Library subject to these terms and conditions. You may not impose any further _______________________________________________________________________________________________________________161 restrictions on the recipients' exercise of the rights granted herein. You are not responsible for enforcing compliance by third parties to this License. 11. If, as a consequence of a court judgment or allegation of patent infringement or for any other reason (not limited to patent issues), conditions are imposed on you (whether by court order, agreement or otherwise) that contradict the conditions of this License, they do not excuse you from the conditions of this License. If you cannot distribute so as to satisfy simultaneously your obligations under this License and any other pertinent obligations, then as a consequence you may not distribute the Library at all. For example, if a patent license would not permit royalty-free redistribution of the Library by all those who receive copies directly or indirectly through you, then the only way you could satisfy both it and this License would be to refrain entirely from distribution of the Library. If any portion of this section is held invalid or unenforceable under any particular circumstance, the balance of the section is intended to apply, and the section as a whole is intended to apply in other circumstances. It is not the purpose of this section to induce you to infringe any patents or other property right claims or to contest validity of any such claims; this section has the sole purpose of protecting the integrity of the free software distribution system which is implemented by public license practices. Many people have made generous contributions to the wide range of software distributed through that system in reliance on consistent application of that system; it is up to the author/donor to decide if he or she is willing to distribute software through any other system and a licensee cannot impose that choice. This section is intended to make thoroughly clear what is believed to be a consequence of the rest of this License. 12. If the distribution and/or use of the Library is restricted in certain countries either by patents or by copyrighted interfaces, the original copyright holder who places the Library under this License may add an explicit geographical distribution limitation excluding those countries, so that distribution is permitted only in or among countries not thus excluded. In such case, this License incorporates the limitation as if written in the body of this License. 13. The Free Software Foundation may publish revised and/or new versions of the Library General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. Each version is given a distinguishing version number. If the Library specifies a version number of this License which applies to it and a_ny later version", you have the option of following the terms and conditions either of that version or of any later version published by the Free Software Foundation. If the Library does not specify a license version number, you may choose any version ever published by the Free Software Foundation. 14. If you wish to incorporate parts of the Library into other free programs whose distribution conditions are incompatible with these, write to the author to ask for permission. For software which is copyrighted by the Free Software Foundation, write to the Free Software Foundation; we sometimes make exceptions for this. Our decision will be guided by the two goals of _______________________________________________________________________________________________________________162 * * Ap*@ preserving the free status of all derivatives of our free software and of promoting the sharing and reuse of software generally. NO WARRANTY 11. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO WAR- RANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE LIBRARY "AS IS"WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMIT- ED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PER- FORMANCE OF THE LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DE- FECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRIT- ING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CON- SEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING REN- DERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. How to Apply These Terms to Your New Libraries If you develop a new library, and you want it to be of the greatest possible use to the public, we recommend making it free software that everyone can redistribute and change. You can do so by permitting redistribution under these terms (or, alternatively, under the terms of the ordinary General Public License). To apply these terms, attach the following notices to the library. It is safest to attach them to the start of each source file to most effectively convey the exclusion of warranty; and each file should have at least the "copyright" line and a pointer to where the full notice is found. one line to give the library's name and a brief idea of what it does. Copyright (C) year name of author This library is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License as published by the Free Software Foundation; _______________________________________________________________________________________________________________163 either version 2 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WAR- RANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public License for more details. You should have received a copy of the GNU Library General Public License along with this library; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. Also add information on how to contact you by electronic and paper mail. You should also get your employer (if you work as a programmer) or your school, if any, to sign a "copyright disclaimer" for the library, if necessary. Here is a sample; alter the names: Yoyodyne, Inc., hereby disclaims all copyright interest in the library `Frob' (a library for tweaking knobs) written by James Random Hacker. signature of Ty Coon, 1 April 1990 Ty Coon, President of Vice That's all there is to it! _______________________________________________________________________________________________________________164 * * Ap*@ Apéndice D >Qué es LuCAS? El proyecto LuCAS (Linux en CAStellano) comenzó, como tantas otras cosas ligadas a Linux, en un bar tomando cervezas (reales, no virtuales). Era allá por marzo de 1995 y ya se había comentado en las áreas de FidoNet la necesidad de disponer de textos en castellano sobre Linux. Fue en aquel bar, el bar Ekin de Algorta (Bizkaia), donde nos reuníamos los usuarios de FidoNet todos los domingos, donde surgió la idea de pasar a la acción. Tras discutirlo un poco, decidimos comenzar por traducir algo que fuese útil para aquellos que comenzaban a dar sus primeros pasos en linux, y creímos que el "Installation & Getting Started" de Matt Welsh era el documento más adecuado. Como era mucho trabajo para una sola persona, y había mucha gente que se había mostrado dispuesta a colaborar, había que hacerlo bien, y el trabajo de traducir un libro como éste requería una labor de coordinación que inmediatamente asumimos Ramón Gutiérrez y yo, Alfonso Belloso. Yo me hice cargo de coordinar a los traductores para que no hiciesen trabajo repetido, y Ramón se encargaba de juntar los trabajos y generar el documento final. Pedimos permiso al propio Matt Welsh, y asi echamos a andar. Hubo que esperar un largo tiempo a tener una primera versión presentable del libro, pero se consiguió. Fundamentalmente, el hecho de que era una experiencia nueva, y la diversidad de gente que colaboró, hizo que este primer paso durase casi un año, pero mereció la pena esperar. Hay que decir que a pesar de que todo este movimiento surgió de FidoNet, y que desde allí se sigue muy de cerca, al poco de comenzar a trabajar en ello fue cuando conseguí mi primera cuenta de Internet, y comprobé que la forma más práctica de coordinarnos era a través de La Red, ya que por Fidonet las comunicaciones se hacían demasiado largas en el tiempo y no siempre eran seguras (para contactar con algún colaborador a veces se podía tardar 2 semanas, o no saber nada de él jamás). Y con ello comenzamos a disponer de más herramientas: primero un servidor de ftp, luego una lista de correo, un servidor de Web, y así hasta hoy. Bueno, pues una vez terminado este primer libro nos quedó el gusanillo de hacer más, y visto que yo acabé un poco cansado, vino Juan José Amor, me tomó el relevo y comenzamos a traducir la "Network Administrator Guide" de Olaf Kirch. Esta vez, y con la infraestructura ya montada, tardamos unos pocos meses en tener la primera versión. Y después de éste ya se están haciendo más. Ya esta terminada la traduccion de la "Linux User Guide" (en su fase alfa), y hay algún proyecto más en marcha. No quiero dejar de mencionar otros proyectos que trabajan en paralelo a éste. LuCAS en sí se ha ido dedicando más a la labor de traduc- 165 _______________________________________________________________________________________________________________166 * * @ ción de textos tipo libro, más concretamente a los del LDP, y creaciones propias, si bien en su origen se ideó para traducir cualquier tipo de documento e incluso para crear documentos directamente en castellano. El SLUG (Spanish Linux User Group) ya existía cuando surgió LuCAS, o acababa de aparecer. Al amparo de LuCAS surgió el INSFLUG, que se centra en la traducción/creación de FAQs, HOWTOs y documentos más pequeños. Y probablemente existan más grupos haciendo tareas similares, pero que ahora no conozco, ni soy capaz de recordar. Para contactar con los coordinadores del grupo LuCAS, puede hacerlo con Alfonso Belloso Mar- tinez o en ; y con Juan Jose Amor Iglesias . Apéndice E >Qué es INSFLUG? El INSFLUG nació allá por marzo del '96, siendo su seno materno el área echomail de FidoNet R34.LINUX. Surge ante el entusiasmo de los que empezábamos por aquel entonces a adentrarnos en el mundo del Linux, maravillados por como un SO tan potente, de distribución libre, podía haberse hecho realidad gracias al buen hacer, generosidad e increíble colaboración entre tantas personas "dispersas"por el globo. . . Nos sentimos aún más maravillados al observar la increíble participación de la gente que fre- cuentaba el área, modélica en FidoNet, y por la inestimable ayuda que allí se prestaba; eso fue, _haciendo un poco de psicólogo_ lo que produjo la formación del INSFLUG, un inmenso y sincero agradecimiento, además de enormes ganas de corresponder por nuestra parte, aportando nuestro granito de arena a la comunidad Linux en forma de traducciones de Howtos y FAQs, documentos que generalmente no superan la decena de páginas, y con cuya traducción además de aportar, el nóvel o no tan nóvel, profundiza en el tema del que trate el Howto a medida que lo traduce, redundando en beneficio para él mismo. . . ;-) El INSFLUG se centra en la traducción de Howtos y FAQs (Frecuently Asked Questions, algo así como Preguntas de Uso Frecuente, PUFs). Para la traducción no necesitas más que un editor de texto (En Linux hay muchos) normal, y el paquete linuxdoc-sgml, con el que empleando un lenguaje muy sencillo, similar al HTML, una vez escrito un sólo fuente, se podrán obtener a partir de él el documento en formatos *.dvi, *.ps, *.txt, *.lyx, *.rtf, *.info, *.html, etc.. Cuentas además con una guía traducida del uso del linuxdoc-sgml en la que se añaden detalles de configuración para el castellano, además de la facilidad que supone el traducir editando el fuente original en inglés, ya que los codigos, etc., ya están; no obstante, es un lenguaje sencillísimo, además de ser el formato oficial de todos los Howtos. El INSFLUG colabora estrechamente con LuCAS, es más, hay varias personas que colaboran con ambos grupos. El grupo LuCAS se dedica mayormente a las guías ("guides"), los libros más extensos del LDP o (Linux Documentation Project). El coordinador de INSFLUG es Francisco J. Montilla (email: ; 167 _______________________________________________________________________________________________________________168 * * @ irc: pukka; FiDO: 2:345/402.22). Si desea más información puede consultar su página en WWW en y su espacio de FTP en . Bibliografía [1] Almesberger, Werner. LILO: Generic Boot Loader for Linux. Disponible electrónicamente: tsx-11.mit.edu. 3 de Julio de 1993. [2] Bach, Maurice J. The Design of the UNIX Operating System. Englewood Cliffs, New Jersey: Prentice-Hall, Inc. 1986. [3] Lamport, Leslie. LATEX: A Document Preparation System. Reading, Massachusetts: Addison- Wesley Publishing Company. 1986. [4] Stallman, Richard M. GNU Emacs Manual, octava edición. Cambridge, Massachusetts: Free Software Foundation. 1993. 169