Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Docs refresh #2688

Merged
merged 34 commits into from
May 18, 2016
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
34 commits
Select commit Hold shift + click to select a range
28c1f63
Remove extranneous commas
carols10cents May 13, 2016
2c1147f
Correct `Fresh` to `Compiling` since we aren't running with -v
carols10cents May 13, 2016
c792163
Remove out of place instructions on passing args and flags
carols10cents May 13, 2016
c99ef3e
Mention that binary location changes when using --release
carols10cents May 13, 2016
d36b183
Clarify that the "somewhere" is github
carols10cents May 13, 2016
a05a80b
Correct reference to `foo` to `hello_world`
carols10cents May 13, 2016
d571d4b
Small rewording changes; mostly to clear up potential ambiguity
carols10cents May 13, 2016
c4d4529
Move the Travis CI section under the testing section
carols10cents May 13, 2016
1364b62
Incorporate "using crates from crates.io" into the main guide
carols10cents May 13, 2016
1c555a8
Consolidate all info about specifying deps into one page.
carols10cents May 13, 2016
e3a9bc6
Make the crates.io docs about publishing only, not using
carols10cents May 13, 2016
9e0da6f
Add instructions for rendering docs locally to the README
carols10cents May 13, 2016
81e1cc4
Fix markdown links that repeat their link text unnecessarily
carols10cents May 13, 2016
0f2cade
Link crates.io everywhere
carols10cents May 13, 2016
742d08b
Clarify that release builds go in the release dir, not another subdir
carols10cents May 13, 2016
7e04235
Replace refs to color-rs crate to rust-lang's rand crate
carols10cents May 13, 2016
67424e3
Add all three channels to the sample .travis.yml
carols10cents May 13, 2016
2067918
Use code formatting for `git`
carols10cents May 13, 2016
752b225
Use — instead of --
carols10cents May 13, 2016
2757020
Reword to not call a non-rust-tuple thing a tuple
carols10cents May 13, 2016
27548b0
Combine related thoughts into the same paragraph
carols10cents May 13, 2016
3f1d9a2
Replace references to conduit(-static) with uuid/rand
carols10cents May 14, 2016
921a210
Remove section about converting a project to cargo
carols10cents May 14, 2016
c888492
Reword note about git init default to be in the positive
carols10cents May 14, 2016
2a7017f
Clarify that integration tests go in tests/
carols10cents May 15, 2016
95d253c
Add an ascii directory tree to the project layout section
carols10cents May 15, 2016
6cce75e
Clarify that you should not manually edit Cargo.lock
carols10cents May 15, 2016
19f3b1e
Small rewordings
carols10cents May 15, 2016
4deac48
Clarify statements about ignoring/checking in Cargo.lock
carols10cents May 15, 2016
1ae5e39
Correct typo when referring to 64 bit
carols10cents May 17, 2016
af09c15
Add a `[dev-dependencies]` example
carols10cents May 17, 2016
40fd278
Add info about `build-dependencies` to the specifying deps page
carols10cents May 17, 2016
9b4174d
Add info about what's different between debug/release
carols10cents May 17, 2016
58a1804
At the end, point to docs that might be interesting next
carols10cents May 17, 2016
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion Makefile.in
Original file line number Diff line number Diff line change
Expand Up @@ -136,7 +136,7 @@ clean:
# === Documentation

DOCS := index faq config guide manifest build-script pkgid-spec crates-io \
environment-variables
environment-variables specifying-dependencies
DOC_DIR := target/doc
DOC_OPTS := --markdown-no-toc \
--markdown-css stylesheets/normalize.css \
Expand Down
9 changes: 8 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,14 @@ 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.
the `src/doc` directory. To view the rendered version of changes you have
made locally, run:

```sh
./configure
make doc
open target/doc/index.html
```

## Release notes

Expand Down
166 changes: 35 additions & 131 deletions src/doc/crates-io.md
Original file line number Diff line number Diff line change
@@ -1,118 +1,17 @@
% Cargo and crates.io
% Publishing on crates.io

In addition to using dependencies from git repositories (as mentioned in
[the guide](guide.html)) Cargo can also publish to and download from the
[crates.io][crates-io] central repository. This site serves as a location to
discover and download packages, and `cargo` is configured to use it by default
to find requested packages.

The guide will explain how crates can use crates.io through the `cargo` command
line tool.

[crates-io]: https://crates.io/

# Using crates.io-based crates

The method of specifying a dependency on a crate from crates.io is slightly
different than the method of specifying a dependency on a git repository. The
syntax for doing so is:

```toml
[dependencies]
glob = "0.0.3"
```

With this format, adding new dependencies should just add a new line, you don’t
need to add `[dependencies]` for each dependency listed, for example:

```toml
[dependencies]
glob = "0.0.3"
num = "0.0.4"
```

The string value for each key in this table is a [semver][semver] version
requirement.

[semver]: https://github.com/steveklabnik/semver#requirements

**Caret requirements** allow SemVer compatible updates to a specified version.

`^1.2.3` is an example of a caret requirement.

When considering “compatible” versions, `0.1` and `0.2` are not considered
compatible, but `1.0` and `1.1` are for example. If no operator is specified,
this is the default requirement (e.g. `1.3` is the same as `^1.3`).

`0.0.x` is not considered compatible with any other version. Missing minor and
patch versions are desugared to `0` but allow flexibility for that value.

```notrust
^1.2.3 := >=1.2.3 <2.0.0
^0.2.3 := >=0.2.3 <0.3.0
^0.0.3 := >=0.0.3 <0.0.4
^0.0 := >=0.0.0 <0.1.0
^0 := >=0.0.0 <1.0.0
```

**Tilde requirements** specify a minimal version with some ability to update.

`~1.2.3` is an example of a tilde requirement.

```notrust
~1.2.3 := >=1.2.3 <1.3.0
~1.2 := >=1.2.0 <1.3.0
~1 := >=1.0.0 <2.0.0
```

**Wildcard requirements** allow for any version where the wildcard is positioned.

`*`, `1.*` and `1.2.*` are examples of wildcard requirements.

```notrust
* := >=0.0.0
1.* := >=1.0.0 <2.0.0
1.2.* := >=1.2.0 <1.3.0
```

**Inequality requirements** allow manually specifying a version range or an
exact version to depend on.

Here are some examples of inequality requirements:

```notrust
>= 1.2.0
> 1
< 2
= 1.2.3
```

Multiple version requirements can also be separated with a comma, e.g. `>= 1.2,
< 1.5`.

# Pre-1.0 versions

While SemVer says that there is no compatibility before 1.0.0, many programmers
treat a `0.x.y` release in the same way as a `1.x.y` release: that is, `y` is
incremented for bugfixes, and `x` is incremented for new features.

As such, Cargo considers a `0.x.y` and `0.x.z` version, where `z > y`, to be
compatible.

# Publishing crates

Ok, now that we’ve got a crate which is using dependencies from crates.io,
let’s publish it! Publishing a crate is when a specific version is uploaded to
crates.io.
Once you've got a library that you'd like to share with the world, it's time to
publish it on [crates.io]! Publishing a crate is when a specific
version is uploaded to be hosted on [crates.io].

Take care when publishing a crate, because a publish is **permanent**. The
version can never be overwritten, and the code cannot be deleted. There is no
limit to the number of versions which can be published, however.

## Acquiring an API token
# Before your first publish

