Giter VIP home page Giter VIP logo

cargo's Introduction

Cargo downloads your Rust project’s dependencies and compiles your project.

Learn more at http://doc.crates.io/

Code Status

Build Status Build Status

Installing Cargo

Cargo is distributed by default with Rust, so if you've got rustc installed locally you probably also have cargo installed locally.

Compiling from Source

Cargo requires the following tools and packages to build:

  • python
  • curl (on Unix)
  • cmake
  • OpenSSL headers (only for Unix, this is the 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

Running the tests

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.

Adding new subcommands to Cargo

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.

Contributing to the Docs

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

Releases

High level release notes are available as part of Rust's release notes. Cargo releases coincide with Rust releases.

Table of Rust versions with their Cargo versions
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

Reporting Issues

Found a bug? We'd love to know about it!

Please report all issues on the github issue tracker.

License

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.

Third party software

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.

cargo's People

Contributors

alexcrichton avatar alx741 avatar bkoropoff avatar bors avatar brson avatar carllerche avatar carols10cents avatar ericson2314 avatar frewsxcv avatar gentoo90 avatar geomaster avatar gkoz avatar huonw avatar ivanukhov avatar jbendig avatar jhbabon avatar jyasskin avatar kalitaalexey avatar matklad avatar mbrubeck avatar munyari avatar nipunn1313 avatar nrc avatar sbeckeriv avatar sfackler avatar steveklabnik avatar tilde-engineering avatar tomaka avatar tshepang avatar wycats avatar

Watchers

 avatar  avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.