-
Notifications
You must be signed in to change notification settings - Fork 13.2k
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
Rustpkg docs and tests #5948
Rustpkg docs and tests #5948
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,101 @@ | ||
% Rustpkg Reference Manual | ||
|
||
# Introduction | ||
|
||
This document is the reference manual for the Rustpkg packaging and build tool for the Rust programming language. | ||
|
||
## Disclaimer | ||
|
||
Rustpkg is a work in progress, as is this reference manual. | ||
If the actual behavior of rustpkg differs from the behavior described in this reference, | ||
that reflects either an incompleteness or a bug in rustpkg. | ||
|
||
# Package searching | ||
|
||
rustpkg searches for packages using the `RUST_PATH` environment variable, | ||
which is a colon-separated list (semicolon-separated on Windows) of directories. | ||
|
||
Each directory in this list is a *package source* for rustpkg. | ||
|
||
`RUST_PATH` implicitly contains an entry for `./.rust` (as well as | ||
`../.rust`, `../../.rust`, | ||
and so on for every parent of `.` up to the filesystem root). | ||
That means that if `RUST_PATH` is not set, | ||
then rustpkg will still search for package sources in `./.rust` and so on | ||
|
||
Each package source may contain one or more packages. | ||
|
||
# Package structure | ||
|
||
A valid package source must contain each of the following subdirectories: | ||
|
||
* 'src/': contains one subdirectory per package containing package source files. | ||
|
||
For example, if `foo` is a package source containing the package `bar`, | ||
then `foo/src/bar/main.rs` could be the `main` entry point for | ||
building a `bar` executable. | ||
* 'lib/': `rustpkg install` installs libraries into a target-specific subdirectory of this directory. | ||
|
||
For example, on a 64-bit machine running Mac OS X, | ||
if `foo` is a package source containing the package `bar`, | ||
rustpkg will install libraries for bar to `foo/lib/x86_64-apple-darwin/`. | ||
The libraries will have names of the form `foo/lib/x86_64-apple-darwin/libbar-[hash].dylib`, | ||
where [hash] is a hash for the dependencies of this build. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. hash is the hash of the link attributes for the crate; so probably just the hash of the pkgid |
||
* 'bin/': `rustpkg install` installs executable binaries into a target-specific subdirectory of this directory. | ||
|
||
For example, on a 64-bit machine running Mac OS X, | ||
if `foo` is a package source, containing the package `bar`, | ||
rustpkg will install executables for `bar` to | ||
`foo/bin/x86_64-apple-darwin/`. | ||
The executables will have names of the form `foo/bin/x86_64-apple-darwin/bar`. | ||
* 'build/': `rustpkg build` stores temporary build artifacts in a target-specific subdirectory of this directory. | ||
|
||
For example, on a 64-bit machine running Mac OS X, | ||
if `foo` is a package source containing the package `bar` and `foo/src/bar/main.rs` exists, | ||
then `rustpkg build` will create `foo/build/x86_64-apple-darwin/bar/main.o`. | ||
|
||
# Package identifiers | ||
|
||
A package identifier identifies a package uniquely. | ||
A package can be stored in a package source on the local file system, | ||
or on a remote Web server, in which case the package ID resembles a URL. | ||
For example, `github.com/mozilla/rust` is a package ID | ||
that would refer to the package source in | ||
the git repository browsable at `http://github.com/mozilla.rust`. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. mozilla/rust not mozilla.rust |
||
|
||
## Source files | ||
|
||
rustpkg searches for four different fixed filenames in order to determine the crate to build: | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. s/crate to build/crates to build/ |
||
|
||
* `main.rs`: Assumed to be a main entry point for building an executable. | ||
* `lib.rs`: Assumed to be a library crate. | ||
* `test.rs`: Assumed to contain tests declared with the `#[test]` attribute. | ||
* `bench.rs`: Assumed to contain benchmarks declared with the `#[bench]` attribute. | ||
|
||
# Custom build scripts | ||
|
||
A file called `pkg.rs` at the root level in a package source is called a *package script*. | ||
If a package script exists, rustpkg executes it to build the package | ||
rather than inferring crates as described previously. | ||
|
||
# Command reference | ||
|
||
## build | ||
|
||
`rustpkg build foo` builds the files in package source `foo`'s `src` subdirectory. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. this statement is confusing the name of a package source / workspace and a pkgid. I believe |
||
It leaves behind files in `foo`'s `build` directory, but not in its `lib` or `bin` directory. | ||
|
||
## clean | ||
|
||
`rustpkg clean foo` deletes the contents of `foo`'s `build` directory. | ||
|
||
## install | ||
|
||
`rustpkg install foo` builds the libraries and/or executables that are targets for `foo`, | ||
and then installs them either into `foo`'s `lib` and `bin` directories, | ||
or into the `lib` and `bin` subdirectories of the first entry in `RUST_PATH`. | ||
|
||
## test | ||
|
||
`rustpkg test foo` builds `foo`'s `test.rs` file if necessary, | ||
then runs the resulting test executable. |
This file was deleted.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'd use "workspace" rather than "package source" here; too confusable with the src/ subdir and/or the place you downloaded the package from.