First thing’s first, you’ll need an account on [crates.io][crates-io] to acquire
an API token. To do so, [visit the home page][crates-io] and log in via a GitHub
First thing’s first, you’ll need an account on [crates.io] to acquire
an API token. To do so, [visit the home page][crates.io] and log in via a GitHub
account (required for now). After this, visit your [Account
Settings](https://crates.io/me) page and run the `cargo login` command
specified.
Expand All @@ -126,10 +25,15 @@ This command will inform Cargo of your API token and store it locally in your
with anyone else. If it leaks for any reason, you should regenerate it
immediately.

# Before publishing a new crate

Keep in mind that crate names on [crates.io] are allocated on a first-come-first-
serve basis. Once a crate name is taken, it cannot be used for another crate.

## Packaging a crate

The next step is to package up your crate into a format that can be uploaded to
crates.io. For this we’ll use the `cargo package` subcommand. This will take
[crates.io]. For this we’ll use the `cargo package` subcommand. This will take
our entire crate and package it all up into a `*.crate` file in the
`target/package` directory.

Expand All @@ -144,10 +48,10 @@ are there for the build to succeed. This behavior can be disabled with the
`--no-verify` flag.

Now’s a good time to take a look at the `*.crate` file to make sure you didn’t
accidentally package up that 2GB video asset. Cargo will automatically ignore
files ignored by your version control system when packaging, but if you want to
specify an extra set of files to ignore you can use the `exclude` key in the
manifest:
accidentally package up that 2GB video asset. There is currently a 10MB upload
size limit on `*.crate` files. Cargo will automatically ignore files ignored by
your version control system when packaging, but if you want to specify an extra
set of files to ignore you can use the `exclude` key in the manifest:

```toml
[package]
Expand Down Expand Up @@ -175,7 +79,7 @@ include = [
## Uploading the crate

Now that we’ve got a `*.crate` file ready to go, it can be uploaded to
crates.io with the `cargo publish` command. And that’s it, you’ve now published
[crates.io] with the `cargo publish` command. And that’s it, you’ve now published
your first crate!

```notrust
Expand All @@ -189,20 +93,18 @@ Be sure to check out the [metadata you can
specify](manifest.html#package-metadata) to ensure your crate can be discovered
more easily!

## Restrictions
# Publishing a new version of an existing crate

There are a few restrictions when publishing a crate in the registry:

* Once a version is uploaded, it can never be overwritten. To upload a new copy
of a crate you must upload a new version.
* Crate names are allocated on a first-come-first-serve basis. Once a crate name
is taken it cannot be used for another crate.
* There is currently a 10MB upload size limit on `*.crate` files.
In order to release a new version, change the `version` value specified in your
`Cargo.toml` manifest. Keep in mind [the semver
rules](manifest.html#the-version-field). Then optionally run `cargo package` if
you want to inspect the `*.crate` file for the new version before publishing,
and run `cargo publish` to upload the new version.

# Managing a crates.io-based crate

Management of crates is primarily done through the command line `cargo` tool
rather than the crates.io web interface. For this, there are a few subcommands
rather than the [crates.io] web interface. For this, there are a few subcommands
to manage a crate.

## `cargo yank`
Expand All @@ -223,7 +125,7 @@ those secrets immediately.

The semantics of a yanked version are that no new dependencies can be created
against that version, but all existing dependencies continue to work. One of the
major goals of crates.io is to act as a permanent archive of crates that does
major goals of [crates.io] is to act as a permanent archive of crates that does
not change over time, and allowing deletion of a version would go against this
goal. Essentially a yank means that all projects with a `Cargo.lock` will not
break, while any future `Cargo.lock` files generated will not list the yanked
Expand All @@ -249,7 +151,7 @@ full rights to the crate. In addition to being able to publish or yank versions
of the crate, they have the ability to add or remove owners, *including* the
owner that made *them* an owner. Needless to say, you shouldn’t make people you
don’t fully trust into a named owner. In order to become a named owner, a user
must have logged into crates.io previously.
must have logged into [crates.io] previously.

If a team name is given to `--add`, that team becomes a “team” owner, with
restricted right to the crate. While they have permission to publish or yank
Expand All @@ -267,7 +169,7 @@ Team membership is not something GitHub provides simple public access to, and it
is likely for you to encounter the following message when working with them:

> It looks like you don’t have permission to query a necessary property from
GitHub to complete this request. You may need to re-authenticate on crates.io
GitHub to complete this request. You may need to re-authenticate on [crates.io]
to grant permission to read GitHub org memberships. Just go to
https://crates.io/login

Expand All @@ -288,9 +190,9 @@ as an owner, or publish a crate as a team owner. If you ever attempt to do this,
you will get the error above. You may also see this error if you ever try to
publish a crate that you don’t own at all, but otherwise happens to have a team.

If you ever change your mind, or just aren’t sure if crates.io has sufficient
If you ever change your mind, or just aren’t sure if [crates.io] has sufficient
permission, you can always go to https://crates.io/login, which will prompt you
for permission if crates.io doesn’t have all the scopes it would like to.
for permission if [crates.io] doesn’t have all the scopes it would like to.

An additional barrier to querying GitHub is that the organization may be
actively denying third party access. To check this, you can go to:
Expand All @@ -302,12 +204,14 @@ something like:

![Organization Access Control](images/org-level-acl.png)

Where you may choose to explicitly remove crates.io from your organization’s
Where you may choose to explicitly remove [crates.io] from your organization’s
blacklist, or simply press the “Remove Restrictions” button to allow all third
party applications to access this data.

Alternatively, when crates.io requested the `read:org` scope, you could have
explicitly whitelisted crates.io querying the org in question by pressing
Alternatively, when [crates.io] requested the `read:org` scope, you could have
explicitly whitelisted [crates.io] querying the org in question by pressing
the “Grant Access” button next to its name:

![Authentication Access Control](images/auth-level-acl.png)

[crates.io]: https://crates.io/
8 changes: 5 additions & 3 deletions src/doc/faq.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

# Is the plan to use GitHub as a package repository?

No. The plan for Cargo is to use crates.io, like npm or Rubygems do with
No. The plan for Cargo is to use [crates.io], like npm or Rubygems do with
npmjs.org and rubygems.org.

We plan to support git repositories as a source of packages forever,
Expand All @@ -15,7 +15,7 @@ We think that it’s very important to support multiple ways to download
packages, including downloading from GitHub and copying packages into
your project itself.

That said, we think that crates.io offers a number of important benefits, and
That said, we think that [crates.io] offers a number of important benefits, and
will likely become the primary way that people download packages in Cargo.

For precedent, both Node.js’s [npm][1] and Ruby’s [bundler][2] support both a
Expand Down Expand Up @@ -130,7 +130,7 @@ picture to decide what versions of dependencies should be used.

# Can libraries use `*` as a version for their dependencies?

**Starting January 22nd, 2016, crates.io will begin rejecting packages with
**Starting January 22nd, 2016, [crates.io] will begin rejecting packages with
wildcard dependency constraints.**

While they _can_, strictly speaking, they should not. A version requirement
Expand All @@ -153,3 +153,5 @@ Cargo does not allow other names such as `cargo.toml` or `Cargofile` to
emphasize the ease of how a Cargo repository can be identified. An option of
many possible names has historically led to confusion where one case was handled
but others were accidentally forgotten.

[crates.io]: https://crates.io/
Loading