Un vistazo a Cargo: el gestor de paquetes de Rust

Publicado por parzibyte en

Rust, Cargo y generador de valores aleatorios

Ya vimos cómo instalar Rust en Windows. Ahora veremos su entorno de paquetes, algo así como el NPM de JS o el Composer de PHP. En Rust, el gestor de paquetes (aunque también funciona como la CLI de Rust) se llama Cargo.

Cargo es un ayudante que gestiona e instala las dependencias, genera proyectos y todas esas cosas bonitas. Los paquetes son llamados crates, no me pregunten por qué.

Rust, Cargo y generador de valores aleatorios

Rust, Cargo y generador de valores aleatorios

Pero bueno, veamos una introducción a Cargo.

Recuerda haber instalado Rust en tu entorno, y probar que todo vaya en orden.

¿Qué es Cargo?

Cargo es el gestor de paquetes, pero además, nos permite generar una aplicación de Rust con un simple comando. Para ello, ejecuta:

cargo hola

En donde hola es una carpeta en donde vivirá tu proyecto. Cuando sea creada, navega a ella. Ahí ejecuta:

cargo run

Y automáticamente se compilará y ejecutará tu proyecto; eso si no tiene errores. Todo eso está resumido en esta imagen:

Generar nueva app de Rust con Cargo

Generar nueva app de Rust con Cargo

Pero espera, que eso no es todo. Con esto ya puedes desarrollar proyectos complejos en Rust, y sobre todo, instalar paquetes creados por cualquier persona.

Además, podrías publicar tus propias librerías.

Estructura de la aplicación

Ahora analicemos un poco lo que crea Cargo:

Estructura de un proyecto generado con Cargo

Estructura de un proyecto generado con Cargo

Las otras carpetas igualmente son importantes, pero las cosas más interesantes son…

  1. src: la carpeta en donde vive nuestro código fuente.
  2. Cargo.toml: un archivo en donde ponemos la descripción del proyecto, agregamos dependencias y esas cosas para que Cargo pueda instalar y gestionar de manera adecuada

Agregar dependencias

Muchos paquetes o librerías de Rust se instalan a través de cargo, primero añadiéndolas al archivo de dependencias y luego ejecutando el comando:

cargo build

Para agregar dependencias, añadimos una línea bajo el apartado [dependencies] de Cargo.toml con el siguiente formato:

dependencia = "x.x"

En donde dependencia es el nombre de la misma, y x.x la versión.

Ejemplo de instalación de paquete

Por ejemplo, para probar podemos agregar el paquete rand así:

rand = "0.6.1"

Luego ejecutamos cargo build para que descargue las dependencias, y listo. Veamos este ejemplo de programa:

En nuestro código, usamos a use rand::Rng para indicar que vamos a usar ese paquete. Después llamamos a una de sus funciones: generar un valor aleatorio en un rango.

El punto no es el programa, sino el paquete, pues alguien más lo programó, lo publicó y ahora nosotros, gracias a ello, podemos usarlo para generar valores aleatorios.

Conclusiones y siguientes pasos

Fue un ejemplo sencillo, pero quedó demostrado que es fácil instalar más paquetes. Todos los paquetes se encuentran en crates.io. Igualmente, cada que encuentres una librería para el lenguaje, te indicarán cómo instalarla.


parzibyte

He trabajado por más de 4 años en el desarrollo de software con experiencia en Java, PHP, JavaScript, HTML, Node.JS, Python, Android y Go. También he trabajado con bases de datos SQL como MySQL y SQLite, así como con bases de datos NoSQL usando MongoDB.Soy bueno utilizando algunos frameworks y herramientas como Firebase, jQuery, AngularJS, VueJS, CodeIgniter, Laravel, BulmaCSS, Bootstrap y Electron.Otros términos que conozco son: Arduino, GraphQL, API's, REST, AJAX, PouchDB, CouchDB, Experiencia de usuario, buenas prácticas de programación, Webpack, NPM, Administración de servidores y programación de scriptsLa plataforma en la que tengo más experiencia es la web, pero en mis ratos libres realizo unos pequeños ejercicios en C# y C.Estoy aquí para ayudarte a resolver tus problemas de programación y depuración :-)

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

This site uses Akismet to reduce spam. Learn how your comment data is processed.

A %d blogueros les gusta esto: