commit | f9e54817e53c7b9845cc7c1ede4c11e4d3e42e36 | [log] [tgz] |
---|---|---|
author | bors <bors@rust-lang.org> | Fri Mar 03 19:21:26 2017 +0000 |
committer | bors <bors@rust-lang.org> | Fri Mar 03 19:21:26 2017 +0000 |
tree | a2fd03b9c59d0cbacc2bbe247d345a7666f0c1ea | |
parent | 0bb804711f87c82aa03af7848dbfc460528b074c [diff] | |
parent | f1c0d44ff0150591e7cedf37ef3d550c3872d408 [diff] |
Auto merge of #3781 - alexcrichton:beta-backport, r=alexcrichton [backport] Fix deps with `cargo test --all` and doctests This commit fixes `cargo test --all` with the way we ship libraries to `rustdoc --test`. I'm... not entirely sure what the previous incarnation was doing but the current organization is to interpret `compilation.libraries` as a mapping from a package to the list of crates it needs to link to test. This updates the support in `cargo_rustc/mod.rs` to create the map appropriately and tweaks the loop in `cargo_test.rs` as well. Closes rust-lang/rust#39879
Cargo downloads your Rust project’s dependencies and compiles your project.
Learn more at http://doc.crates.io/
Cargo is distributed by default with Rust, so if you've got rustc
installed locally you probably also have cargo
installed locally.
Cargo requires the following tools and packages to build:
python
curl
(on Unix)cmake
libssl-dev
package on ubuntu)cargo
and rustc
First, you'll want to check out this repository
git clone --recursive https://github.com/rust-lang/cargo cd cargo
With cargo
already installed, you can simply run:
cargo build --release
Otherwise, you can also use a more traditional approach:
./configure make make install
More options can be discovered through ./configure
, such as compiling cargo for more than one target. For example, if you'd like to compile both 32 and 64 bit versions of cargo on unix you would use:
$ ./configure --target=i686-unknown-linux-gnu,x86_64-unknown-linux-gnu
To run cargo's tests, use cargo test
. If you do not have the cross-compilers installed locally, ignore the cross-compile test failures, or disable them by using CFG_DISABLE_CROSS_TESTS=1 cargo test
.
Cargo is designed to be extensible with new subcommands without having to modify Cargo itself. See the Wiki page for more details and a list of known community-developed subcommands.
To contribute to the docs, all you need to do is change the markdown files in the src/doc
directory. To view the rendered version of changes you have made locally, run:
./configure make doc open target/doc/index.html
High level release notes are available as part of Rust's release notes. Cargo releases coincide with Rust releases.
Rust version | Cargo version |
---|---|
1.12.0 | 0.13.0 |
1.11.0 | 0.12.0 |
1.10.0 | 0.11.0 |
1.9.0 | 0.10.0 |
1.8.0 | 0.9.0 |
1.7.0 | 0.8.0 |
1.6.0 | 0.7.0 |
1.5.0 | 0.6.0 |
1.4.0 | 0.5.0 |
1.3.0 | 0.4.0 |
1.2.0 | 0.3.0 |
1.1.0 | 0.2.0 |
1.0.0 | 0.1.0 |
Found a bug? We'd love to know about it!
Please report all issues on the github issue tracker.
Cargo is primarily distributed under the terms of both the MIT license and the Apache License (Version 2.0).
See LICENSE-APACHE and LICENSE-MIT for details.
This product includes software developed by the OpenSSL Project for use in the OpenSSL Toolkit (http://www.openssl.org/).
In binary form, this product includes software that is licensed under the terms of the GNU General Public License, version 2, with a linking exception, which can be obtained from the upstream repository.