2015-01-08 10:27:03 -08:00
|
|
|
% Hello, Cargo!
|
2014-12-02 09:20:48 -05:00
|
|
|
|
|
|
|
[Cargo](http://crates.io) is a tool that Rustaceans use to help manage their
|
|
|
|
Rust projects. Cargo is currently in an alpha state, just like Rust, and so it
|
|
|
|
is still a work in progress. However, it is already good enough to use for many
|
|
|
|
Rust projects, and so it is assumed that Rust projects will use Cargo from the
|
|
|
|
beginning.
|
|
|
|
|
|
|
|
Cargo manages three things: building your code, downloading the dependencies
|
2015-01-09 17:21:30 -05:00
|
|
|
your code needs, and building those dependencies. At first, your
|
2014-12-02 09:20:48 -05:00
|
|
|
program doesn't have any dependencies, so we'll only be using the first part of
|
|
|
|
its functionality. Eventually, we'll add more. Since we started off by using
|
|
|
|
Cargo, it'll be easy to add later.
|
|
|
|
|
|
|
|
If you installed Rust via the official installers you will also have
|
|
|
|
Cargo. If you installed Rust some other way, you may want to [check
|
|
|
|
the Cargo
|
|
|
|
README](https://github.com/rust-lang/cargo#installing-cargo-from-nightlies)
|
|
|
|
for specific instructions about installing it.
|
|
|
|
|
2015-02-23 16:06:49 -05:00
|
|
|
## Converting to Cargo
|
|
|
|
|
2014-12-02 09:20:48 -05:00
|
|
|
Let's convert Hello World to Cargo.
|
|
|
|
|
|
|
|
To Cargo-ify our project, we need to do two things: Make a `Cargo.toml`
|
|
|
|
configuration file, and put our source file in the right place. Let's
|
|
|
|
do that part first:
|
|
|
|
|
2015-02-23 16:35:47 -05:00
|
|
|
```bash
|
2014-12-02 09:20:48 -05:00
|
|
|
$ mkdir src
|
|
|
|
$ mv main.rs src/main.rs
|
|
|
|
```
|
|
|
|
|
|
|
|
Cargo expects your source files to live inside a `src` directory. That leaves
|
|
|
|
the top level for other things, like READMEs, license information, and anything
|
|
|
|
not related to your code. Cargo helps us keep our projects nice and tidy. A
|
|
|
|
place for everything, and everything in its place.
|
|
|
|
|
|
|
|
Next, our configuration file:
|
|
|
|
|
2015-02-23 16:35:47 -05:00
|
|
|
```bash
|
2014-12-02 09:20:48 -05:00
|
|
|
$ editor Cargo.toml
|
|
|
|
```
|
|
|
|
|
|
|
|
Make sure to get this name right: you need the capital `C`!
|
|
|
|
|
|
|
|
Put this inside:
|
|
|
|
|
|
|
|
```toml
|
|
|
|
[package]
|
|
|
|
|
|
|
|
name = "hello_world"
|
|
|
|
version = "0.0.1"
|
|
|
|
authors = [ "Your name <you@example.com>" ]
|
|
|
|
|
|
|
|
[[bin]]
|
|
|
|
|
|
|
|
name = "hello_world"
|
|
|
|
```
|
|
|
|
|
|
|
|
This file is in the [TOML](https://github.com/toml-lang/toml) format. Let's let
|
|
|
|
it explain itself to you:
|
|
|
|
|
|
|
|
> TOML aims to be a minimal configuration file format that's easy to read due
|
|
|
|
> to obvious semantics. TOML is designed to map unambiguously to a hash table.
|
|
|
|
> TOML should be easy to parse into data structures in a wide variety of
|
|
|
|
> languages.
|
|
|
|
|
|
|
|
TOML is very similar to INI, but with some extra goodies.
|
|
|
|
|
2015-01-08 16:52:50 -08:00
|
|
|
Anyway, there are two *tables* in this file: `package` and `bin`. The first
|
2014-12-02 09:20:48 -05:00
|
|
|
tells Cargo metadata about your package. The second tells Cargo that we're
|
|
|
|
interested in building a binary, not a library (though we could do both!), as
|
|
|
|
well as what it is named.
|
|
|
|
|
|
|
|
Once you have this file in place, we should be ready to build! Try this:
|
|
|
|
|
2015-02-23 16:35:47 -05:00
|
|
|
```bash
|
2014-12-02 09:20:48 -05:00
|
|
|
$ cargo build
|
|
|
|
Compiling hello_world v0.0.1 (file:///home/yourname/projects/hello_world)
|
2015-03-11 16:48:32 -07:00
|
|
|
$ ./target/debug/hello_world
|
2014-12-02 09:20:48 -05:00
|
|
|
Hello, world!
|
|
|
|
```
|
|
|
|
|
|
|
|
Bam! We build our project with `cargo build`, and run it with
|
2015-03-11 16:48:32 -07:00
|
|
|
`./target/debug/hello_world`. This hasn't bought us a whole lot over our simple use
|
2014-12-02 09:20:48 -05:00
|
|
|
of `rustc`, but think about the future: when our project has more than one
|
2015-03-12 17:00:35 -04:00
|
|
|
file, we would need to call `rustc` more than once and pass it a bunch of options to
|
2014-12-02 09:20:48 -05:00
|
|
|
tell it to build everything together. With Cargo, as our project grows, we can
|
2015-03-12 17:00:35 -04:00
|
|
|
just `cargo build`, and it'll work the right way. When your project is finally
|
|
|
|
ready for release, you can use `cargo build --release` to compile your crates with
|
|
|
|
optimizations.
|
2014-12-02 09:20:48 -05:00
|
|
|
|
|
|
|
You'll also notice that Cargo has created a new file: `Cargo.lock`.
|
|
|
|
|
|
|
|
```toml
|
|
|
|
[root]
|
|
|
|
name = "hello_world"
|
|
|
|
version = "0.0.1"
|
|
|
|
```
|
|
|
|
|
|
|
|
This file is used by Cargo to keep track of dependencies in your application.
|
|
|
|
Right now, we don't have any, so it's a bit sparse. You won't ever need
|
|
|
|
to touch this file yourself, just let Cargo handle it.
|
|
|
|
|
|
|
|
That's it! We've successfully built `hello_world` with Cargo. Even though our
|
|
|
|
program is simple, it's using much of the real tooling that you'll use for the
|
|
|
|
rest of your Rust career.
|
|
|
|
|
2015-02-23 16:06:49 -05:00
|
|
|
## A New Project
|
|
|
|
|
|
|
|
You don't have to go through this whole process every time you want to start a new
|
|
|
|
project! Cargo has the ability to make a bare-bones project directory in which you
|
|
|
|
can start developing right away.
|
|
|
|
|
|
|
|
To start a new project with Cargo, use `cargo new`:
|
|
|
|
|
2015-02-23 16:35:47 -05:00
|
|
|
```bash
|
2015-02-23 16:06:49 -05:00
|
|
|
$ cargo new hello_world --bin
|
|
|
|
```
|
|
|
|
|
|
|
|
We're passing `--bin` because we're making a binary program: if we
|
|
|
|
were making a library, we'd leave it off.
|
|
|
|
|
|
|
|
Let's check out what Cargo has generated for us:
|
|
|
|
|
2015-02-23 16:35:47 -05:00
|
|
|
```bash
|
2015-02-23 16:06:49 -05:00
|
|
|
$ cd hello_world
|
|
|
|
$ tree .
|
|
|
|
.
|
|
|
|
├── Cargo.toml
|
|
|
|
└── src
|
|
|
|
└── main.rs
|
|
|
|
|
|
|
|
1 directory, 2 files
|
|
|
|
```
|
|
|
|
|
|
|
|
If you don't have the `tree` command, you can probably get it from your distro's package
|
|
|
|
manager. It's not necessary, but it's certainly useful.
|
|
|
|
|
|
|
|
This is all we need to get started. First, let's check out `Cargo.toml`:
|
|
|
|
|
2015-02-23 16:35:47 -05:00
|
|
|
```toml
|
2015-02-23 16:06:49 -05:00
|
|
|
[package]
|
|
|
|
|
|
|
|
name = "hello_world"
|
|
|
|
version = "0.0.1"
|
|
|
|
authors = ["Your Name <you@example.com>"]
|
|
|
|
```
|
|
|
|
|
2015-02-23 16:35:47 -05:00
|
|
|
Cargo has populated this file with reasonable defaults based off the arguments you gave
|
|
|
|
it and your `git` global configuration. You may notice that Cargo has also initialized
|
|
|
|
the `hello_world` directory as a `git` repository.
|
2015-02-23 16:06:49 -05:00
|
|
|
|
|
|
|
Here's what's in `src/main.rs`:
|
|
|
|
|
2015-02-23 16:35:47 -05:00
|
|
|
```rust
|
2015-02-23 16:06:49 -05:00
|
|
|
fn main() {
|
|
|
|
println!("Hello, world!");
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Cargo has generated a "Hello World!" for us, and you're ready to start coding! A
|
|
|
|
much more in-depth guide to Cargo can be found [here](http://doc.crates.io/guide.html).
|
|
|
|
|
2014-12-02 09:20:48 -05:00
|
|
|
Now that you've got the tools down, let's actually learn more about the Rust
|
|
|
|
language itself. These are the basics that will serve you well through the rest
|
2015-03-11 16:48:32 -07:00
|
|
|
of your time with Rust.
|