¿Le han dicho que "clone el repositorio y lo cree" y no sabe qué hacer a continuación? Le mostraremos cómo hacer que ese programa en GitHub se ejecute en Linux, incluso si es un principiante.
Las instrucciones que componen un programa de computadora se escriben, editan y guardan en archivos de texto. Un programa llamado compilador procesa estos archivos. Esto produce la versión ejecutable del programa. Los archivos de texto de las instrucciones se denominan código fuente. La versión del programa que realmente se puede ejecutar en una computadora se llama binario o ejecutable.
Esa es una versión simplificada de los eventos, pero presenta una imagen correcta, aunque generalizada. En la práctica, encontrará todo tipo de variaciones en ese modelo. A veces, otros programas generan los archivos de texto. Otras veces, el código fuente se ejecuta dentro de un intérprete y no es necesario compilarlo, etc.
Sin embargo, la única verdad universal en todos los proyectos de software es la siguiente: los archivos de código fuente son las joyas de la corona y deben cuidarse con el mismo cuidado.
Programas de control de versiones
Todos los archivos de código fuente dentro de un proyecto se denominan base de código. Los proyectos grandes a menudo tienen muchos desarrolladores trabajando en la base de código. Cada cambio de código debe ser rastreado e identificable. Si es necesario, los cambios deben ser reversibles. Si diferentes desarrolladores realizan cambios en el mismo archivo de código fuente, sus ediciones deben fusionarse.
No es sorprendente, entonces, que existan programas de software llamados sistemas de control de versiones para facilitar la gestión de cambios en la base de código. Los sistemas de control de versiones mantienen todas las versiones anteriores de cada archivo en la base de código, y cada cambio se registra, comenta y rastrea.
Una cosita llamada Git
Linus Torvalds, el creador del kernel de Linux, desarrolló un programa de control de versiones llamado Git para administrar el código base del kernel de Linux. Ahora es el software de control de versiones más adoptado en el mundo. Hay millones de personas que lo utilizan, literalmente.
Con Git, la base de código de un proyecto se almacena en repositorios . Además de los repositorios locales que se encuentran en las computadoras de los desarrolladores y, quizás, en un servidor central en la red, es una buena práctica tener un repositorio remoto o fuera del sitio.
Y ahí es donde entra GitHub.
GitHub
GitHub fue creado como resultado del git
éxito de '. Los fundadores vieron la necesidad emergente de git
repositorios remotos alojados de forma segura . Lanzaron un negocio que proporciona una plataforma en la nube para permitir que los equipos de desarrollo alojen repositorios remotos. En abril de 2019, GitHub aloja más de 100 millones de repositorios.
Si una aplicación es un proyecto de código abierto, es muy probable que se aloje en GitHub. Hay otras plataformas de repositorio disponibles, como BitBucket y GitLab, pero GitHub tiene la mayor parte de los repositorios de código abierto.
Anatomía de un repositorio
Un repositorio de GitHub se compone de carpetas que contienen archivos como los archivos de código fuente más importantes. Por lo general, hay muchos otros tipos de archivos en el repositorio. Puede haber archivos de documentación, páginas de manual, archivos de licencia de software, instrucciones de compilación y archivos de script de shell. No hay reglas sobre lo que debe o debe contener un repositorio, pero existen convenciones.
Si conoce una cocina, puede navegar por cualquier cocina. Lo mismo ocurre con los repositorios. Una vez que comprenda las convenciones, sabrá adónde ir para encontrar lo que necesita.
Entonces, ¿cómo obtienes una copia del repositorio en tu computadora y cómo construyes el programa en un ejecutable binario?
El archivo Léame
Es tradicional incluir un archivo Léame en un repositorio. Podría llamarse Léame, Léame o Léame. Puede tener una extensión de ".md" o ninguna extensión.
Echemos un vistazo al repositorio de GitHub para el editor Atom. Verá una larga lista de carpetas y archivos. Desplácese hacia abajo y verá el contenido del archivo README.md.
GitHub coloca automáticamente el contenido del archivo Léame en la página principal del repositorio. Si el archivo Léame tiene una extensión ".md", contendrá el lenguaje de marcado Markdown. Esto permite a los desarrolladores utilizar elementos de estilo, como fuentes, viñetas e imágenes.
Por lo general, un archivo Léame tiene secciones que le indican de qué se trata el proyecto, cuál es el tipo de licencia, quién mantiene el proyecto, cómo participar y cómo construir y ejecutar la aplicación.
Si no enumera las instrucciones de construcción reales, le dirá dónde encontrar esta información. Otra información útil para construir la aplicación, como las herramientas de compilación necesarias y otras dependencias, puede aparecer aquí o un enlace puede llevarlo a esa información.
El repositorio de cajas
Nuestra misión es clonar el repositorio de cajas y luego construir la boxes
aplicación.
El repositorio sigue el mismo diseño que el de Atom. Hay una lista de carpetas y archivos y debajo está el contenido del archivo Léame. Sigue el diseño estándar de un repositorio, pero es un proyecto más pequeño, por lo que hay menos carpetas y archivos.
El archivo Léame también es más breve. Tiene una sección llamada "Desarrollo". En esa sección hay un enlace titulado "construcción desde la fuente". Si seguimos ese enlace, deberíamos encontrar la información que necesitamos.
Por lo general, se necesita algo de investigación ligera para navegar por el repositorio y encontrar la información que desea, pero no es difícil. Lea todo en la página del repositorio con atención. A veces, la información está ahí, pero es posible que no se muestre de forma destacada.
Las dependencias
La página "Construir desde el código fuente" tiene una sección llamada "Construir en Linux", y eso es justo lo que necesitamos. Dice que debemos tener un compilador de C, Bison y Flex instalados.
Las instrucciones de compilación dicen que emita el make
comando, por lo que también lo necesitaremos make
.
Las herramientas necesarias para crear esta aplicación son un compilador de C, Bison, Flex make
y Git (para clonar el repositorio en su computadora).
Este artículo se investigó en computadoras que ejecutan las distribuciones Ubuntu, Fedora y Manjaro Linux. Ninguno de los miembros de la distribución tenía todas estas herramientas instaladas; había que instalar algo en cada una de ellas.
Instalación del juego de herramientas
Ubuntu tenía que tener Git, Flex, Bison e make
instalado. Aquí están los comandos:
sudo apt-get install git
sudo apt-get install flex
sudo apt-get install bison
sudo apt-get install make
Fedora tenía que tener Flex, Bison e make
instalado. Aquí están los comandos:
sudo dnf instalar flex
sudo dnf instalar bison
sudo dnf instalar hacer
Manjaro tenía que tener el compilador GCC, Flex y Bison instalados. Aquí están los comandos:
sudo pacman -Syu gcc
sudo pacman -Syu flex
sudo pacman -Syu bison
Clonación del repositorio
Cada repositorio de GitHub tiene una dirección web específica que se usa con Git para clonar el repositorio en su computadora. En la página principal del repositorio de cajas, hay un botón verde con la etiqueta "Clonar o descargar".
Haga clic en el botón para ver la dirección web. Esta es la dirección que debemos pasar al git
comando cuando clonemos el repositorio.
Cambie al directorio en el que queremos clonar el repositorio y luego use este comando. Si la ventana de su terminal lo admite, puede copiar y pegar la dirección web en el comando. Presione Ctrl + Shift + V para pegar en una ventana de terminal GNOME.
Git clona el repositorio remoto y crea uno local en su computadora. Nos dice que está clonando en un directorio llamado "cajas".
El directorio de cajas se crea dentro del directorio desde el que emitió el git
comando. Si cambiamos al directorio de cajas y miramos el contenido, vemos la misma lista de archivos y carpetas que vimos en la página de GitHub.
¡Genial! Hemos clonado con éxito el código fuente y otros archivos en nuestra computadora. Ahora, necesitamos construir la aplicación.
Construyendo la Aplicación
Para construir la aplicación, debemos seguir las instrucciones del repositorio de GitHub. A veces, ejecutamos un archivo de shell en particular y otros ejecutamos make
. Las instrucciones de compilación que seguimos nos dijeron que corriéramos make
.
La make
utilidad lee y ejecuta un conjunto de instrucciones de un archivo MAKE. Estas instrucciones indican make
cómo compilar el programa y vincularlo. make
pasa las instrucciones al compilador y otras herramientas de compilación.
El comando que se nos dice que usemos llamará make
dos veces. La primera llamada a make
compila la aplicación y la segunda ejecuta un conjunto de pruebas.
El comando que las instrucciones de compilación nos dijeron que usemos es:
hacer && hacer prueba
Muchas líneas de salida se desplazan rápidamente en la ventana de la terminal. En un minuto más o menos, volverá al símbolo del sistema.
Implementación de la aplicación Box
La aplicación ha sido construida y tenemos un binario ejecutable. Ahora debemos copiar el binario al directorio / usr / bin /. Esto permite que el shell lo encuentre cuando intentamos usarlo.
Para algunas aplicaciones, esto puede ser todo lo que tiene que hacer. En otros casos, es posible que deba copiar archivos adicionales, como páginas de manual y archivos de configuración, en ubicaciones del sistema de archivos. Esto último es lo que tenemos que hacer con nuestra nueva aplicación porque estaba en las instrucciones de construcción.
Úselo sudo
para ejecutar estos comandos. El primer comando copia una página de manual en el directorio man1:
sudo cp doc / boxes.1 / usr / share / man / man1
A continuación, copie el archivo de configuración global a un directorio en / usr / share /:
sudo cp boxes-config / usr / share / boxes
Finalmente, copie el binario en / usr / bin:
sudo cp src / boxes / usr / bin
Prueba de la aplicación de cajas
¡Veamos si funciona todo! Intente abrir la página de manual del boxes
comando.
cajas de hombre
¡Eso es alentador! Verá una página de manual que le indicará cómo utilizar el boxes
comando.
Presione "Q" para salir del sistema man e intente usar el boxes
comando.
echo How-To Geek | cajas
Y obtenemos la respuesta:
Esto puede parecer un poco decepcionante considerando todo el esfuerzo que ha realizado, pero el objetivo de este ejercicio fue guiarlo a través de la extracción de un repositorio de GitHub y la construcción de la aplicación.
El boxes
comando le permite ajustar el texto que se le envía en una amplia variedad de marcos. Algunos de ellos podrían usarse como comentarios en archivos de código fuente. El formato anterior funcionaría como comentario en un archivo de código fuente C, por ejemplo. Otros son puramente decorativos. La -d
opción (diseño) le permite elegir el estilo del marco.
echo How-To Geek | cajas -d whirly
echo How-To Geek | cajas -d c-cmt2
Hay una larga lista de diseños entre los que puede elegir. Para verlos todos, use este comando:
cajas -l | menos
Construcción completa
Los pasos para compilar desde el código fuente suelen ser sencillos:
- Revise las instrucciones de compilación en el repositorio.
- Compruebe que tiene instaladas las herramientas necesarias e instale las que falten.
- Clona el repositorio en tu computadora.
- Siga las instrucciones de compilación, que a menudo son tan simples como escribir
make
. - Copie los archivos en las ubicaciones requeridas.
Si hay pasos en las instrucciones de compilación que no están claros, vea si el proyecto tiene un foro o una comunidad a la que pueda enviar una pregunta. Si la aplicación tiene un sitio web, es posible que tengan una página de "Contáctenos". El desarrollador que mantiene el proyecto de boxes tiene su correo electrónico en la página "Acerca de" del sitio web de boxes. Ese es un gesto generoso de su parte y típico de la comunidad de código abierto en general.
0 Comentarios