reference.md 136.4 KB
Newer Older
S
Steve Klabnik 已提交
1 2 3 4 5 6 7
% The Rust Reference

# Introduction

This document is the primary reference for the Rust programming language. It
provides three kinds of material:

8
  - Chapters that informally describe each language construct and their use.
S
Steve Klabnik 已提交
9 10 11 12 13 14
  - Chapters that informally describe the memory model, concurrency model,
    runtime services, linkage model and debugging facilities.
  - Appendix chapters providing rationale and references to languages that
    influenced the design.

This document does not serve as an introduction to the language. Background
S
Steve Klabnik 已提交
15
familiarity with the language is assumed. A separate [book] is available to
S
Steve Klabnik 已提交
16 17 18 19
help acquire such background familiarity.

This document also does not serve as a reference to the [standard] library
included in the language distribution. Those libraries are documented
20 21 22
separately by extracting documentation attributes from their source code. Many
of the features that one might expect to be language features are library
features in Rust, so what you're looking for may be there, not here.
S
Steve Klabnik 已提交
23

24 25
You may also be interested in the [grammar].

S
Steve Klabnik 已提交
26
[book]: book/index.html
S
Steve Klabnik 已提交
27
[standard]: std/index.html
28
[grammar]: grammar.html
S
Steve Klabnik 已提交
29 30 31 32 33

# Notation

## Unicode productions

S
Steve Klabnik 已提交
34 35 36 37 38 39 40
A few productions in Rust's grammar permit Unicode code points outside the
ASCII range. We define these productions in terms of character properties
specified in the Unicode standard, rather than in terms of ASCII-range code
points. The grammar has a [Special Unicode Productions][unicodeproductions]
section that lists these productions.

[unicodeproductions]: grammar.html#special-unicode-productions
S
Steve Klabnik 已提交
41 42 43 44 45

## String table productions

Some rules in the grammar — notably [unary
operators](#unary-operator-expressions), [binary
S
Steve Klabnik 已提交
46
operators](#binary-operator-expressions), and [keywords][keywords] — are
S
Steve Klabnik 已提交
47 48 49 50 51 52
given in a simplified form: as a listing of a table of unquoted, printable
whitespace-separated strings. These cases form a subset of the rules regarding
the [token](#tokens) rule, and are assumed to be the result of a
lexical-analysis phase feeding the parser, driven by a DFA, operating over the
disjunction of all such string table entries.

S
Steve Klabnik 已提交
53 54
[keywords]: grammar.html#keywords

S
Steve Klabnik 已提交
55 56 57 58 59 60 61 62
When such a string enclosed in double-quotes (`"`) occurs inside the grammar,
it is an implicit reference to a single member of such a string table
production. See [tokens](#tokens) for more information.

# Lexical structure

## Input format

M
Mike Boutin 已提交
63
Rust input is interpreted as a sequence of Unicode code points encoded in UTF-8.
S
Steve Klabnik 已提交
64
Most Rust grammar rules are defined in terms of printable ASCII-range
M
Mike Boutin 已提交
65 66
code points, but a small number are defined in terms of Unicode properties or
explicit code point lists. [^inputformat]
S
Steve Klabnik 已提交
67 68 69 70 71

[^inputformat]: Substitute definitions for the special Unicode productions are
  provided to the grammar verifier, restricted to ASCII range, when verifying the
  grammar in this document.

R
Robin Kruppe 已提交
72
## Identifiers
S
Steve Klabnik 已提交
73

R
Robin Kruppe 已提交
74
An identifier is any nonempty Unicode[^non_ascii_idents] string of the following form:
75 76 77

[^non_ascii_idents]: Non-ASCII characters in identifiers are currently feature
  gated. This is expected to improve soon.
S
Steve Klabnik 已提交
78 79 80 81

- The first character has property `XID_start`
- The remaining characters have property `XID_continue`

S
Steve Klabnik 已提交
82
that does _not_ occur in the set of [keywords][keywords].
S
Steve Klabnik 已提交
83 84 85 86 87 88 89

> **Note**: `XID_start` and `XID_continue` as character properties cover the
> character ranges used to form the more familiar C and Java language-family
> identifiers.

## Comments

90
Comments in Rust code follow the general C++ style of line (`//`) and
91
block (`/* ... */`) comment forms. Nested block comments are supported.
S
Steve Klabnik 已提交
92 93 94 95

Line comments beginning with exactly _three_ slashes (`///`), and block
comments beginning with exactly one repeated asterisk in the block-open
sequence (`/**`), are interpreted as a special syntax for `doc`
S
Steve Klabnik 已提交
96
[attributes](#attributes). That is, they are equivalent to writing
97 98
`#[doc="..."]` around the body of the comment, i.e., `/// Foo` turns into
`#[doc="Foo"]`.
S
Steve Klabnik 已提交
99

M
Matt Brubeck 已提交
100 101 102
Line comments beginning with `//!` and block comments beginning with `/*!` are
doc comments that apply to the parent of the comment, rather than the item
that follows.  That is, they are equivalent to writing `#![doc="..."]` around
103 104
the body of the comment. `//!` comments are usually used to document
modules that occupy a source file.
S
Steve Klabnik 已提交
105 106 107 108 109

Non-doc comments are interpreted as a form of whitespace.

## Whitespace

110
Whitespace is any non-empty string containing only the following characters:
111 112 113 114 115

- `U+0020` (space, `' '`)
- `U+0009` (tab, `'\t'`)
- `U+000A` (LF, `'\n'`)
- `U+000D` (CR, `'\r'`)
S
Steve Klabnik 已提交
116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136

Rust is a "free-form" language, meaning that all forms of whitespace serve only
to separate _tokens_ in the grammar, and have no semantic significance.

A Rust program has identical meaning if each whitespace element is replaced
with any other legal whitespace element, such as a single space character.

## Tokens

Tokens are primitive productions in the grammar defined by regular
(non-recursive) languages. "Simple" tokens are given in [string table
production](#string-table-productions) form, and occur in the rest of the
grammar as double-quoted strings. Other tokens have exact rules given.

### Literals

A literal is an expression consisting of a single token, rather than a sequence
of tokens, that immediately and directly denotes the value it evaluates to,
rather than referring to it by name or some other evaluation rule. A literal is
a form of constant expression, so is evaluated (primarily) at compile time.

137 138 139 140
#### Examples

##### Characters and strings

141 142 143 144 145 146 147 148
|                                              | Example         | `#` sets   | Characters  | Escapes             |
|----------------------------------------------|-----------------|------------|-------------|---------------------|
| [Character](#character-literals)             | `'H'`           | `N/A`      | All Unicode | `\'` & [Byte](#byte-escapes) & [Unicode](#unicode-escapes) |
| [String](#string-literals)                   | `"hello"`       | `N/A`      | All Unicode | `\"` & [Byte](#byte-escapes) & [Unicode](#unicode-escapes) |
| [Raw](#raw-string-literals)                  | `r#"hello"#`    | `0...`     | All Unicode | `N/A`                                                      |
| [Byte](#byte-literals)                       | `b'H'`          | `N/A`      | All ASCII   | `\'` & [Byte](#byte-escapes)                               |
| [Byte string](#byte-string-literals)         | `b"hello"`      | `N/A`      | All ASCII   | `\"` & [Byte](#byte-escapes)                               |
| [Raw byte string](#raw-byte-string-literals) | `br#"hello"#`   | `0...`     | All ASCII   | `N/A`                                                      |
149 150 151 152 153 154 155 156 157 158 159 160 161 162

##### Byte escapes

|   | Name |
|---|------|
| `\x7F` | 8-bit character code (exactly 2 digits) |
| `\n` | Newline |
| `\r` | Carriage return |
| `\t` | Tab |
| `\\` | Backslash |

##### Unicode escapes
|   | Name |
|---|------|
163
| `\u{7FFF}` | 24-bit Unicode character code (up to 6 digits) |
164 165 166 167 168

##### Numbers

| [Number literals](#number-literals)`*` | Example | Exponentiation | Suffixes |
|----------------------------------------|---------|----------------|----------|
169 170 171 172 173
| Decimal integer | `98_222` | `N/A` | Integer suffixes |
| Hex integer | `0xff` | `N/A` | Integer suffixes |
| Octal integer | `0o77` | `N/A` | Integer suffixes |
| Binary integer | `0b1111_0000` | `N/A` | Integer suffixes |
| Floating-point | `123.0E+77` | `Optional` | Floating-point suffixes |
174 175 176 177 178 179

`*` All number literals allow `_` as a visual separator: `1_234.0E+18f64`

##### Suffixes
| Integer | Floating-point |
|---------|----------------|
180
| `u8`, `i8`, `u16`, `i16`, `u32`, `i32`, `u64`, `i64`, `isize`, `usize` | `f32`, `f64` |
181

S
Steve Klabnik 已提交
182 183
#### Character and string literals

184 185
##### Character literals

S
Steve Klabnik 已提交
186 187
A _character literal_ is a single Unicode character enclosed within two
`U+0027` (single-quote) characters, with the exception of `U+0027` itself,
188
which must be _escaped_ by a preceding `U+005C` character (`\`).
S
Steve Klabnik 已提交
189

190 191
##### String literals

S
Steve Klabnik 已提交
192 193
A _string literal_ is a sequence of any Unicode characters enclosed within two
`U+0022` (double-quote) characters, with the exception of `U+0022` itself,
194
which must be _escaped_ by a preceding `U+005C` character (`\`).
S
Steve Klabnik 已提交
195

196 197 198 199 200
Line-break characters are allowed in string literals. Normally they represent
themselves (i.e. no translation), but as a special exception, when a `U+005C`
character (`\`) occurs immediately before the newline, the `U+005C` character,
the newline, and all whitespace at the beginning of the next line are ignored.
Thus `a` and `b` are equal:
201 202 203 204 205 206

```rust
let a = "foobar";
let b = "foo\
         bar";

207 208
assert_eq!(a,b);
```
209

210 211
##### Character escapes

S
Steve Klabnik 已提交
212 213 214 215
Some additional _escapes_ are available in either character or non-raw string
literals. An escape starts with a `U+005C` (`\`) and continues with one of the
following forms:

M
Mike Boutin 已提交
216 217
* An _8-bit code point escape_ starts with `U+0078` (`x`) and is
  followed by exactly two _hex digits_. It denotes the Unicode code point
S
Steve Klabnik 已提交
218
  equal to the provided hex value.
M
Mike Boutin 已提交
219
* A _24-bit code point escape_ starts with `U+0075` (`u`) and is followed
220
  by up to six _hex digits_ surrounded by braces `U+007B` (`{`) and `U+007D`
M
Mike Boutin 已提交
221
  (`}`). It denotes the Unicode code point equal to the provided hex value.
S
Steve Klabnik 已提交
222
* A _whitespace escape_ is one of the characters `U+006E` (`n`), `U+0072`
M
Mike Boutin 已提交
223
  (`r`), or `U+0074` (`t`), denoting the Unicode values `U+000A` (LF),
S
Steve Klabnik 已提交
224 225 226 227
  `U+000D` (CR) or `U+0009` (HT) respectively.
* The _backslash escape_ is the character `U+005C` (`\`) which must be
  escaped in order to denote *itself*.

228 229
##### Raw string literals

S
Steve Klabnik 已提交
230 231
Raw string literals do not process any escapes. They start with the character
`U+0072` (`r`), followed by zero or more of the character `U+0023` (`#`) and a
M
mdinger 已提交
232 233 234 235
`U+0022` (double-quote) character. The _raw string body_ can contain any sequence
of Unicode characters and is terminated only by another `U+0022` (double-quote)
character, followed by the same number of `U+0023` (`#`) characters that preceded
the opening `U+0022` (double-quote) character.
S
Steve Klabnik 已提交
236 237 238 239 240 241 242 243

All Unicode characters contained in the raw string body represent themselves,
the characters `U+0022` (double-quote) (except when followed by at least as
many `U+0023` (`#`) characters as were used to start the raw string literal) or
`U+005C` (`\`) do not have any special meaning.

Examples for string literals:

S
Steve Klabnik 已提交
244
```
S
Steve Klabnik 已提交
245 246 247 248 249 250 251 252
"foo"; r"foo";                     // foo
"\"foo\""; r#""foo""#;             // "foo"

"foo #\"# bar";
r##"foo #"# bar"##;                // foo #"# bar

"\x52"; "R"; r"R";                 // R
"\\x52"; r"\x52";                  // \x52
S
Steve Klabnik 已提交
253
```
S
Steve Klabnik 已提交
254 255 256

#### Byte and byte string literals

257 258
##### Byte literals

S
Steve Klabnik 已提交
259
A _byte literal_ is a single ASCII character (in the `U+0000` to `U+007F`
S
Skyler 已提交
260 261 262 263 264
range) or a single _escape_ preceded by the characters `U+0062` (`b`) and
`U+0027` (single-quote), and followed by the character `U+0027`. If the character
`U+0027` is present within the literal, it must be _escaped_ by a preceding
`U+005C` (`\`) character. It is equivalent to a `u8` unsigned 8-bit integer
_number literal_.
S
Steve Klabnik 已提交
265

266 267
##### Byte string literals

268 269 270 271 272
A non-raw _byte string literal_ is a sequence of ASCII characters and _escapes_,
preceded by the characters `U+0062` (`b`) and `U+0022` (double-quote), and
followed by the character `U+0022`. If the character `U+0022` is present within
the literal, it must be _escaped_ by a preceding `U+005C` (`\`) character.
Alternatively, a byte string literal can be a _raw byte string literal_, defined
273
below. A byte string literal of length `n` is equivalent to a `&'static [u8; n]` borrowed fixed-sized array
274
of unsigned 8-bit integers.
S
Steve Klabnik 已提交
275 276 277 278 279

Some additional _escapes_ are available in either byte or non-raw byte string
literals. An escape starts with a `U+005C` (`\`) and continues with one of the
following forms:

M
Mike Boutin 已提交
280
* A _byte escape_ escape starts with `U+0078` (`x`) and is
S
Steve Klabnik 已提交
281 282 283 284 285 286 287 288
  followed by exactly two _hex digits_. It denotes the byte
  equal to the provided hex value.
* A _whitespace escape_ is one of the characters `U+006E` (`n`), `U+0072`
  (`r`), or `U+0074` (`t`), denoting the bytes values `0x0A` (ASCII LF),
  `0x0D` (ASCII CR) or `0x09` (ASCII HT) respectively.
* The _backslash escape_ is the character `U+005C` (`\`) which must be
  escaped in order to denote its ASCII encoding `0x5C`.

289 290
##### Raw byte string literals

S
Steve Klabnik 已提交
291
Raw byte string literals do not process any escapes. They start with the
292
character `U+0062` (`b`), followed by `U+0072` (`r`), followed by zero or more
S
Steve Klabnik 已提交
293
of the character `U+0023` (`#`), and a `U+0022` (double-quote) character. The
M
mdinger 已提交
294 295 296 297
_raw string body_ can contain any sequence of ASCII characters and is terminated
only by another `U+0022` (double-quote) character, followed by the same number of
`U+0023` (`#`) characters that preceded the opening `U+0022` (double-quote)
character. A raw byte string literal can not contain any non-ASCII byte.
S
Steve Klabnik 已提交
298 299 300 301 302 303 304 305

All characters contained in the raw string body represent their ASCII encoding,
the characters `U+0022` (double-quote) (except when followed by at least as
many `U+0023` (`#`) characters as were used to start the raw string literal) or
`U+005C` (`\`) do not have any special meaning.

Examples for byte string literals:

S
Steve Klabnik 已提交
306
```
S
Steve Klabnik 已提交
307 308 309 310 311 312 313 314
b"foo"; br"foo";                     // foo
b"\"foo\""; br#""foo""#;             // "foo"

b"foo #\"# bar";
br##"foo #"# bar"##;                 // foo #"# bar

b"\x52"; b"R"; br"R";                // R
b"\\x52"; br"\x52";                  // \x52
S
Steve Klabnik 已提交
315
```
S
Steve Klabnik 已提交
316 317 318 319

#### Number literals

A _number literal_ is either an _integer literal_ or a _floating-point
320
literal_. The grammar for recognizing the two kinds of literals is mixed.
S
Steve Klabnik 已提交
321 322 323 324 325 326 327 328

##### Integer literals

An _integer literal_ has one of four forms:

* A _decimal literal_ starts with a *decimal digit* and continues with any
  mixture of *decimal digits* and _underscores_.
* A _hex literal_ starts with the character sequence `U+0030` `U+0078`
D
Daniel Hofstetter 已提交
329
  (`0x`) and continues as any mixture of hex digits and underscores.
S
Steve Klabnik 已提交
330
* An _octal literal_ starts with the character sequence `U+0030` `U+006F`
D
Daniel Hofstetter 已提交
331
  (`0o`) and continues as any mixture of octal digits and underscores.
S
Steve Klabnik 已提交
332
* A _binary literal_ starts with the character sequence `U+0030` `U+0062`
D
Daniel Hofstetter 已提交
333
  (`0b`) and continues as any mixture of binary digits and underscores.
S
Steve Klabnik 已提交
334

335 336
Like any literal, an integer literal may be followed (immediately,
without any spaces) by an _integer suffix_, which forcibly sets the
337 338 339
type of the literal. The integer suffix must be the name of one of the
integral types: `u8`, `i8`, `u16`, `i16`, `u32`, `i32`, `u64`, `i64`,
`isize`, or `usize`.
S
Steve Klabnik 已提交
340 341 342

The type of an _unsuffixed_ integer literal is determined by type inference.
If an integer type can be _uniquely_ determined from the surrounding program
S
Steve Klabnik 已提交
343
context, the unsuffixed integer literal has that type. If the program context
344 345 346
underconstrains the type, it defaults to the signed 32-bit integer `i32`; if
the program context overconstrains the type, it is considered a static type
error.
S
Steve Klabnik 已提交
347 348 349

Examples of integer literals of various forms:

S
Steve Klabnik 已提交
350
```
351 352 353
123i32;                            // type i32
123u32;                            // type u32
123_u32;                           // type u32
S
Steve Klabnik 已提交
354 355 356
0xff_u8;                           // type u8
0o70_i16;                          // type i16
0b1111_1111_1001_0000_i32;         // type i32
357
0usize;                            // type usize
S
Steve Klabnik 已提交
358
```
S
Steve Klabnik 已提交
359 360 361 362 363

##### Floating-point literals

A _floating-point literal_ has one of two forms:

364 365
* A _decimal literal_ followed by a period character `U+002E` (`.`). This is
  optionally followed by another decimal literal, with an optional _exponent_.
S
Steve Klabnik 已提交
366 367
* A single _decimal literal_ followed by an _exponent_.

368 369 370
Like integer literals, a floating-point literal may be followed by a
suffix, so long as the pre-suffix part does not end with `U+002E` (`.`).
The suffix forcibly sets the type of the literal. There are two valid
371 372
_floating-point suffixes_, `f32` and `f64` (the 32-bit and 64-bit floating point
types), which explicitly determine the type of the literal.
S
Steve Klabnik 已提交
373

374 375 376 377 378 379 380
The type of an _unsuffixed_ floating-point literal is determined by type
inference. If a floating-point type can be _uniquely_ determined from the
surrounding program context, the unsuffixed floating-point literal has that type.
If the program context underconstrains the type, it defaults to double-precision `f64`;
if the program context overconstrains the type, it is considered a static type
error.

S
Steve Klabnik 已提交
381 382
Examples of floating-point literals of various forms:

S
Steve Klabnik 已提交
383
```
384 385 386 387 388
123.0f64;        // type f64
0.1f64;          // type f64
0.1f32;          // type f32
12E+99_f64;      // type f64
let x: f64 = 2.; // type f64
S
Steve Klabnik 已提交
389
```
S
Steve Klabnik 已提交
390

391 392 393 394
This last example is different because it is not possible to use the suffix
syntax with a floating point literal ending in a period. `2.f64` would attempt
to call a method named `f64` on `2`.

395 396 397
The representation semantics of floating-point numbers are described in
["Machine Types"](#machine-types).

398
#### Boolean literals
S
Steve Klabnik 已提交
399

J
Jakub Bukaj 已提交
400
The two values of the boolean type are written `true` and `false`.
S
Steve Klabnik 已提交
401 402 403 404 405 406 407

### Symbols

Symbols are a general class of printable [token](#tokens) that play structural
roles in a variety of grammar productions. They are catalogued here for
completeness as the set of remaining miscellaneous printable tokens that do not
otherwise appear as [unary operators](#unary-operator-expressions), [binary
S
Steve Klabnik 已提交
408
operators](#binary-operator-expressions), or [keywords][keywords].
S
Steve Klabnik 已提交
409 410 411 412 413 414


## Paths

A _path_ is a sequence of one or more path components _logically_ separated by
a namespace qualifier (`::`). If a path consists of only one component, it may
415
refer to either an [item](#items) or a [variable](#variables) in a local control
S
Steve Klabnik 已提交
416 417 418 419 420 421 422 423
scope. If a path has multiple components, it refers to an item.

Every item has a _canonical path_ within its crate, but the path naming an item
is only meaningful within a given crate. There is no global namespace across
crates; an item's canonical path merely identifies it within the crate.

Two examples of simple paths consisting of only identifier components:

S
Steve Klabnik 已提交
424
```{.ignore}
S
Steve Klabnik 已提交
425 426
x;
x::y::z;
S
Steve Klabnik 已提交
427
```
S
Steve Klabnik 已提交
428 429 430 431 432 433 434 435 436 437

Path components are usually [identifiers](#identifiers), but the trailing
component of a path may be an angle-bracket-enclosed list of type arguments. In
[expression](#expressions) context, the type argument list is given after a
final (`::`) namespace qualifier in order to disambiguate it from a relational
expression involving the less-than symbol (`<`). In type expression context,
the final namespace qualifier is omitted.

Two examples of paths with type arguments:

S
Steve Klabnik 已提交
438
```
439
# struct HashMap<K, V>(K,V);
S
Steve Klabnik 已提交
440 441
# fn f() {
# fn id<T>(t: T) -> T { t }
442 443
type T = HashMap<i32,String>; // Type arguments used in a type expression
let x  = id::<i32>(10);       // Type arguments used in a call expression
S
Steve Klabnik 已提交
444
# }
S
Steve Klabnik 已提交
445
```
S
Steve Klabnik 已提交
446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466

Paths can be denoted with various leading qualifiers to change the meaning of
how it is resolved:

* Paths starting with `::` are considered to be global paths where the
  components of the path start being resolved from the crate root. Each
  identifier in the path must resolve to an item.

```rust
mod a {
    pub fn foo() {}
}
mod b {
    pub fn foo() {
        ::a::foo(); // call a's foo function
    }
}
# fn main() {}
```

* Paths starting with the keyword `super` begin resolution relative to the
467
  parent module. Each further identifier must resolve to an item.
S
Steve Klabnik 已提交
468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495

```rust
mod a {
    pub fn foo() {}
}
mod b {
    pub fn foo() {
        super::a::foo(); // call a's foo function
    }
}
# fn main() {}
```

* Paths starting with the keyword `self` begin resolution relative to the
  current module. Each further identifier must resolve to an item.

```rust
fn foo() {}
fn bar() {
    self::foo();
}
# fn main() {}
```

# Syntax extensions

A number of minor features of Rust are not central enough to have their own
syntax, and yet are not implementable as functions. Instead, they are given
496
names, and invoked through a consistent syntax: `some_extension!(...)`.
S
Steve Klabnik 已提交
497

498 499
Users of `rustc` can define new syntax extensions in two ways:

500
* [Compiler plugins][plugin] can include arbitrary
501 502
  Rust code that manipulates syntax trees at compile time.

S
Steve Klabnik 已提交
503
* [Macros](book/macros.html) define new syntax in a higher-level,
504 505
  declarative way.

S
Steve Klabnik 已提交
506 507
## Macros

K
Keegan McAllister 已提交
508 509 510 511 512
`macro_rules` allows users to define syntax extension in a declarative way.  We
call such extensions "macros by example" or simply "macros" — to be distinguished
from the "procedural macros" defined in [compiler plugins][plugin].

Currently, macros can expand to expressions, statements, items, or patterns.
S
Steve Klabnik 已提交
513

S
Steve Klabnik 已提交
514
(A `sep_token` is any token other than `*` and `+`. A `non_special_token` is
S
Steve Klabnik 已提交
515 516 517
any token other than a delimiter or `$`.)

The macro expander looks up macro invocations by name, and tries each macro
S
Steve Klabnik 已提交
518
rule in turn. It transcribes the first successful match. Matching and
S
Steve Klabnik 已提交
519 520 521 522 523 524
transcription are closely related to each other, and we will describe them
together.

### Macro By Example

The macro expander matches and transcribes every token that does not begin with
S
Steve Klabnik 已提交
525
a `$` literally, including delimiters. For parsing reasons, delimiters must be
S
Steve Klabnik 已提交
526 527 528 529
balanced, but they are otherwise not special.

In the matcher, `$` _name_ `:` _designator_ matches the nonterminal in the Rust
syntax named by _designator_. Valid designators are `item`, `block`, `stmt`,
530 531 532
`pat`, `expr`, `ty` (type), `ident`, `path`, `tt` (either side of the `=>`
in macro rules). In the transcriber, the designator is already known, and so
only the name of a matched nonterminal comes after the dollar sign.
S
Steve Klabnik 已提交
533 534

In both the matcher and transcriber, the Kleene star-like operator indicates
M
Manish Goregaokar 已提交
535
repetition. The Kleene star operator consists of `$` and parentheses, optionally
S
Steve Klabnik 已提交
536
followed by a separator token, followed by `*` or `+`. `*` means zero or more
M
Manish Goregaokar 已提交
537
repetitions, `+` means at least one repetition. The parentheses are not matched or
S
Steve Klabnik 已提交
538
transcribed. On the matcher side, a name is bound to _all_ of the names it
S
Steve Klabnik 已提交
539 540 541 542 543 544 545 546 547 548 549 550 551 552 553
matches, in a structure that mimics the structure of the repetition encountered
on a successful match. The job of the transcriber is to sort that structure
out.

The rules for transcription of these repetitions are called "Macro By Example".
Essentially, one "layer" of repetition is discharged at a time, and all of them
must be discharged by the time a name is transcribed. Therefore, `( $( $i:ident
),* ) => ( $i )` is an invalid macro, but `( $( $i:ident ),* ) => ( $( $i:ident
),*  )` is acceptable (if trivial).

When Macro By Example encounters a repetition, it examines all of the `$`
_name_ s that occur in its body. At the "current layer", they all must repeat
the same number of times, so ` ( $( $i:ident ),* ; $( $j:ident ),* ) => ( $(
($i,$j) ),* )` is valid if given the argument `(a,b,c ; d,e,f)`, but not
`(a,b,c ; d,e)`. The repetition walks through the choices at that layer in
J
Jan-Erik Rediger 已提交
554
lockstep, so the former input transcribes to `(a,d), (b,e), (c,f)`.
S
Steve Klabnik 已提交
555 556 557 558 559 560 561 562 563 564 565 566

Nested repetitions are allowed.

### Parsing limitations

The parser used by the macro system is reasonably powerful, but the parsing of
Rust syntax is restricted in two ways:

1. The parser will always parse as much as possible. If it attempts to match
   `$i:expr [ , ]` against `8 [ , ]`, it will attempt to parse `i` as an array
   index operation and fail. Adding a separator can solve this problem.
2. The parser must have eliminated all ambiguity by the time it reaches a `$`
S
Steve Klabnik 已提交
567
   _name_ `:` _designator_. This requirement most often affects name-designator
S
Steve Klabnik 已提交
568 569 570 571 572
   pairs when they occur at the beginning of, or immediately after, a `$(...)*`;
   requiring a distinctive token in front can solve the problem.

# Crates and source files

573 574 575 576 577 578 579 580
Although Rust, like any other language, can be implemented by an interpreter as
well as a compiler, the only existing implementation is a compiler &mdash;
from now on referred to as *the* Rust compiler &mdash; and the language has
always been designed to be compiled. For these reasons, this section assumes a
compiler.

Rust's semantics obey a *phase distinction* between compile-time and
run-time.[^phase-distinction] Those semantic rules that have a *static
G
Graydon Hoare 已提交
581 582 583
interpretation* govern the success or failure of compilation. Those semantics
that have a *dynamic interpretation* govern the behavior of the program at
run-time.
S
Steve Klabnik 已提交
584

585 586 587 588
[^phase-distinction]: This distinction would also exist in an interpreter.
    Static checks like syntactic analysis, type checking, and lints should
    happen before the program is executed regardless of when it is executed.

S
Steve Klabnik 已提交
589
The compilation model centers on artifacts called _crates_. Each compilation
S
Steve Klabnik 已提交
590
processes a single crate in source form, and if successful, produces a single
591 592
crate in binary form: either an executable or some sort of
library.[^cratesourcefile]
S
Steve Klabnik 已提交
593 594 595 596 597 598

[^cratesourcefile]: A crate is somewhat analogous to an *assembly* in the
    ECMA-335 CLI model, a *library* in the SML/NJ Compilation Manager, a *unit*
    in the Owens and Flatt module system, or a *configuration* in Mesa.

A _crate_ is a unit of compilation and linking, as well as versioning,
S
Steve Klabnik 已提交
599 600
distribution and runtime loading. A crate contains a _tree_ of nested
[module](#modules) scopes. The top level of this tree is a module that is
S
Steve Klabnik 已提交
601 602 603 604 605
anonymous (from the point of view of paths within the module) and any item
within a crate has a canonical [module path](#paths) denoting its location
within the crate's module tree.

The Rust compiler is always invoked with a single source file as input, and
S
Steve Klabnik 已提交
606 607
always produces a single output crate. The processing of that source file may
result in other source files being loaded as modules. Source files have the
S
Steve Klabnik 已提交
608 609 610 611 612
extension `.rs`.

A Rust source file describes a module, the name and location of which &mdash;
in the module tree of the current crate &mdash; are defined from outside the
source file: either by an explicit `mod_item` in a referencing source file, or
613 614 615
by the name of the crate itself. Every source file is a module, but not every
module needs its own source file: [module definitions](#modules) can be nested
within one file.
S
Steve Klabnik 已提交
616 617

Each source file contains a sequence of zero or more `item` definitions, and
S
Steve Klabnik 已提交
618
may optionally begin with any number of [attributes](#items-and-attributes)
619 620 621
that apply to the containing module, most of which influence the behavior of
the compiler. The anonymous crate module can have additional attributes that
apply to the crate as a whole.
S
Steve Klabnik 已提交
622

623
```no_run
624
// Specify the crate name.
625
#![crate_name = "projx"]
S
Steve Klabnik 已提交
626

627
// Specify the type of output artifact.
S
Steve Klabnik 已提交
628 629
#![crate_type = "lib"]

630 631
// Turn on a warning.
// This can be done in any module, not just the anonymous crate module.
S
Steve Klabnik 已提交
632
#![warn(non_camel_case_types)]
S
Steve Klabnik 已提交
633
```
S
Steve Klabnik 已提交
634

S
Steve Klabnik 已提交
635
A crate that contains a `main` function can be compiled to an executable. If a
S
Steve Klabnik 已提交
636 637 638 639 640 641 642 643 644 645
`main` function is present, its return type must be [`unit`](#primitive-types)
and it must take no arguments.

# Items and attributes

Crates contain [items](#items), each of which may have some number of
[attributes](#attributes) attached to it.

## Items

S
Steve Klabnik 已提交
646 647
An _item_ is a component of a crate. Items are organized within a crate by a
nested set of [modules](#modules). Every crate has a single "outermost"
S
Steve Klabnik 已提交
648 649 650 651 652 653 654 655
anonymous module; all further items within the crate have [paths](#paths)
within the module tree of the crate.

Items are entirely determined at compile-time, generally remain fixed during
execution, and may reside in read-only memory.

There are several kinds of item:

656 657
* [`extern crate` declarations](#extern-crate-declarations)
* [`use` declarations](#use-declarations)
S
Steve Klabnik 已提交
658 659
* [modules](#modules)
* [functions](#functions)
S
Steve Klabnik 已提交
660
* [type definitions](grammar.html#type-definitions)
S
Steve Klabnik 已提交
661 662
* [structures](#structures)
* [enumerations](#enumerations)
663
* [constant items](#constant-items)
S
Steve Klabnik 已提交
664 665 666 667 668 669 670 671 672 673 674
* [static items](#static-items)
* [traits](#traits)
* [implementations](#implementations)

Some items form an implicit scope for the declaration of sub-items. In other
words, within a function or module, declarations of items can (in many cases)
be mixed with the statements, control blocks, and similar artifacts that
otherwise compose the item body. The meaning of these scoped items is the same
as if the item was declared outside the scope &mdash; it is still a static item
&mdash; except that the item's *path name* within the module namespace is
qualified by the name of the enclosing item, or is private to the enclosing
S
Steve Klabnik 已提交
675
item (in the case of functions). The grammar specifies the exact locations in
S
Steve Klabnik 已提交
676 677 678 679
which sub-item declarations may appear.

### Type Parameters

680 681 682 683 684 685 686 687 688 689
All items except modules, constants and statics may be *parameterized* by type.
Type parameters are given as a comma-separated list of identifiers enclosed in
angle brackets (`<...>`), after the name of the item and before its definition.
The type parameters of an item are considered "part of the name", not part of
the type of the item. A referencing [path](#paths) must (in principle) provide
type arguments as a list of comma-separated types enclosed within angle
brackets, in order to refer to the type-parameterized item. In practice, the
type-inference system can usually infer such argument types from context. There
are no general type-parametric types, only type-parametric items. That is, Rust
has no notion of type abstraction: there are no first-class "forall" types.
S
Steve Klabnik 已提交
690 691 692

### Modules

693
A module is a container for zero or more [items](#items).
S
Steve Klabnik 已提交
694 695 696 697 698 699 700

A _module item_ is a module, surrounded in braces, named, and prefixed with the
keyword `mod`. A module item introduces a new, named module into the tree of
modules making up a crate. Modules can nest arbitrarily.

An example of a module:

S
Steve Klabnik 已提交
701
```
S
Steve Klabnik 已提交
702 703 704 705
mod math {
    type Complex = (f64, f64);
    fn sin(f: f64) -> f64 {
        /* ... */
S
Steve Klabnik 已提交
706
# panic!();
S
Steve Klabnik 已提交
707 708 709
    }
    fn cos(f: f64) -> f64 {
        /* ... */
S
Steve Klabnik 已提交
710
# panic!();
S
Steve Klabnik 已提交
711 712 713
    }
    fn tan(f: f64) -> f64 {
        /* ... */
S
Steve Klabnik 已提交
714
# panic!();
S
Steve Klabnik 已提交
715 716
    }
}
S
Steve Klabnik 已提交
717
```
S
Steve Klabnik 已提交
718

D
Daniel Hofstetter 已提交
719
Modules and types share the same namespace. Declaring a named type with
S
Steve Klabnik 已提交
720 721 722 723 724
the same name as a module in scope is forbidden: that is, a type definition,
trait, struct, enumeration, or type parameter can't shadow the name of a module
in scope, or vice versa.

A module without a body is loaded from an external file, by default with the
S
Steve Klabnik 已提交
725
same name as the module, plus the `.rs` extension. When a nested submodule is
S
Steve Klabnik 已提交
726 727 728
loaded from an external file, it is loaded from a subdirectory path that
mirrors the module hierarchy.

S
Steve Klabnik 已提交
729
```{.ignore}
S
Steve Klabnik 已提交
730 731 732
// Load the `vec` module from `vec.rs`
mod vec;

S
Steve Klabnik 已提交
733 734
mod thread {
    // Load the `local_data` module from `thread/local_data.rs`
S
Steve Klabnik 已提交
735 736
    mod local_data;
}
S
Steve Klabnik 已提交
737
```
S
Steve Klabnik 已提交
738 739 740 741

The directories and files used for loading external file modules can be
influenced with the `path` attribute.

S
Steve Klabnik 已提交
742
```{.ignore}
S
Steve Klabnik 已提交
743 744 745
#[path = "thread_files"]
mod thread {
    // Load the `local_data` module from `thread_files/tls.rs`
S
Steve Klabnik 已提交
746 747 748
    #[path = "tls.rs"]
    mod local_data;
}
S
Steve Klabnik 已提交
749
```
S
Steve Klabnik 已提交
750

751
#### Extern crate declarations
S
Steve Klabnik 已提交
752 753 754 755 756 757 758

An _`extern crate` declaration_ specifies a dependency on an external crate.
The external crate is then bound into the declaring scope as the `ident`
provided in the `extern_crate_decl`.

The external crate is resolved to a specific `soname` at compile time, and a
runtime linkage requirement to that `soname` is passed to the linker for
S
Steve Klabnik 已提交
759
loading at runtime. The `soname` is resolved at compile time by scanning the
760 761 762 763
compiler's library path and matching the optional `crateid` provided against
the `crateid` attributes that were declared on the external crate when it was
compiled. If no `crateid` is provided, a default `name` attribute is assumed,
equal to the `ident` given in the `extern_crate_decl`.
S
Steve Klabnik 已提交
764

D
Daniel Hofstetter 已提交
765
Three examples of `extern crate` declarations:
S
Steve Klabnik 已提交
766

S
Steve Klabnik 已提交
767
```{.ignore}
S
Steve Klabnik 已提交
768 769 770 771
extern crate pcre;

extern crate std; // equivalent to: extern crate std as std;

772
extern crate std as ruststd; // linking to 'std' under another name
S
Steve Klabnik 已提交
773
```
S
Steve Klabnik 已提交
774

775
#### Use declarations
S
Steve Klabnik 已提交
776 777

A _use declaration_ creates one or more local name bindings synonymous with
S
Steve Klabnik 已提交
778
some other [path](#paths). Usually a `use` declaration is used to shorten the
S
Steve Klabnik 已提交
779
path required to refer to a module item. These declarations may appear at the
S
Steve Klabnik 已提交
780
top of [modules](#modules) and [blocks](grammar.html#block-expressions).
S
Steve Klabnik 已提交
781 782 783 784 785 786 787

> **Note**: Unlike in many languages,
> `use` declarations in Rust do *not* declare linkage dependency with external crates.
> Rather, [`extern crate` declarations](#extern-crate-declarations) declare linkage dependencies.

Use declarations support a number of convenient shortcuts:

788
* Rebinding the target name as a new local name, using the syntax `use p::q::r as x;`
S
Steve Klabnik 已提交
789 790 791 792 793
* Simultaneously binding a list of paths differing only in their final element,
  using the glob-like brace syntax `use a::b::{c,d,e,f};`
* Binding all paths matching a given prefix, using the asterisk wildcard syntax
  `use a::b::*;`
* Simultaneously binding a list of paths differing only in their final element
794 795
  and their immediate parent module, using the `self` keyword, such as
  `use a::b::{self, c, d};`
S
Steve Klabnik 已提交
796 797 798

An example of `use` declarations:

799
```rust
C
Corey Farwell 已提交
800
use std::option::Option::{Some, None};
801
use std::collections::hash_map::{self, HashMap};
S
Steve Klabnik 已提交
802

803
fn foo<T>(_: T){}
804
fn bar(map1: HashMap<String, usize>, map2: hash_map::HashMap<String, usize>){}
S
Steve Klabnik 已提交
805 806

fn main() {
C
Corey Farwell 已提交
807 808
    // Equivalent to 'foo(vec![std::option::Option::Some(1.0f64),
    // std::option::Option::None]);'
S
Steve Klabnik 已提交
809 810
    foo(vec![Some(1.0f64), None]);

811 812 813 814
    // Both `hash_map` and `HashMap` are in scope.
    let map1 = HashMap::new();
    let map2 = hash_map::HashMap::new();
    bar(map1, map2);
S
Steve Klabnik 已提交
815
}
S
Steve Klabnik 已提交
816
```
S
Steve Klabnik 已提交
817 818

Like items, `use` declarations are private to the containing module, by
S
Steve Klabnik 已提交
819 820
default. Also like items, a `use` declaration can be public, if qualified by
the `pub` keyword. Such a `use` declaration serves to _re-export_ a name. A
S
Steve Klabnik 已提交
821 822
public `use` declaration can therefore _redirect_ some public name to a
different target definition: even a definition with a private canonical path,
S
Steve Klabnik 已提交
823
inside a different module. If a sequence of such redirections form a cycle or
S
Steve Klabnik 已提交
824 825 826 827
cannot be resolved unambiguously, they represent a compile-time error.

An example of re-exporting:

S
Steve Klabnik 已提交
828
```
S
Steve Klabnik 已提交
829 830 831 832 833 834 835 836 837
# fn main() { }
mod quux {
    pub use quux::foo::{bar, baz};

    pub mod foo {
        pub fn bar() { }
        pub fn baz() { }
    }
}
S
Steve Klabnik 已提交
838
```
S
Steve Klabnik 已提交
839 840 841 842 843

In this example, the module `quux` re-exports two public names defined in
`foo`.

Also note that the paths contained in `use` items are relative to the crate
S
Steve Klabnik 已提交
844 845
root. So, in the previous example, the `use` refers to `quux::foo::{bar,
baz}`, and not simply to `foo::{bar, baz}`. This also means that top-level
S
Steve Klabnik 已提交
846
module declarations should be at the crate root if direct usage of the declared
S
Steve Klabnik 已提交
847
modules within `use` items is desired. It is also possible to use `self` and
S
Steve Klabnik 已提交
848
`super` at the beginning of a `use` item to refer to the current and direct
S
Steve Klabnik 已提交
849
parent modules respectively. All rules regarding accessing declared modules in
850
`use` declarations apply to both module declarations and `extern crate`
S
Steve Klabnik 已提交
851 852 853 854
declarations.

An example of what will and will not work for `use` items:

S
Steve Klabnik 已提交
855
```
S
Steve Klabnik 已提交
856 857 858 859 860
# #![allow(unused_imports)]
use foo::baz::foobaz;    // good: foo is at the root of the crate

mod foo {

861 862 863 864 865 866
    mod example {
        pub mod iter {}
    }

    use foo::example::iter; // good: foo is at crate root
//  use example::iter;      // bad:  core is not at the crate root
S
Steve Klabnik 已提交
867 868 869 870 871 872 873 874 875 876 877 878 879 880
    use self::baz::foobaz;  // good: self refers to module 'foo'
    use foo::bar::foobar;   // good: foo is at crate root

    pub mod bar {
        pub fn foobar() { }
    }

    pub mod baz {
        use super::bar::foobar; // good: super refers to module 'foo'
        pub fn foobaz() { }
    }
}

fn main() {}
S
Steve Klabnik 已提交
881
```
S
Steve Klabnik 已提交
882 883 884 885 886

### Functions

A _function item_ defines a sequence of [statements](#statements) and an
optional final [expression](#expressions), along with a name and a set of
S
Steve Klabnik 已提交
887
parameters. Functions are declared with the keyword `fn`. Functions declare a
888 889 890
set of *input* [*variables*](#variables) as parameters, through which the caller
passes arguments into the function, and the *output* [*type*](#types)
of the value the function will return to its caller on completion.
S
Steve Klabnik 已提交
891

892
A function may also be copied into a first-class *value*, in which case the
S
Steve Klabnik 已提交
893 894 895 896 897 898 899 900 901 902 903
value has the corresponding [*function type*](#function-types), and can be used
otherwise exactly as a function item (with a minor additional cost of calling
the function indirectly).

Every control path in a function logically ends with a `return` expression or a
diverging expression. If the outermost block of a function has a
value-producing expression in its final-expression position, that expression is
interpreted as an implicit `return` expression applied to the final-expression.

An example of a function:

S
Steve Klabnik 已提交
904
```
905
fn add(x: i32, y: i32) -> i32 {
S
Steve Klabnik 已提交
906 907
    return x + y;
}
S
Steve Klabnik 已提交
908
```
S
Steve Klabnik 已提交
909 910 911 912

As with `let` bindings, function arguments are irrefutable patterns, so any
pattern that is valid in a let binding is also valid as an argument.

S
Steve Klabnik 已提交
913
```
914
fn first((value, _): (i32, i32)) -> i32 { value }
S
Steve Klabnik 已提交
915
```
S
Steve Klabnik 已提交
916 917 918 919 920 921 922 923


#### Generic functions

A _generic function_ allows one or more _parameterized types_ to appear in its
signature. Each type parameter must be explicitly declared, in an
angle-bracket-enclosed, comma-separated list following the function name.

S
Steve Klabnik 已提交
924
```{.ignore}
925 926
fn iter<T, F>(seq: &[T], f: F) where T: Copy, F: Fn(T) {
    for elt in seq { f(*elt); }
S
Steve Klabnik 已提交
927
}
928
fn map<T, U, F>(seq: &[T], f: F) -> Vec<U> where T: Copy, U: Copy, F: Fn(T) -> U {
S
Steve Klabnik 已提交
929
    let mut acc = vec![];
930
    for elt in seq { acc.push(f(*elt)); }
S
Steve Klabnik 已提交
931 932
    acc
}
S
Steve Klabnik 已提交
933
```
S
Steve Klabnik 已提交
934 935

Inside the function signature and body, the name of the type parameter can be
936 937 938
used as a type name. [Trait](#traits) bounds can be specified for type parameters
to allow methods with that trait to be called on values of that type. This is
specified using the `where` syntax, as in the above example.
S
Steve Klabnik 已提交
939 940 941

When a generic function is referenced, its type is instantiated based on the
context of the reference. For example, calling the `iter` function defined
942
above on `[1, 2]` will instantiate type parameter `T` with `i32`, and require
943
the closure parameter to have type `Fn(i32)`.
S
Steve Klabnik 已提交
944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959 960 961 962 963 964

The type parameters can also be explicitly supplied in a trailing
[path](#paths) component after the function name. This might be necessary if
there is not sufficient context to determine the type parameters. For example,
`mem::size_of::<u32>() == 4`.

#### Unsafety

Unsafe operations are those that potentially violate the memory-safety
guarantees of Rust's static semantics.

The following language level features cannot be used in the safe subset of
Rust:

- Dereferencing a [raw pointer](#pointer-types).
- Reading or writing a [mutable static variable](#mutable-statics).
- Calling an unsafe function (including an intrinsic or foreign function).

##### Unsafe functions

Unsafe functions are functions that are not safe in all contexts and/or for all
965 966
possible inputs. Such a function must be prefixed with the keyword `unsafe` and
can only be called from an `unsafe` block or another `unsafe` function.
S
Steve Klabnik 已提交
967 968 969

##### Unsafe blocks

970 971
A block of code can be prefixed with the `unsafe` keyword, to permit calling
`unsafe` functions or dereferencing raw pointers within a safe function.
S
Steve Klabnik 已提交
972 973 974 975 976 977 978 979 980

When a programmer has sufficient conviction that a sequence of potentially
unsafe operations is actually safe, they can encapsulate that sequence (taken
as a whole) within an `unsafe` block. The compiler will consider uses of such
code safe, in the surrounding context.

Unsafe blocks are used to wrap foreign libraries, make direct use of hardware
or implement features not directly present in the language. For example, Rust
provides the language features necessary to implement memory-safe concurrency
S
Steve Klabnik 已提交
981
in the language but the implementation of threads and message passing is in the
S
Steve Klabnik 已提交
982 983 984 985 986
standard library.

Rust's type system is a conservative approximation of the dynamic safety
requirements, so in some cases there is a performance cost to using safe code.
For example, a doubly-linked list is not a tree structure and can only be
S
Steve Klabnik 已提交
987 988 989
represented with reference-counted pointers in safe code. By using `unsafe`
blocks to represent the reverse links as raw pointers, it can be implemented
with only boxes.
S
Steve Klabnik 已提交
990

991
##### Behavior considered undefined
S
Steve Klabnik 已提交
992

993 994 995
The following is a list of behavior which is forbidden in all Rust code,
including within `unsafe` blocks and `unsafe` functions. Type checking provides
the guarantee that these issues are never caused by safe code.
S
Steve Klabnik 已提交
996 997 998 999 1000 1001 1002 1003

* Data races
* Dereferencing a null/dangling raw pointer
* Reads of [undef](http://llvm.org/docs/LangRef.html#undefined-values)
  (uninitialized) memory
* Breaking the [pointer aliasing
  rules](http://llvm.org/docs/LangRef.html#pointer-aliasing-rules)
  with raw pointers (a subset of the rules used by C)
1004 1005 1006 1007
* `&mut` and `&` follow LLVM’s scoped [noalias] model, except if the `&T`
  contains an `UnsafeCell<U>`. Unsafe code must not violate these aliasing
  guarantees.
* Mutating an immutable value/reference without `UnsafeCell<U>`
S
Steve Klabnik 已提交
1008 1009 1010 1011 1012
* Invoking undefined behavior via compiler intrinsics:
  * Indexing outside of the bounds of an object with `std::ptr::offset`
    (`offset` intrinsic), with
    the exception of one byte past the end which is permitted.
  * Using `std::ptr::copy_nonoverlapping_memory` (`memcpy32`/`memcpy64`
J
Joseph Crail 已提交
1013
    intrinsics) on overlapping buffers
S
Steve Klabnik 已提交
1014
* Invalid values in primitive types, even in private fields/locals:
1015
  * Dangling/null references or boxes
S
Steve Klabnik 已提交
1016 1017 1018
  * A value other than `false` (0) or `true` (1) in a `bool`
  * A discriminant in an `enum` not included in the type definition
  * A value in a `char` which is a surrogate or above `char::MAX`
1019
  * Non-UTF-8 byte sequences in a `str`
1020 1021 1022
* Unwinding into Rust from foreign code or unwinding from Rust into foreign
  code. Rust's failure system is not compatible with exception handling in
  other languages. Unwinding must be caught and handled at FFI boundaries.
S
Steve Klabnik 已提交
1023

1024 1025
[noalias]: http://llvm.org/docs/LangRef.html#noalias

M
Mike Boutin 已提交
1026
##### Behavior not considered unsafe
S
Steve Klabnik 已提交
1027

M
Mike Boutin 已提交
1028
This is a list of behavior not considered *unsafe* in Rust terms, but that may
S
Steve Klabnik 已提交
1029 1030 1031
be undesired.

* Deadlocks
L
Luqman Aden 已提交
1032
* Reading data from private fields (`std::repr`)
S
Steve Klabnik 已提交
1033 1034 1035 1036 1037
* Leaks due to reference count cycles, even in the global heap
* Exiting without calling destructors
* Sending signals
* Accessing/modifying the file system
* Unsigned integer overflow (well-defined as wrapping)
S
Steve Klabnik 已提交
1038
* Signed integer overflow (well-defined as two’s complement representation
S
Steve Klabnik 已提交
1039 1040 1041 1042 1043
  wrapping)

#### Diverging functions

A special kind of function can be declared with a `!` character where the
1044
output type would normally be. For example:
S
Steve Klabnik 已提交
1045

S
Steve Klabnik 已提交
1046
```
S
Steve Klabnik 已提交
1047 1048
fn my_err(s: &str) -> ! {
    println!("{}", s);
S
Steve Klabnik 已提交
1049
    panic!();
S
Steve Klabnik 已提交
1050
}
S
Steve Klabnik 已提交
1051
```
S
Steve Klabnik 已提交
1052 1053

We call such functions "diverging" because they never return a value to the
S
Steve Klabnik 已提交
1054
caller. Every control path in a diverging function must end with a `panic!()` or
S
Steve Klabnik 已提交
1055
a call to another diverging function on every control path. The `!` annotation
S
Steve Klabnik 已提交
1056
does *not* denote a type.
S
Steve Klabnik 已提交
1057 1058 1059 1060 1061 1062 1063

It might be necessary to declare a diverging function because as mentioned
previously, the typechecker checks that every control path in a function ends
with a [`return`](#return-expressions) or diverging expression. So, if `my_err`
were declared without the `!` annotation, the following code would not
typecheck:

S
Steve Klabnik 已提交
1064
```
S
Steve Klabnik 已提交
1065
# fn my_err(s: &str) -> ! { panic!() }
S
Steve Klabnik 已提交
1066

1067
fn f(i: i32) -> i32 {
S
Steve Klabnik 已提交
1068 1069 1070 1071 1072 1073 1074
   if i == 42 {
     return 42;
   }
   else {
     my_err("Bad number!");
   }
}
S
Steve Klabnik 已提交
1075
```
S
Steve Klabnik 已提交
1076 1077

This will not compile without the `!` annotation on `my_err`, since the `else`
1078
branch of the conditional in `f` does not return an `i32`, as required by the
S
Steve Klabnik 已提交
1079
signature of `f`. Adding the `!` annotation to `my_err` informs the
S
Steve Klabnik 已提交
1080 1081
typechecker that, should control ever enter `my_err`, no further type judgments
about `f` need to hold, since control will never resume in any context that
S
Steve Klabnik 已提交
1082
relies on those judgments. Thus the return type on `f` only needs to reflect
S
Steve Klabnik 已提交
1083 1084 1085 1086 1087
the `if` branch of the conditional.

#### Extern functions

Extern functions are part of Rust's foreign function interface, providing the
S
Steve Klabnik 已提交
1088
opposite functionality to [external blocks](#external-blocks). Whereas
S
Steve Klabnik 已提交
1089 1090 1091 1092 1093
external blocks allow Rust code to call foreign code, extern functions with
bodies defined in Rust code _can be called by foreign code_. They are defined
in the same way as any other Rust function, except that they have the `extern`
modifier.

S
Steve Klabnik 已提交
1094
```
S
Steve Klabnik 已提交
1095
// Declares an extern fn, the ABI defaults to "C"
1096
extern fn new_i32() -> i32 { 0 }
S
Steve Klabnik 已提交
1097 1098

// Declares an extern fn with "stdcall" ABI
1099
extern "stdcall" fn new_i32_stdcall() -> i32 { 0 }
S
Steve Klabnik 已提交
1100
```
S
Steve Klabnik 已提交
1101

S
Steve Klabnik 已提交
1102
Unlike normal functions, extern fns have an `extern "ABI" fn()`. This is the
S
Steve Klabnik 已提交
1103 1104
same type as the functions declared in an extern block.

S
Steve Klabnik 已提交
1105
```
1106 1107
# extern fn new_i32() -> i32 { 0 }
let fptr: extern "C" fn() -> i32 = new_i32;
S
Steve Klabnik 已提交
1108
```
S
Steve Klabnik 已提交
1109 1110 1111 1112

Extern functions may be called directly from Rust code as Rust uses large,
contiguous stack segments like C.

1113
### Type aliases
S
Steve Klabnik 已提交
1114

1115 1116
A _type alias_ defines a new name for an existing [type](#types). Type
aliases are declared with the keyword `type`. Every value has a single,
1117 1118 1119 1120
specific type, but may implement several different traits, or be compatible with
several different type constraints.

For example, the following defines the type `Point` as a synonym for the type
M
Mike Boutin 已提交
1121
`(u8, u8)`, the type of pairs of unsigned 8 bit integers:
1122 1123 1124 1125 1126

```
type Point = (u8, u8);
let p: Point = (41, 68);
```
S
Steve Klabnik 已提交
1127 1128 1129 1130 1131 1132 1133 1134

### Structures

A _structure_ is a nominal [structure type](#structure-types) defined with the
keyword `struct`.

An example of a `struct` item and its use:

S
Steve Klabnik 已提交
1135
```
1136
struct Point {x: i32, y: i32}
S
Steve Klabnik 已提交
1137
let p = Point {x: 10, y: 11};
1138
let px: i32 = p.x;
S
Steve Klabnik 已提交
1139
```
S
Steve Klabnik 已提交
1140 1141

A _tuple structure_ is a nominal [tuple type](#tuple-types), also defined with
S
Steve Klabnik 已提交
1142
the keyword `struct`. For example:
S
Steve Klabnik 已提交
1143

S
Steve Klabnik 已提交
1144
```
1145
struct Point(i32, i32);
S
Steve Klabnik 已提交
1146
let p = Point(10, 11);
1147
let px: i32 = match p { Point(x, _) => x };
S
Steve Klabnik 已提交
1148
```
S
Steve Klabnik 已提交
1149 1150

A _unit-like struct_ is a structure without any fields, defined by leaving off
S
Steve Klabnik 已提交
1151
the list of fields entirely. Such types will have a single value. For example:
S
Steve Klabnik 已提交
1152

S
Steve Klabnik 已提交
1153
```
S
Steve Klabnik 已提交
1154 1155
struct Cookie;
let c = [Cookie, Cookie, Cookie, Cookie];
S
Steve Klabnik 已提交
1156
```
S
Steve Klabnik 已提交
1157 1158 1159 1160 1161 1162 1163 1164 1165 1166 1167 1168 1169 1170

The precise memory layout of a structure is not specified. One can specify a
particular layout using the [`repr` attribute](#ffi-attributes).

### Enumerations

An _enumeration_ is a simultaneous definition of a nominal [enumerated
type](#enumerated-types) as well as a set of *constructors*, that can be used
to create or pattern-match values of the corresponding enumerated type.

Enumerations are declared with the keyword `enum`.

An example of an `enum` item and its use:

S
Steve Klabnik 已提交
1171
```
S
Steve Klabnik 已提交
1172 1173 1174 1175 1176
enum Animal {
  Dog,
  Cat
}

S
Steven Fackler 已提交
1177 1178
let mut a: Animal = Animal::Dog;
a = Animal::Cat;
S
Steve Klabnik 已提交
1179
```
S
Steve Klabnik 已提交
1180 1181 1182

Enumeration constructors can have either named or unnamed fields:

1183
```rust
S
Steve Klabnik 已提交
1184 1185 1186 1187 1188
enum Animal {
    Dog (String, f64),
    Cat { name: String, weight: f64 }
}

S
Steven Fackler 已提交
1189 1190
let mut a: Animal = Animal::Dog("Cocoa".to_string(), 37.2);
a = Animal::Cat { name: "Spotty".to_string(), weight: 2.7 };
S
Steve Klabnik 已提交
1191
```
S
Steve Klabnik 已提交
1192 1193 1194 1195

In this example, `Cat` is a _struct-like enum variant_,
whereas `Dog` is simply called an enum variant.

1196 1197 1198 1199 1200 1201 1202 1203 1204 1205 1206 1207 1208 1209 1210 1211 1212 1213 1214 1215 1216
Enums have a discriminant. You can assign them explicitly:

```
enum Foo {
    Bar = 123,
}
```

If a discriminant isn't assigned, they start at zero, and add one for each
variant, in order.

You can cast an enum to get this value:

```
# enum Foo { Bar = 123 }
let x = Foo::Bar as u32; // x is now 123u32
```

This only works as long as none of the variants have data attached. If
it were `Bar(i32)`, this is disallowed.

1217
### Constant items
S
Steve Klabnik 已提交
1218

1219 1220 1221 1222 1223 1224 1225 1226 1227 1228 1229
A *constant item* is a named _constant value_ which is not associated with a
specific memory location in the program. Constants are essentially inlined
wherever they are used, meaning that they are copied directly into the relevant
context when used. References to the same constant are not necessarily
guaranteed to refer to the same memory address.

Constant values must not have destructors, and otherwise permit most forms of
data. Constants may refer to the address of other constants, in which case the
address will have the `static` lifetime. The compiler is, however, still at
liberty to translate the constant many times, so the address referred to may not
be stable.
S
Steve Klabnik 已提交
1230

1231 1232 1233
Constants must be explicitly typed. The type may be `bool`, `char`, a number, or
a type derived from those primitive types. The derived types are references with
the `static` lifetime, fixed-size arrays, tuples, enum variants, and structs.
S
Steve Klabnik 已提交
1234

S
Steve Klabnik 已提交
1235
```
1236 1237
const BIT1: u32 = 1 << 0;
const BIT2: u32 = 1 << 1;
S
Steve Klabnik 已提交
1238

1239
const BITS: [u32; 2] = [BIT1, BIT2];
1240
const STRING: &'static str = "bitstring";
S
Steve Klabnik 已提交
1241 1242

struct BitsNStrings<'a> {
1243
    mybits: [u32; 2],
S
Steve Klabnik 已提交
1244 1245 1246
    mystring: &'a str
}

1247
const BITS_N_STRINGS: BitsNStrings<'static> = BitsNStrings {
S
Steve Klabnik 已提交
1248 1249 1250
    mybits: BITS,
    mystring: STRING
};
S
Steve Klabnik 已提交
1251
```
S
Steve Klabnik 已提交
1252

1253 1254 1255 1256 1257 1258 1259 1260 1261 1262 1263 1264 1265 1266 1267 1268 1269 1270 1271 1272 1273
### Static items

A *static item* is similar to a *constant*, except that it represents a precise
memory location in the program. A static is never "inlined" at the usage site,
and all references to it refer to the same memory location. Static items have
the `static` lifetime, which outlives all other lifetimes in a Rust program.
Static items may be placed in read-only memory if they do not contain any
interior mutability.

Statics may contain interior mutability through the `UnsafeCell` language item.
All access to a static is safe, but there are a number of restrictions on
statics:

* Statics may not contain any destructors.
* The types of static values must ascribe to `Sync` to allow threadsafe access.
* Statics may not refer to other statics by value, only by reference.
* Constants cannot refer to statics.

Constants should in general be preferred over statics, unless large amounts of
data are being stored, or single-address and mutability properties are required.

S
Steve Klabnik 已提交
1274 1275
#### Mutable statics

S
Steve Klabnik 已提交
1276
If a static item is declared with the `mut` keyword, then it is allowed to
S
Steve Klabnik 已提交
1277 1278
be modified by the program. One of Rust's goals is to make concurrency bugs
hard to run into, and this is obviously a very large source of race conditions
S
Steve Klabnik 已提交
1279
or other bugs. For this reason, an `unsafe` block is required when either
S
Steve Klabnik 已提交
1280
reading or writing a mutable static variable. Care should be taken to ensure
S
Steve Klabnik 已提交
1281
that modifications to a mutable static are safe with respect to other threads
S
Steve Klabnik 已提交
1282 1283 1284
running in the same process.

Mutable statics are still very useful, however. They can be used with C
S
Steve Klabnik 已提交
1285
libraries and can also be bound from C libraries (in an `extern` block).
S
Steve Klabnik 已提交
1286

S
Steve Klabnik 已提交
1287
```
1288
# fn atomic_add(_: &mut u32, _: u32) -> u32 { 2 }
S
Steve Klabnik 已提交
1289

1290
static mut LEVELS: u32 = 0;
S
Steve Klabnik 已提交
1291 1292 1293

// This violates the idea of no shared state, and this doesn't internally
// protect against races, so this function is `unsafe`
1294
unsafe fn bump_levels_unsafe1() -> u32 {
S
Steve Klabnik 已提交
1295 1296 1297 1298 1299 1300 1301 1302
    let ret = LEVELS;
    LEVELS += 1;
    return ret;
}

// Assuming that we have an atomic_add function which returns the old value,
// this function is "safe" but the meaning of the return value may not be what
// callers expect, so it's still marked as `unsafe`
1303
unsafe fn bump_levels_unsafe2() -> u32 {
S
Steve Klabnik 已提交
1304 1305
    return atomic_add(&mut LEVELS, 1);
}
S
Steve Klabnik 已提交
1306
```
S
Steve Klabnik 已提交
1307

1308 1309 1310
Mutable statics have the same restrictions as normal statics, except that the
type of the value is not required to ascribe to `Sync`.

S
Steve Klabnik 已提交
1311 1312 1313 1314 1315 1316 1317 1318 1319 1320 1321
### Traits

A _trait_ describes a set of method types.

Traits can include default implementations of methods, written in terms of some
unknown [`self` type](#self-types); the `self` type may either be completely
unspecified, or constrained by some other trait.

Traits are implemented for specific types through separate
[implementations](#implementations).

S
Steve Klabnik 已提交
1322
```
1323 1324
# type Surface = i32;
# type BoundingBox = i32;
S
Steve Klabnik 已提交
1325 1326 1327 1328
trait Shape {
    fn draw(&self, Surface);
    fn bounding_box(&self) -> BoundingBox;
}
S
Steve Klabnik 已提交
1329
```
S
Steve Klabnik 已提交
1330

S
Steve Klabnik 已提交
1331
This defines a trait with two methods. All values that have
S
Steve Klabnik 已提交
1332 1333 1334 1335
[implementations](#implementations) of this trait in scope can have their
`draw` and `bounding_box` methods called, using `value.bounding_box()`
[syntax](#method-call-expressions).

S
Steve Klabnik 已提交
1336
Type parameters can be specified for a trait to make it generic. These appear
S
Steve Klabnik 已提交
1337 1338 1339
after the trait name, using the same syntax used in [generic
functions](#generic-functions).

1340
```
S
Steve Klabnik 已提交
1341
trait Seq<T> {
1342 1343
   fn len(&self) -> u32;
   fn elt_at(&self, n: u32) -> T;
1344
   fn iter<F>(&self, F) where F: Fn(T);
S
Steve Klabnik 已提交
1345
}
S
Steve Klabnik 已提交
1346
```
S
Steve Klabnik 已提交
1347

S
Steve Klabnik 已提交
1348
Generic functions may use traits as _bounds_ on their type parameters. This
S
Steve Klabnik 已提交
1349 1350
will have two effects: only types that have the trait may instantiate the
parameter, and within the generic function, the methods of the trait can be
S
Steve Klabnik 已提交
1351
called on values that have the parameter's type. For example:
S
Steve Klabnik 已提交
1352

S
Steve Klabnik 已提交
1353
```
1354
# type Surface = i32;
S
Steve Klabnik 已提交
1355 1356 1357 1358 1359
# trait Shape { fn draw(&self, Surface); }
fn draw_twice<T: Shape>(surface: Surface, sh: T) {
    sh.draw(surface);
    sh.draw(surface);
}
S
Steve Klabnik 已提交
1360
```
S
Steve Klabnik 已提交
1361

N
nwin 已提交
1362
Traits also define an [trait object](#trait-objects) with the same name as the
S
Steve Klabnik 已提交
1363
trait. Values of this type are created by [casting](#type-cast-expressions)
S
Steve Klabnik 已提交
1364 1365 1366
pointer values (pointing to a type for which an implementation of the given
trait is in scope) to pointers to the trait name, used as a type.

S
Steve Klabnik 已提交
1367
```
1368
# trait Shape { fn dummy(&self) { } }
1369 1370
# impl Shape for i32 { }
# let mycircle = 0i32;
A
Alex Crichton 已提交
1371
let myshape: Box<Shape> = Box::new(mycircle) as Box<Shape>;
S
Steve Klabnik 已提交
1372
```
S
Steve Klabnik 已提交
1373 1374 1375 1376 1377 1378 1379 1380 1381

The resulting value is a box containing the value that was cast, along with
information that identifies the methods of the implementation that was used.
Values with a trait type can have [methods called](#method-call-expressions) on
them, for any method in the trait, and can be used to instantiate type
parameters that are bounded by the trait.

Trait methods may be static, which means that they lack a `self` argument.
This means that they can only be called with function call syntax (`f(x)`) and
S
Steve Klabnik 已提交
1382
not method call syntax (`obj.f()`). The way to refer to the name of a static
S
Steve Klabnik 已提交
1383 1384 1385
method is to qualify it with the trait name, treating the trait name like a
module. For example:

S
Steve Klabnik 已提交
1386
```
S
Steve Klabnik 已提交
1387
trait Num {
1388
    fn from_i32(n: i32) -> Self;
S
Steve Klabnik 已提交
1389 1390
}
impl Num for f64 {
1391
    fn from_i32(n: i32) -> f64 { n as f64 }
S
Steve Klabnik 已提交
1392
}
1393
let x: f64 = Num::from_i32(42);
S
Steve Klabnik 已提交
1394
```
S
Steve Klabnik 已提交
1395 1396 1397

Traits may inherit from other traits. For example, in

S
Steve Klabnik 已提交
1398
```
1399 1400
trait Shape { fn area(&self) -> f64; }
trait Circle : Shape { fn radius(&self) -> f64; }
S
Steve Klabnik 已提交
1401
```
S
Steve Klabnik 已提交
1402 1403

the syntax `Circle : Shape` means that types that implement `Circle` must also
S
Steve Klabnik 已提交
1404 1405
have an implementation for `Shape`. Multiple supertraits are separated by `+`,
`trait Circle : Shape + PartialEq { }`. In an implementation of `Circle` for a
S
Steve Klabnik 已提交
1406 1407 1408 1409 1410
given type `T`, methods can refer to `Shape` methods, since the typechecker
checks that any type with an implementation of `Circle` also has an
implementation of `Shape`.

In type-parameterized functions, methods of the supertrait may be called on
S
Steve Klabnik 已提交
1411
values of subtrait-bound type parameters. Referring to the previous example of
S
Steve Klabnik 已提交
1412 1413
`trait Circle : Shape`:

S
Steve Klabnik 已提交
1414
```
S
Steve Klabnik 已提交
1415 1416 1417 1418 1419 1420
# trait Shape { fn area(&self) -> f64; }
# trait Circle : Shape { fn radius(&self) -> f64; }
fn radius_times_area<T: Circle>(c: T) -> f64 {
    // `c` is both a Circle and a Shape
    c.radius() * c.area()
}
S
Steve Klabnik 已提交
1421
```
S
Steve Klabnik 已提交
1422 1423 1424

Likewise, supertrait methods may also be called on trait objects.

S
Steve Klabnik 已提交
1425
```{.ignore}
S
Steve Klabnik 已提交
1426 1427
# trait Shape { fn area(&self) -> f64; }
# trait Circle : Shape { fn radius(&self) -> f64; }
1428 1429 1430
# impl Shape for i32 { fn area(&self) -> f64 { 0.0 } }
# impl Circle for i32 { fn radius(&self) -> f64 { 0.0 } }
# let mycircle = 0i32;
A
Alex Crichton 已提交
1431
let mycircle = Box::new(mycircle) as Box<Circle>;
S
Steve Klabnik 已提交
1432
let nonsense = mycircle.radius() * mycircle.area();
S
Steve Klabnik 已提交
1433
```
S
Steve Klabnik 已提交
1434 1435 1436 1437 1438 1439 1440 1441

### Implementations

An _implementation_ is an item that implements a [trait](#traits) for a
specific type.

Implementations are defined with the keyword `impl`.

S
Steve Klabnik 已提交
1442
```
1443
# #[derive(Copy, Clone)]
S
Steve Klabnik 已提交
1444
# struct Point {x: f64, y: f64};
1445
# type Surface = i32;
S
Steve Klabnik 已提交
1446 1447 1448 1449 1450 1451 1452 1453
# struct BoundingBox {x: f64, y: f64, width: f64, height: f64};
# trait Shape { fn draw(&self, Surface); fn bounding_box(&self) -> BoundingBox; }
# fn do_draw_circle(s: Surface, c: Circle) { }
struct Circle {
    radius: f64,
    center: Point,
}

N
Niko Matsakis 已提交
1454 1455
impl Copy for Circle {}

1456 1457 1458 1459
impl Clone for Circle {
    fn clone(&self) -> Circle { *self }
}

S
Steve Klabnik 已提交
1460 1461 1462 1463 1464 1465 1466 1467
impl Shape for Circle {
    fn draw(&self, s: Surface) { do_draw_circle(s, *self); }
    fn bounding_box(&self) -> BoundingBox {
        let r = self.radius;
        BoundingBox{x: self.center.x - r, y: self.center.y - r,
         width: 2.0 * r, height: 2.0 * r}
    }
}
S
Steve Klabnik 已提交
1468
```
S
Steve Klabnik 已提交
1469

S
Steve Klabnik 已提交
1470
It is possible to define an implementation without referring to a trait. The
S
Steve Klabnik 已提交
1471
methods in such an implementation can only be used as direct calls on the
S
Steve Klabnik 已提交
1472 1473
values of the type that the implementation targets. In such an implementation,
the trait type and `for` after `impl` are omitted. Such implementations are
S
Steve Klabnik 已提交
1474
limited to nominal types (enums, structs), and the implementation must appear
1475 1476 1477
in the same module or a sub-module as the `self` type:

```
1478
struct Point {x: i32, y: i32}
1479 1480 1481 1482 1483 1484 1485 1486 1487 1488

impl Point {
    fn log(&self) {
        println!("Point is at ({}, {})", self.x, self.y);
    }
}

let my_point = Point {x: 10, y:11};
my_point.log();
```
S
Steve Klabnik 已提交
1489 1490 1491 1492 1493

When a trait _is_ specified in an `impl`, all methods declared as part of the
trait must be implemented, with matching types and type parameter counts.

An implementation can take type parameters, which can be different from the
S
Steve Klabnik 已提交
1494
type parameters taken by the trait it implements. Implementation parameters
S
Steve Klabnik 已提交
1495 1496
are written after the `impl` keyword.

S
Steve Klabnik 已提交
1497
```
1498
# trait Seq<T> { fn dummy(&self, _: T) { } }
S
Steve Klabnik 已提交
1499 1500 1501 1502 1503 1504
impl<T> Seq<T> for Vec<T> {
   /* ... */
}
impl Seq<bool> for u32 {
   /* Treat the integer as a sequence of bits */
}
S
Steve Klabnik 已提交
1505
```
S
Steve Klabnik 已提交
1506 1507 1508 1509 1510 1511 1512 1513 1514 1515 1516 1517

### External blocks

External blocks form the basis for Rust's foreign function interface.
Declarations in an external block describe symbols in external, non-Rust
libraries.

Functions within external blocks are declared in the same way as other Rust
functions, with the exception that they may not have a body and are instead
terminated by a semicolon.

Functions within external blocks may be called by Rust code, just like
S
Steve Klabnik 已提交
1518
functions defined in Rust. The Rust compiler automatically translates between
S
Steve Klabnik 已提交
1519 1520 1521 1522 1523
the Rust ABI and the foreign ABI.

A number of [attributes](#attributes) control the behavior of external blocks.

By default external blocks assume that the library they are calling uses the
S
Steve Klabnik 已提交
1524
standard C "cdecl" ABI. Other ABIs may be specified using an `abi` string, as
S
Steve Klabnik 已提交
1525 1526
shown here:

1527
```ignore
S
Steve Klabnik 已提交
1528 1529
// Interface to the Windows API
extern "stdcall" { }
S
Steve Klabnik 已提交
1530
```
S
Steve Klabnik 已提交
1531 1532 1533 1534 1535

The `link` attribute allows the name of the library to be specified. When
specified the compiler will attempt to link against the native library of the
specified name.

S
Steve Klabnik 已提交
1536
```{.ignore}
S
Steve Klabnik 已提交
1537 1538
#[link(name = "crypto")]
extern { }
S
Steve Klabnik 已提交
1539
```
S
Steve Klabnik 已提交
1540 1541 1542 1543 1544 1545 1546 1547 1548 1549 1550 1551 1552 1553 1554 1555 1556 1557 1558 1559 1560

The type of a function declared in an extern block is `extern "abi" fn(A1, ...,
An) -> R`, where `A1...An` are the declared types of its arguments and `R` is
the declared return type.

## Visibility and Privacy

These two terms are often used interchangeably, and what they are attempting to
convey is the answer to the question "Can this item be used at this location?"

Rust's name resolution operates on a global hierarchy of namespaces. Each level
in the hierarchy can be thought of as some item. The items are one of those
mentioned above, but also include external crates. Declaring or defining a new
module can be thought of as inserting a new tree into the hierarchy at the
location of the definition.

To control whether interfaces can be used across modules, Rust checks each use
of an item to see whether it should be allowed or not. This is where privacy
warnings are generated, or otherwise "you used a private item of another module
and weren't allowed to."

S
Steve Klabnik 已提交
1561
By default, everything in Rust is *private*, with one exception. Enum variants
1562
in a `pub` enum are also public by default. When an item is declared as `pub`,
S
Steve Klabnik 已提交
1563 1564
it can be thought of as being accessible to the outside world. For example:

S
Steve Klabnik 已提交
1565
```
S
Steve Klabnik 已提交
1566 1567 1568 1569 1570 1571
# fn main() {}
// Declare a private struct
struct Foo;

// Declare a public struct with a private field
pub struct Bar {
1572
    field: i32
S
Steve Klabnik 已提交
1573 1574 1575 1576 1577 1578 1579
}

// Declare a public enum with two public variants
pub enum State {
    PubliclyAccessibleState,
    PubliclyAccessibleState2,
}
S
Steve Klabnik 已提交
1580
```
S
Steve Klabnik 已提交
1581 1582 1583 1584 1585 1586 1587 1588 1589 1590 1591

With the notion of an item being either public or private, Rust allows item
accesses in two cases:

1. If an item is public, then it can be used externally through any of its
   public ancestors.
2. If an item is private, it may be accessed by the current module and its
   descendants.

These two cases are surprisingly powerful for creating module hierarchies
exposing public APIs while hiding internal implementation details. To help
1592
explain, here's a few use cases and what they would entail:
S
Steve Klabnik 已提交
1593 1594 1595 1596 1597 1598 1599 1600 1601 1602 1603 1604 1605 1606 1607 1608 1609 1610 1611 1612 1613 1614 1615 1616 1617 1618 1619 1620 1621 1622

* A library developer needs to expose functionality to crates which link
  against their library. As a consequence of the first case, this means that
  anything which is usable externally must be `pub` from the root down to the
  destination item. Any private item in the chain will disallow external
  accesses.

* A crate needs a global available "helper module" to itself, but it doesn't
  want to expose the helper module as a public API. To accomplish this, the
  root of the crate's hierarchy would have a private module which then
  internally has a "public api". Because the entire crate is a descendant of
  the root, then the entire local crate can access this private module through
  the second case.

* When writing unit tests for a module, it's often a common idiom to have an
  immediate child of the module to-be-tested named `mod test`. This module
  could access any items of the parent module through the second case, meaning
  that internal implementation details could also be seamlessly tested from the
  child module.

In the second case, it mentions that a private item "can be accessed" by the
current module and its descendants, but the exact meaning of accessing an item
depends on what the item is. Accessing a module, for example, would mean
looking inside of it (to import more items). On the other hand, accessing a
function would mean that it is invoked. Additionally, path expressions and
import statements are considered to access an item in the sense that the
import/expression is only valid if the destination is in the current visibility
scope.

Here's an example of a program which exemplifies the three cases outlined
1623
above:
S
Steve Klabnik 已提交
1624

S
Steve Klabnik 已提交
1625
```
S
Steve Klabnik 已提交
1626 1627 1628 1629 1630 1631 1632 1633 1634 1635 1636 1637 1638 1639 1640 1641 1642 1643 1644 1645 1646 1647 1648 1649 1650 1651 1652 1653 1654 1655 1656 1657 1658 1659 1660 1661 1662 1663 1664 1665 1666 1667 1668 1669 1670 1671 1672
// This module is private, meaning that no external crate can access this
// module. Because it is private at the root of this current crate, however, any
// module in the crate may access any publicly visible item in this module.
mod crate_helper_module {

    // This function can be used by anything in the current crate
    pub fn crate_helper() {}

    // This function *cannot* be used by anything else in the crate. It is not
    // publicly visible outside of the `crate_helper_module`, so only this
    // current module and its descendants may access it.
    fn implementation_detail() {}
}

// This function is "public to the root" meaning that it's available to external
// crates linking against this one.
pub fn public_api() {}

// Similarly to 'public_api', this module is public so external crates may look
// inside of it.
pub mod submodule {
    use crate_helper_module;

    pub fn my_method() {
        // Any item in the local crate may invoke the helper module's public
        // interface through a combination of the two rules above.
        crate_helper_module::crate_helper();
    }

    // This function is hidden to any module which is not a descendant of
    // `submodule`
    fn my_implementation() {}

    #[cfg(test)]
    mod test {

        #[test]
        fn test_my_implementation() {
            // Because this module is a descendant of `submodule`, it's allowed
            // to access private items inside of `submodule` without a privacy
            // violation.
            super::my_implementation();
        }
    }
}

# fn main() {}
S
Steve Klabnik 已提交
1673
```
S
Steve Klabnik 已提交
1674 1675 1676 1677 1678 1679 1680 1681 1682 1683 1684 1685

For a rust program to pass the privacy checking pass, all paths must be valid
accesses given the two rules above. This includes all use statements,
expressions, types, etc.

### Re-exporting and Visibility

Rust allows publicly re-exporting items through a `pub use` directive. Because
this is a public directive, this allows the item to be used in the current
module through the rules above. It essentially allows public access into the
re-exported item. For example, this program is valid:

S
Steve Klabnik 已提交
1686
```
N
Nick Cameron 已提交
1687
pub use self::implementation::api;
S
Steve Klabnik 已提交
1688 1689

mod implementation {
N
Nick Cameron 已提交
1690 1691 1692
    pub mod api {
        pub fn f() {}
    }
S
Steve Klabnik 已提交
1693 1694 1695
}

# fn main() {}
S
Steve Klabnik 已提交
1696
```
S
Steve Klabnik 已提交
1697

N
Nick Cameron 已提交
1698
This means that any external crate referencing `implementation::api::f` would
S
Steve Klabnik 已提交
1699 1700 1701 1702 1703 1704 1705 1706 1707 1708 1709 1710 1711 1712 1713 1714 1715 1716 1717 1718 1719 1720 1721 1722 1723
receive a privacy violation, while the path `api::f` would be allowed.

When re-exporting a private item, it can be thought of as allowing the "privacy
chain" being short-circuited through the reexport instead of passing through
the namespace hierarchy as it normally would.

## Attributes

Any item declaration may have an _attribute_ applied to it. Attributes in Rust
are modeled on Attributes in ECMA-335, with the syntax coming from ECMA-334
(C#). An attribute is a general, free-form metadatum that is interpreted
according to name, convention, and language and compiler version. Attributes
may appear as any of:

* A single identifier, the attribute name
* An identifier followed by the equals sign '=' and a literal, providing a
  key/value pair
* An identifier followed by a parenthesized list of sub-attribute arguments

Attributes with a bang ("!") after the hash ("#") apply to the item that the
attribute is declared within. Attributes that do not have a bang after the hash
apply to the item that follows the attribute.

An example of attributes:

S
Steve Klabnik 已提交
1724
```{.rust}
S
Steve Klabnik 已提交
1725
// General metadata applied to the enclosing module or crate.
1726
#![crate_type = "lib"]
S
Steve Klabnik 已提交
1727 1728 1729 1730 1731 1732 1733 1734 1735 1736 1737 1738 1739 1740 1741 1742

// A function marked as a unit test
#[test]
fn test_foo() {
  /* ... */
}

// A conditionally-compiled module
#[cfg(target_os="linux")]
mod bar {
  /* ... */
}

// A lint attribute used to suppress a warning/error
#[allow(non_camel_case_types)]
type int8_t = i8;
S
Steve Klabnik 已提交
1743
```
S
Steve Klabnik 已提交
1744 1745 1746 1747 1748 1749 1750 1751

> **Note:** At some point in the future, the compiler will distinguish between
> language-reserved and user-available attributes. Until then, there is
> effectively no difference between an attribute handled by a loadable syntax
> extension and the compiler.

### Crate-only attributes

M
Mike Boutin 已提交
1752
- `crate_name` - specify the crate's crate name.
S
Steve Klabnik 已提交
1753 1754 1755 1756 1757 1758 1759 1760 1761
- `crate_type` - see [linkage](#linkage).
- `feature` - see [compiler features](#compiler-features).
- `no_builtins` - disable optimizing certain code patterns to invocations of
                  library functions that are assumed to exist
- `no_main` - disable emitting the `main` symbol. Useful when some other
   object being linked to defines `main`.
- `no_start` - disable linking to the `native` crate, which specifies the
  "start" language item.
- `no_std` - disable linking to the `std` crate.
1762 1763 1764 1765 1766
- `plugin` — load a list of named crates as compiler plugins, e.g.
             `#![plugin(foo, bar)]`. Optional arguments for each plugin,
             i.e. `#![plugin(foo(... args ...))]`, are provided to the plugin's
             registrar function.  The `plugin` feature gate is required to use
             this attribute.
S
Steve Klabnik 已提交
1767 1768 1769 1770 1771 1772 1773 1774 1775 1776 1777 1778 1779 1780

### Module-only attributes

- `no_implicit_prelude` - disable injecting `use std::prelude::*` in this
  module.
- `path` - specifies the file to load the module from. `#[path="foo.rs"] mod
  bar;` is equivalent to `mod bar { /* contents of foo.rs */ }`. The path is
  taken relative to the directory that the current module is in.

### Function-only attributes

- `main` - indicates that this function should be passed to the entry point,
  rather than the function in the crate root named `main`.
- `plugin_registrar` - mark this function as the registration point for
1781
  [compiler plugins][plugin], such as loadable syntax extensions.
S
Steve Klabnik 已提交
1782
- `start` - indicates that this function should be used as the entry point,
S
Steve Klabnik 已提交
1783
  overriding the "start" language item. See the "start" [language
S
Steve Klabnik 已提交
1784
  item](#language-items) for more details.
S
Steve Klabnik 已提交
1785 1786
- `test` - indicates that this function is a test function, to only be compiled
  in case of `--test`.
1787
- `should_panic` - indicates that this test function should panic, inverting the success condition.
1788 1789
- `cold` - The function is unlikely to be executed, so optimize it (and calls
  to it) differently.
S
Steve Klabnik 已提交
1790 1791 1792 1793 1794 1795 1796 1797 1798 1799 1800 1801 1802 1803 1804

### Static-only attributes

- `thread_local` - on a `static mut`, this signals that the value of this
  static may change depending on the current thread. The exact consequences of
  this are implementation-defined.

### FFI attributes

On an `extern` block, the following attributes are interpreted:

- `link_args` - specify arguments to the linker, rather than just the library
  name and type. This is feature gated and the exact behavior is
  implementation-defined (due to variety of linker invocation syntax).
- `link` - indicate that a native library should be linked to for the
1805 1806 1807 1808
  declarations in this block to be linked correctly. `link` supports an optional `kind`
  key with three possible values: `dylib`, `static`, and `framework`. See [external blocks](#external-blocks) for more about external blocks. Two
  examples: `#[link(name = "readline")]` and
  `#[link(name = "CoreFoundation", kind = "framework")]`.
S
Steve Klabnik 已提交
1809 1810 1811 1812 1813 1814 1815 1816 1817 1818 1819 1820 1821 1822 1823 1824 1825 1826 1827 1828 1829 1830 1831 1832 1833 1834

On declarations inside an `extern` block, the following attributes are
interpreted:

- `link_name` - the name of the symbol that this function or static should be
  imported as.
- `linkage` - on a static, this specifies the [linkage
  type](http://llvm.org/docs/LangRef.html#linkage-types).

On `enum`s:

- `repr` - on C-like enums, this sets the underlying type used for
  representation. Takes one argument, which is the primitive
  type this enum should be represented for, or `C`, which specifies that it
  should be the default `enum` size of the C ABI for that platform. Note that
  enum representation in C is undefined, and this may be incorrect when the C
  code is compiled with certain flags.

On `struct`s:

- `repr` - specifies the representation to use for this struct. Takes a list
  of options. The currently accepted ones are `C` and `packed`, which may be
  combined. `C` will use a C ABI compatible struct layout, and `packed` will
  remove any padding between fields (note that this is very fragile and may
  break platforms which require aligned access).

1835
### Macro-related attributes
K
Keegan McAllister 已提交
1836 1837 1838 1839 1840 1841 1842 1843

- `macro_use` on a `mod` — macros defined in this module will be visible in the
  module's parent, after this module has been included.

- `macro_use` on an `extern crate` — load macros from this crate.  An optional
  list of names `#[macro_use(foo, bar)]` restricts the import to just those
  macros named.  The `extern crate` must appear at the crate root, not inside
  `mod`, which ensures proper function of the [`$crate` macro
S
Steve Klabnik 已提交
1844
  variable](book/macros.html#the-variable-$crate).
K
Keegan McAllister 已提交
1845 1846 1847 1848 1849

- `macro_reexport` on an `extern crate` — re-export the named macros.

- `macro_export` - export a macro for cross-crate usage.

1850 1851
- `no_link` on an `extern crate` — even if we load this crate for macros, don't
  link it into the output.
K
Keegan McAllister 已提交
1852

S
Steve Klabnik 已提交
1853 1854 1855
See the [macros section of the
book](book/macros.html#scoping-and-macro-import/export) for more information on
macro scope.
K
Keegan McAllister 已提交
1856 1857


S
Steve Klabnik 已提交
1858 1859 1860 1861 1862 1863 1864 1865 1866 1867 1868 1869 1870 1871
### Miscellaneous attributes

- `export_name` - on statics and functions, this determines the name of the
  exported symbol.
- `link_section` - on statics and functions, this specifies the section of the
  object file that this item's contents will be placed into.
- `no_mangle` - on any item, do not apply the standard name mangling. Set the
  symbol for this item to its identifier.
- `packed` - on structs or enums, eliminate any padding that would be used to
  align fields.
- `simd` - on certain tuple structs, derive the arithmetic operators, which
  lower to the target's SIMD instructions, if any; the `simd` feature gate
  is necessary to use this attribute.
- `static_assert` - on statics whose type is `bool`, terminates compilation
1872 1873
  with an error if it is not initialized to `true`. To use this, the `static_assert`
  feature gate must be enabled.
S
Steve Klabnik 已提交
1874 1875
- `unsafe_no_drop_flag` - on structs, remove the flag that prevents
  destructors from being run twice. Destructors might be run multiple times on
1876 1877
  the same object with this attribute. To use this, the `unsafe_no_drop_flag` feature
  gate must be enabled.
1878
- `doc` - Doc comments such as `/// foo` are equivalent to `#[doc = "foo"]`.
M
docs  
Manish Goregaokar 已提交
1879 1880 1881 1882 1883 1884 1885
- `rustc_on_unimplemented` - Write a custom note to be shown along with the error
   when the trait is found to be unimplemented on a type.
   You may use format arguments like `{T}`, `{A}` to correspond to the
   types at the point of use corresponding to the type parameters of the
   trait of the same name. `{Self}` will be replaced with the type that is supposed
   to implement the trait but doesn't. To use this, the `on_unimplemented` feature gate
   must be enabled.
S
Steve Klabnik 已提交
1886 1887 1888 1889 1890 1891 1892 1893 1894

### Conditional compilation

Sometimes one wants to have different compiler outputs from the same code,
depending on build target, such as targeted operating system, or to enable
release builds.

There are two kinds of configuration options, one that is either defined or not
(`#[cfg(foo)]`), and the other that contains a string that can be checked
1895 1896
against (`#[cfg(bar = "baz")]`). Currently, only compiler-defined configuration
options can have the latter form.
S
Steve Klabnik 已提交
1897

S
Steve Klabnik 已提交
1898
```
S
Steve Klabnik 已提交
1899 1900 1901 1902 1903 1904 1905
// The function is only included in the build when compiling for OSX
#[cfg(target_os = "macos")]
fn macos_only() {
  // ...
}

// This function is only included when either foo or bar is defined
S
Steven Fackler 已提交
1906
#[cfg(any(foo, bar))]
S
Steve Klabnik 已提交
1907 1908 1909 1910 1911 1912
fn needs_foo_or_bar() {
  // ...
}

// This function is only included when compiling for a unixish OS with a 32-bit
// architecture
1913
#[cfg(all(unix, target_pointer_width = "32"))]
S
Steve Klabnik 已提交
1914 1915 1916
fn on_32bit_unix() {
  // ...
}
S
Steven Fackler 已提交
1917 1918 1919 1920 1921 1922

// This function is only included when foo is not defined
#[cfg(not(foo))]
fn needs_not_foo() {
  // ...
}
S
Steve Klabnik 已提交
1923
```
S
Steve Klabnik 已提交
1924 1925

This illustrates some conditional compilation can be achieved using the
S
Steven Fackler 已提交
1926 1927
`#[cfg(...)]` attribute. `any`, `all` and `not` can be used to assemble
arbitrarily complex configurations through nesting.
S
Steve Klabnik 已提交
1928 1929 1930 1931

The following configurations must be defined by the implementation:

* `target_arch = "..."`. Target CPU architecture, such as `"x86"`, `"x86_64"`
1932
  `"mips"`, `"powerpc"`, `"arm"`, or `"aarch64"`.
S
Steve Klabnik 已提交
1933 1934 1935 1936 1937 1938
* `target_endian = "..."`. Endianness of the target CPU, either `"little"` or
  `"big"`.
* `target_family = "..."`. Operating system family of the target, e. g.
  `"unix"` or `"windows"`. The value of this configuration option is defined
  as a configuration itself, like `unix` or `windows`.
* `target_os = "..."`. Operating system of the target, examples include
1939
  `"windows"`, `"macos"`, `"ios"`, `"linux"`, `"android"`, `"freebsd"`, `"dragonfly"`,
D
Dave Huseby 已提交
1940
  `"bitrig"` or `"openbsd"`.
1941 1942 1943
* `target_pointer_width = "..."`. Target pointer width in bits. This is set
  to `"32"` for targets with 32-bit pointers, and likewise set to `"64"` for
  64-bit pointers.
S
Steve Klabnik 已提交
1944 1945 1946
* `unix`. See `target_family`.
* `windows`. See `target_family`.

1947 1948 1949 1950 1951 1952 1953 1954
You can also set another attribute based on a `cfg` variable with `cfg_attr`:

```rust,ignore
#[cfg_attr(a, b)]
```

Will be the same as `#[b]` if `a` is set by `cfg`, and nothing otherwise.

S
Steve Klabnik 已提交
1955 1956 1957 1958 1959 1960 1961 1962 1963 1964 1965 1966 1967 1968 1969 1970
### Lint check attributes

A lint check names a potentially undesirable coding pattern, such as
unreachable code or omitted documentation, for the static entity to which the
attribute applies.

For any lint check `C`:

* `allow(C)` overrides the check for `C` so that violations will go
   unreported,
* `deny(C)` signals an error after encountering a violation of `C`,
* `forbid(C)` is the same as `deny(C)`, but also forbids changing the lint
   level afterwards,
* `warn(C)` warns about violations of `C` but continues compilation.

The lint checks supported by the compiler can be found via `rustc -W help`,
1971
along with their default settings.  [Compiler
1972
plugins](book/compiler-plugins.html#lint-plugins) can provide additional lint checks.
S
Steve Klabnik 已提交
1973

S
Steve Klabnik 已提交
1974
```{.ignore}
S
Steve Klabnik 已提交
1975 1976
mod m1 {
    // Missing documentation is ignored here
1977
    #[allow(missing_docs)]
1978
    pub fn undocumented_one() -> i32 { 1 }
S
Steve Klabnik 已提交
1979 1980

    // Missing documentation signals a warning here
1981
    #[warn(missing_docs)]
1982
    pub fn undocumented_too() -> i32 { 2 }
S
Steve Klabnik 已提交
1983 1984

    // Missing documentation signals an error here
1985
    #[deny(missing_docs)]
1986
    pub fn undocumented_end() -> i32 { 3 }
S
Steve Klabnik 已提交
1987
}
S
Steve Klabnik 已提交
1988
```
S
Steve Klabnik 已提交
1989 1990

This example shows how one can use `allow` and `warn` to toggle a particular
1991
check on and off:
S
Steve Klabnik 已提交
1992

S
Steve Klabnik 已提交
1993
```{.ignore}
1994
#[warn(missing_docs)]
S
Steve Klabnik 已提交
1995
mod m2{
1996
    #[allow(missing_docs)]
S
Steve Klabnik 已提交
1997 1998
    mod nested {
        // Missing documentation is ignored here
1999
        pub fn undocumented_one() -> i32 { 1 }
S
Steve Klabnik 已提交
2000 2001 2002

        // Missing documentation signals a warning here,
        // despite the allow above.
2003
        #[warn(missing_docs)]
2004
        pub fn undocumented_two() -> i32 { 2 }
S
Steve Klabnik 已提交
2005 2006 2007
    }

    // Missing documentation signals a warning here
2008
    pub fn undocumented_too() -> i32 { 3 }
S
Steve Klabnik 已提交
2009
}
S
Steve Klabnik 已提交
2010
```
S
Steve Klabnik 已提交
2011 2012

This example shows how one can use `forbid` to disallow uses of `allow` for
2013
that lint check:
S
Steve Klabnik 已提交
2014

S
Steve Klabnik 已提交
2015
```{.ignore}
2016
#[forbid(missing_docs)]
S
Steve Klabnik 已提交
2017 2018
mod m3 {
    // Attempting to toggle warning signals an error here
2019
    #[allow(missing_docs)]
S
Steve Klabnik 已提交
2020
    /// Returns 2.
2021
    pub fn undocumented_too() -> i32 { 2 }
S
Steve Klabnik 已提交
2022
}
S
Steve Klabnik 已提交
2023
```
S
Steve Klabnik 已提交
2024 2025 2026 2027

### Language items

Some primitive Rust operations are defined in Rust code, rather than being
S
Steve Klabnik 已提交
2028 2029 2030
implemented directly in C or assembly language. The definitions of these
operations have to be easy for the compiler to find. The `lang` attribute
makes it possible to declare these operations. For example, the `str` module
S
Steve Klabnik 已提交
2031 2032
in the Rust standard library defines the string equality function:

S
Steve Klabnik 已提交
2033
```{.ignore}
2034
#[lang = "str_eq"]
S
Steve Klabnik 已提交
2035 2036 2037
pub fn eq_slice(a: &str, b: &str) -> bool {
    // details elided
}
S
Steve Klabnik 已提交
2038
```
S
Steve Klabnik 已提交
2039 2040 2041 2042 2043

The name `str_eq` has a special meaning to the Rust compiler, and the presence
of this definition means that it will use this definition when generating calls
to the string equality function.

2044
A complete list of the built-in language items will be added in the future.
S
Steve Klabnik 已提交
2045 2046 2047

### Inline attributes

2048 2049 2050
The inline attribute suggests that the compiler should place a copy of
the function or static in the caller, rather than generating code to
call the function or access the static where it is defined.
S
Steve Klabnik 已提交
2051 2052

The compiler automatically inlines functions based on internal heuristics.
2053
Incorrectly inlining functions can actually make the program slower, so it
S
Steve Klabnik 已提交
2054 2055 2056
should be used with care.

Immutable statics are always considered inlineable unless marked with
S
Steve Klabnik 已提交
2057 2058
`#[inline(never)]`. It is undefined whether two different inlineable statics
have the same memory address. In other words, the compiler is free to collapse
S
Steve Klabnik 已提交
2059 2060
duplicate inlineable statics together.

2061 2062
`#[inline]` and `#[inline(always)]` always cause the function to be serialized
into the crate metadata to allow cross-crate inlining.
S
Steve Klabnik 已提交
2063 2064 2065 2066 2067 2068 2069

There are three different types of inline attributes:

* `#[inline]` hints the compiler to perform an inline expansion.
* `#[inline(always)]` asks the compiler to always perform an inline expansion.
* `#[inline(never)]` asks the compiler to never perform an inline expansion.

2070
### `derive`
S
Steve Klabnik 已提交
2071

2072
The `derive` attribute allows certain traits to be automatically implemented
S
Steve Klabnik 已提交
2073 2074 2075 2076
for data structures. For example, the following will create an `impl` for the
`PartialEq` and `Clone` traits for `Foo`, the type parameter `T` will be given
the `PartialEq` or `Clone` constraints for the appropriate `impl`:

S
Steve Klabnik 已提交
2077
```
2078
#[derive(PartialEq, Clone)]
S
Steve Klabnik 已提交
2079
struct Foo<T> {
2080
    a: i32,
S
Steve Klabnik 已提交
2081 2082
    b: T
}
S
Steve Klabnik 已提交
2083
```
S
Steve Klabnik 已提交
2084 2085 2086

The generated `impl` for `PartialEq` is equivalent to

S
Steve Klabnik 已提交
2087
```
2088
# struct Foo<T> { a: i32, b: T }
S
Steve Klabnik 已提交
2089 2090 2091 2092 2093 2094 2095 2096 2097
impl<T: PartialEq> PartialEq for Foo<T> {
    fn eq(&self, other: &Foo<T>) -> bool {
        self.a == other.a && self.b == other.b
    }

    fn ne(&self, other: &Foo<T>) -> bool {
        self.a != other.a || self.b != other.b
    }
}
S
Steve Klabnik 已提交
2098
```
S
Steve Klabnik 已提交
2099 2100 2101 2102 2103 2104 2105 2106 2107 2108

### Compiler Features

Certain aspects of Rust may be implemented in the compiler, but they're not
necessarily ready for every-day use. These features are often of "prototype
quality" or "almost production ready", but may not be stable enough to be
considered a full-fledged language feature.

For this reason, Rust recognizes a special crate-level attribute of the form:

S
Steve Klabnik 已提交
2109
```{.ignore}
S
Steve Klabnik 已提交
2110
#![feature(feature1, feature2, feature3)]
S
Steve Klabnik 已提交
2111
```
S
Steve Klabnik 已提交
2112 2113 2114 2115 2116 2117 2118 2119

This directive informs the compiler that the feature list: `feature1`,
`feature2`, and `feature3` should all be enabled. This is only recognized at a
crate-level, not at a module-level. Without this directive, all features are
considered off, and using the features will result in a compiler error.

The currently implemented features of the reference compiler are:

2120
* `advanced_slice_patterns` - See the [match expressions](#match-expressions)
2121
                              section for discussion; the exact semantics of
2122 2123 2124 2125 2126
                              slice patterns are subject to change, so some types
			      are still unstable.

* `slice_patterns` - OK, actually, slice patterns are just scary and
                     completely unstable.
2127

S
Steve Klabnik 已提交
2128 2129 2130 2131 2132
* `asm` - The `asm!` macro provides a means for inline assembly. This is often
          useful, but the exact syntax for this feature along with its
          semantics are likely to change, so this macro usage must be opted
          into.

2133 2134 2135 2136
* `associated_consts` - Allows constants to be defined in `impl` and `trait`
                        blocks, so that they can be associated with a type or
                        trait in a similar manner to methods and associated
                        types.
2137 2138 2139 2140 2141 2142 2143

* `box_patterns` - Allows `box` patterns, the exact semantics of which
                   is subject to change.

* `box_syntax` - Allows use of `box` expressions, the exact semantics of which
                 is subject to change.

S
Steve Klabnik 已提交
2144 2145 2146 2147
* `concat_idents` - Allows use of the `concat_idents` macro, which is in many
                    ways insufficient for concatenating identifiers, and may be
                    removed entirely for something more wholesome.

2148
* `custom_attribute` - Allows the usage of attributes unknown to the compiler
L
Luke Gallagher 已提交
2149
                       so that new attributes can be added in a backwards compatible
2150 2151
                       manner (RFC 572).

2152 2153 2154 2155
* `custom_derive` - Allows the use of `#[derive(Foo,Bar)]` as sugar for
                    `#[derive_Foo] #[derive_Bar]`, which can be user-defined syntax
                    extensions.

S
Steve Klabnik 已提交
2156 2157 2158 2159 2160 2161 2162 2163 2164 2165 2166 2167 2168
* `intrinsics` - Allows use of the "rust-intrinsics" ABI. Compiler intrinsics
                 are inherently unstable and no promise about them is made.

* `lang_items` - Allows use of the `#[lang]` attribute. Like `intrinsics`,
                 lang items are inherently unstable and no promise about them
                 is made.

* `link_args` - This attribute is used to specify custom flags to the linker,
                but usage is strongly discouraged. The compiler's usage of the
                system linker is not guaranteed to continue in the future, and
                if the system linker is not used then specifying custom flags
                doesn't have much meaning.

2169 2170 2171
* `link_llvm_intrinsics` – Allows linking to LLVM intrinsics via
                           `#[link_name="llvm.*"]`.

S
Steve Klabnik 已提交
2172 2173 2174 2175 2176
* `linkage` - Allows use of the `linkage` attribute, which is not portable.

* `log_syntax` - Allows use of the `log_syntax` macro attribute, which is a
                 nasty hack that will certainly be removed.

2177
* `main` - Allows use of the `#[main]` attribute, which changes the entry point
L
Luke Gallagher 已提交
2178
           into a Rust program. This capability is subject to change.
2179 2180 2181 2182 2183 2184

* `macro_reexport` - Allows macros to be re-exported from one crate after being imported
                     from another. This feature was originally designed with the sole
                     use case of the Rust standard library in mind, and is subject to
                     change.

S
Steve Klabnik 已提交
2185 2186 2187 2188 2189 2190
* `non_ascii_idents` - The compiler supports the use of non-ascii identifiers,
                       but the implementation is a little rough around the
                       edges, so this can be seen as an experimental feature
                       for now until the specification of identifiers is fully
                       fleshed out.

2191 2192 2193 2194 2195 2196 2197 2198 2199 2200 2201 2202 2203
* `no_std` - Allows the `#![no_std]` crate attribute, which disables the implicit
             `extern crate std`. This typically requires use of the unstable APIs
             behind the libstd "facade", such as libcore and libcollections. It
             may also cause problems when using syntax extensions, including
             `#[derive]`.

* `on_unimplemented` - Allows the `#[rustc_on_unimplemented]` attribute, which allows
                       trait definitions to add specialized notes to error messages
                       when an implementation was expected but not found.

* `optin_builtin_traits` - Allows the definition of default and negative trait
                           implementations. Experimental.

K
Keegan McAllister 已提交
2204 2205
* `plugin` - Usage of [compiler plugins][plugin] for custom lints or syntax extensions.
             These depend on compiler internals and are subject to change.
S
Steve Klabnik 已提交
2206

K
Keegan McAllister 已提交
2207
* `plugin_registrar` - Indicates that a crate provides [compiler plugins][plugin].
S
Steve Klabnik 已提交
2208 2209 2210 2211 2212

* `quote` - Allows use of the `quote_*!` family of macros, which are
            implemented very poorly and will likely change significantly
            with a proper implementation.

2213 2214 2215
* `rustc_attrs` - Gates internal `#[rustc_*]` attributes which may be
                  for internal use only or have meaning added to them in the future.

S
Steve Klabnik 已提交
2216 2217 2218 2219 2220 2221
* `rustc_diagnostic_macros`- A mysterious feature, used in the implementation
                             of rustc, not meant for mortals.

* `simd` - Allows use of the `#[simd]` attribute, which is overly simple and
           not the SIMD interface we want to expose in the long term.

2222 2223 2224
* `simd_ffi` - Allows use of SIMD vectors in signatures for foreign functions.
               The SIMD interface is subject to change.

2225 2226 2227
* `staged_api` - Allows usage of stability markers and `#![staged_api]` in a
                 crate. Stability markers are also attributes: `#[stable]`,
                 `#[unstable]`, and `#[deprecated]` are the three levels.
2228

H
Huon Wilson 已提交
2229 2230 2231 2232 2233 2234
* `static_assert` - The `#[static_assert]` functionality is experimental and
                    unstable. The attribute can be attached to a `static` of
                    type `bool` and the compiler will error if the `bool` is
                    `false` at compile time. This version of this functionality
                    is unintuitive and suboptimal.

2235
* `start` - Allows use of the `#[start]` attribute, which changes the entry point
L
Luke Gallagher 已提交
2236
            into a Rust program. This capability, especially the signature for the
2237 2238
            annotated function, is subject to change.

S
Steve Klabnik 已提交
2239 2240 2241 2242 2243 2244 2245 2246 2247 2248 2249 2250 2251 2252 2253
* `struct_inherit` - Allows using struct inheritance, which is barely
                     implemented and will probably be removed. Don't use this.

* `struct_variant` - Structural enum variants (those with named fields). It is
                     currently unknown whether this style of enum variant is as
                     fully supported as the tuple-forms, and it's not certain
                     that this style of variant should remain in the language.
                     For now this style of variant is hidden behind a feature
                     flag.

* `thread_local` - The usage of the `#[thread_local]` attribute is experimental
                   and should be seen as unstable. This attribute is used to
                   declare a `static` as being unique per-thread leveraging
                   LLVM's implementation which works in concert with the kernel
                   loader and dynamic linker. This is not necessarily available
S
Steve Klabnik 已提交
2254
                   on all platforms, and usage of it is discouraged.
S
Steve Klabnik 已提交
2255 2256 2257 2258

* `trace_macros` - Allows use of the `trace_macros` macro, which is a nasty
                   hack that will certainly be removed.

2259 2260
* `unboxed_closures` - Rust's new closure design, which is currently a work in
                       progress feature with many known bugs.
S
Steve Klabnik 已提交
2261 2262 2263 2264 2265

* `unsafe_destructor` - Allows use of the `#[unsafe_destructor]` attribute,
                        which is considered wildly unsafe and will be
                        obsoleted by language improvements.

2266 2267 2268 2269 2270 2271
* `unsafe_no_drop_flag` - Allows use of the `#[unsafe_no_drop_flag]` attribute,
                          which removes hidden flag added to a type that
                          implements the `Drop` trait. The design for the
                          `Drop` flag is subject to change, and this feature
                          may be removed in the future.

2272 2273 2274 2275 2276
* `unmarked_api` - Allows use of items within a `#![staged_api]` crate
                   which have not been marked with a stability marker.
                   Such items should not be allowed by the compiler to exist,
                   so if you need this there probably is a compiler bug.

2277 2278 2279
* `visible_private_types` - Allows public APIs to expose otherwise private
                            types, e.g. as the return type of a public function.
                            This capability may be removed in the future.
K
Keegan McAllister 已提交
2280

2281 2282 2283 2284 2285 2286 2287 2288
* `allow_internal_unstable` - Allows `macro_rules!` macros to be tagged with the
                              `#[allow_internal_unstable]` attribute, designed
                              to allow `std` macros to call
                              `#[unstable]`/feature-gated functionality
                              internally without imposing on callers
                              (i.e. making them behave like function calls in
                              terms of encapsulation).

S
Steve Klabnik 已提交
2289
If a feature is promoted to a language feature, then all existing programs will
2290
start to receive compilation warnings about `#![feature]` directives which enabled
S
Steve Klabnik 已提交
2291 2292 2293 2294 2295 2296
the new feature (because the directive is no longer necessary). However, if a
feature is decided to be removed from the language, errors will be issued (if
there isn't a parser error first). The directive in this case is no longer
necessary, and it's likely that existing code will break if the feature isn't
removed.

A
Alex Gaynor 已提交
2297
If an unknown feature is found in a directive, it results in a compiler error.
S
Steve Klabnik 已提交
2298 2299 2300 2301 2302 2303 2304 2305 2306 2307 2308 2309 2310 2311 2312 2313 2314 2315 2316 2317 2318 2319 2320 2321 2322 2323
An unknown feature is one which has never been recognized by the compiler.

# Statements and expressions

Rust is _primarily_ an expression language. This means that most forms of
value-producing or effect-causing evaluation are directed by the uniform syntax
category of _expressions_. Each kind of expression can typically _nest_ within
each other kind of expression, and rules for evaluation of expressions involve
specifying both the value produced by the expression and the order in which its
sub-expressions are themselves evaluated.

In contrast, statements in Rust serve _mostly_ to contain and explicitly
sequence expression evaluation.

## Statements

A _statement_ is a component of a block, which is in turn a component of an
outer [expression](#expressions) or [function](#functions).

Rust has two kinds of statement: [declaration
statements](#declaration-statements) and [expression
statements](#expression-statements).

### Declaration statements

A _declaration statement_ is one that introduces one or more *names* into the
2324
enclosing statement block. The declared names may denote new variables or new
S
Steve Klabnik 已提交
2325 2326 2327 2328 2329 2330 2331 2332 2333 2334 2335 2336 2337 2338
items.

#### Item declarations

An _item declaration statement_ has a syntactic form identical to an
[item](#items) declaration within a module. Declaring an item &mdash; a
function, enumeration, structure, type, static, trait, implementation or module
&mdash; locally within a statement block is simply a way of restricting its
scope to a narrow region containing all of its uses; it is otherwise identical
in meaning to declaring the item outside the statement block.

> **Note**: there is no implicit capture of the function's dynamic environment when
> declaring a function-local item.

2339
#### Variable declarations
S
Steve Klabnik 已提交
2340

2341
A _variable declaration_ introduces a new set of variable, given by a pattern. The
S
Steve Klabnik 已提交
2342 2343 2344
pattern may be followed by a type annotation, and/or an initializer expression.
When no type annotation is given, the compiler will infer the type, or signal
an error if insufficient type information is available for definite inference.
2345
Any variables introduced by a variable declaration are visible from the point of
S
Steve Klabnik 已提交
2346 2347 2348 2349 2350
declaration until the end of the enclosing block scope.

### Expression statements

An _expression statement_ is one that evaluates an [expression](#expressions)
S
Steve Klabnik 已提交
2351 2352
and ignores its result. The type of an expression statement `e;` is always
`()`, regardless of the type of `e`. As a rule, an expression statement's
S
Steve Klabnik 已提交
2353 2354 2355 2356 2357
purpose is to trigger the effects of evaluating its expression.

## Expressions

An expression may have two roles: it always produces a *value*, and it may have
S
Steve Klabnik 已提交
2358 2359 2360
*effects* (otherwise known as "side effects"). An expression *evaluates to* a
value, and has effects during *evaluation*. Many expressions contain
sub-expressions (operands). The meaning of each kind of expression dictates
S
Steve Klabnik 已提交
2361
several things:
2362 2363 2364 2365

* Whether or not to evaluate the sub-expressions when evaluating the expression
* The order in which to evaluate the sub-expressions
* How to combine the sub-expressions' values to obtain the value of the expression
S
Steve Klabnik 已提交
2366 2367 2368 2369 2370 2371 2372 2373 2374

In this way, the structure of expressions dictates the structure of execution.
Blocks are just another kind of expression, so blocks, statements, expressions,
and blocks again can recursively nest inside each other to an arbitrary depth.

#### Lvalues, rvalues and temporaries

Expressions are divided into two main categories: _lvalues_ and _rvalues_.
Likewise within each expression, sub-expressions may occur in _lvalue context_
S
Steve Klabnik 已提交
2375
or _rvalue context_. The evaluation of an expression depends both on its own
S
Steve Klabnik 已提交
2376 2377 2378 2379 2380 2381
category and the context it occurs within.

An lvalue is an expression that represents a memory location. These expressions
are [paths](#path-expressions) (which refer to local variables, function and
method arguments, or static variables), dereferences (`*expr`), [indexing
expressions](#index-expressions) (`expr[expr]`), and [field
S
Steve Klabnik 已提交
2382
references](#field-expressions) (`expr.f`). All other expressions are rvalues.
S
Steve Klabnik 已提交
2383 2384 2385 2386

The left operand of an [assignment](#assignment-expressions) or
[compound-assignment](#compound-assignment-expressions) expression is an lvalue
context, as is the single operand of a unary
S
Steve Klabnik 已提交
2387
[borrow](#unary-operator-expressions). All other expression contexts are
S
Steve Klabnik 已提交
2388 2389 2390 2391 2392 2393
rvalue contexts.

When an lvalue is evaluated in an _lvalue context_, it denotes a memory
location; when evaluated in an _rvalue context_, it denotes the value held _in_
that memory location.

A
Alex Gaynor 已提交
2394
When an rvalue is used in an lvalue context, a temporary un-named lvalue is
S
Steve Klabnik 已提交
2395
created and used instead. A temporary's lifetime equals the largest lifetime
S
Steve Klabnik 已提交
2396 2397 2398 2399
of any reference that points to it.

#### Moved and copied types

2400
When a [local variable](#variables) is used as an
S
Steve Klabnik 已提交
2401
[rvalue](#lvalues,-rvalues-and-temporaries) the variable will either be moved
2402 2403
or copied, depending on its type. All values whose type implements `Copy` are
copied, all others are moved.
S
Steve Klabnik 已提交
2404 2405 2406 2407 2408 2409 2410

### Literal expressions

A _literal expression_ consists of one of the [literal](#literals) forms
described earlier. It directly describes a number, character, string, boolean
value, or the unit value.

S
Steve Klabnik 已提交
2411
```{.literals}
S
Steve Klabnik 已提交
2412 2413 2414 2415
();        // unit type
"hello";   // string type
'5';       // character type
5;         // integer type
S
Steve Klabnik 已提交
2416
```
S
Steve Klabnik 已提交
2417 2418 2419 2420

### Path expressions

A [path](#paths) used as an expression context denotes either a local variable
S
Steve Klabnik 已提交
2421
or an item. Path expressions are [lvalues](#lvalues,-rvalues-and-temporaries).
S
Steve Klabnik 已提交
2422 2423 2424

### Tuple expressions

J
Jakub Bukaj 已提交
2425
Tuples are written by enclosing zero or more comma-separated expressions in
S
Steve Klabnik 已提交
2426 2427
parentheses. They are used to create [tuple-typed](#tuple-types) values.

S
Steve Klabnik 已提交
2428
```{.tuple}
S
Steve Klabnik 已提交
2429
(0.0, 4.5);
2430
("a", 4usize, true);
S
Steve Klabnik 已提交
2431
```
S
Steve Klabnik 已提交
2432

S
Steve Klabnik 已提交
2433 2434 2435 2436 2437 2438 2439 2440
You can disambiguate a single-element tuple from a value in parentheses with a
comma:

```
(0,); // single-element tuple
(0); // zero in parentheses
```

S
Steve Klabnik 已提交
2441 2442
### Structure expressions

S
Steve Klabnik 已提交
2443
There are several forms of structure expressions. A _structure expression_
S
Steve Klabnik 已提交
2444 2445
consists of the [path](#paths) of a [structure item](#structures), followed by
a brace-enclosed list of one or more comma-separated name-value pairs,
S
Steve Klabnik 已提交
2446
providing the field values of a new instance of the structure. A field name
S
Steve Klabnik 已提交
2447 2448 2449 2450 2451 2452 2453
can be any identifier, and is separated from its value expression by a colon.
The location denoted by a structure field is mutable if and only if the
enclosing structure is mutable.

A _tuple structure expression_ consists of the [path](#paths) of a [structure
item](#structures), followed by a parenthesized list of one or more
comma-separated expressions (in other words, the path of a structure item
S
Steve Klabnik 已提交
2454
followed by a tuple expression). The structure item must be a tuple structure
S
Steve Klabnik 已提交
2455 2456 2457 2458 2459 2460 2461
item.

A _unit-like structure expression_ consists only of the [path](#paths) of a
[structure item](#structures).

The following are examples of structure expressions:

S
Steve Klabnik 已提交
2462
```
S
Steve Klabnik 已提交
2463 2464
# struct Point { x: f64, y: f64 }
# struct TuplePoint(f64, f64);
2465
# mod game { pub struct User<'a> { pub name: &'a str, pub age: u32, pub score: usize } }
S
Steve Klabnik 已提交
2466 2467 2468 2469 2470
# struct Cookie; fn some_fn<T>(t: T) {}
Point {x: 10.0, y: 20.0};
TuplePoint(10.0, 20.0);
let u = game::User {name: "Joe", age: 35, score: 100_000};
some_fn::<Cookie>(Cookie);
S
Steve Klabnik 已提交
2471
```
S
Steve Klabnik 已提交
2472

S
Steve Klabnik 已提交
2473
A structure expression forms a new value of the named structure type. Note
S
Steve Klabnik 已提交
2474 2475 2476 2477
that for a given *unit-like* structure type, this will always be the same
value.

A structure expression can terminate with the syntax `..` followed by an
S
Steve Klabnik 已提交
2478
expression to denote a functional update. The expression following `..` (the
S
Steve Klabnik 已提交
2479 2480 2481 2482 2483 2484
base) must have the same structure type as the new structure type being formed.
The entire expression denotes the result of constructing a new structure (with
the same type as the base expression) with the given values for the fields that
were explicitly specified and the values in the base expression for all other
fields.

S
Steve Klabnik 已提交
2485
```
2486
# struct Point3d { x: i32, y: i32, z: i32 }
S
Steve Klabnik 已提交
2487 2488
let base = Point3d {x: 1, y: 2, z: 3};
Point3d {y: 0, z: 10, .. base};
S
Steve Klabnik 已提交
2489
```
S
Steve Klabnik 已提交
2490 2491 2492 2493

### Block expressions

A _block expression_ is similar to a module in terms of the declarations that
2494
are possible. Each block conceptually introduces a new namespace scope. Use
S
Steve Klabnik 已提交
2495 2496 2497 2498
items can bring new names into scopes and declared items are in scope for only
the block itself.

A block will execute each statement sequentially, and then execute the
2499 2500 2501 2502 2503 2504 2505 2506 2507 2508 2509 2510 2511
expression (if given). If the block ends in a statement, its value is `()`:

```
let x: () = { println!("Hello."); };
```

If it ends in an expression, its value and type are that of the expression:

```
let x: i32 = { println!("Hello."); 5 };

assert_eq!(5, x);
```
S
Steve Klabnik 已提交
2512 2513 2514 2515

### Method-call expressions

A _method call_ consists of an expression followed by a single dot, an
S
Steve Klabnik 已提交
2516
identifier, and a parenthesized expression-list. Method calls are resolved to
S
Steve Klabnik 已提交
2517 2518
methods on specific traits, either statically dispatching to a method if the
exact `self`-type of the left-hand-side is known, or dynamically dispatching if
N
nwin 已提交
2519
the left-hand-side expression is an indirect [trait object](#trait-objects).
S
Steve Klabnik 已提交
2520 2521 2522 2523 2524

### Field expressions

A _field expression_ consists of an expression followed by a single dot and an
identifier, when not immediately followed by a parenthesized expression-list
S
Steve Klabnik 已提交
2525
(the latter is a [method call expression](#method-call-expressions)). A field
S
Steve Klabnik 已提交
2526 2527
expression denotes a field of a [structure](#structure-types).

S
Steve Klabnik 已提交
2528
```{.ignore .field}
S
Steve Klabnik 已提交
2529 2530 2531
mystruct.myfield;
foo().x;
(Struct {a: 10, b: 20}).a;
S
Steve Klabnik 已提交
2532
```
S
Steve Klabnik 已提交
2533 2534

A field access is an [lvalue](#lvalues,-rvalues-and-temporaries) referring to
A
Alex Gaynor 已提交
2535
the value of that field. When the type providing the field inherits mutability,
S
Steve Klabnik 已提交
2536 2537 2538 2539 2540 2541 2542
it can be [assigned](#assignment-expressions) to.

Also, if the type of the expression to the left of the dot is a pointer, it is
automatically dereferenced to make the field access possible.

### Array expressions

S
Steve Klabnik 已提交
2543 2544
An [array](#array,-and-slice-types) _expression_ is written by enclosing zero
or more comma-separated expressions of uniform type in square brackets.
S
Steve Klabnik 已提交
2545

A
Armin Preiml 已提交
2546
In the `[expr ';' expr]` form, the expression after the `';'` must be a
S
Steve Klabnik 已提交
2547 2548 2549
constant expression that can be evaluated at compile time, such as a
[literal](#literals) or a [static item](#static-items).

S
Steve Klabnik 已提交
2550
```
2551
[1, 2, 3, 4];
S
Steve Klabnik 已提交
2552
["a", "b", "c", "d"];
2553
[0; 128];              // array with 128 zeros
S
Steve Klabnik 已提交
2554
[0u8, 0u8, 0u8, 0u8];
S
Steve Klabnik 已提交
2555
```
S
Steve Klabnik 已提交
2556 2557 2558

### Index expressions

S
Steve Klabnik 已提交
2559
[Array](#array,-and-slice-types)-typed expressions can be indexed by
S
Steve Klabnik 已提交
2560 2561 2562 2563 2564
writing a square-bracket-enclosed expression (the index) after them. When the
array is mutable, the resulting [lvalue](#lvalues,-rvalues-and-temporaries) can
be assigned to.

Indices are zero-based, and may be of any integral type. Vector access is
2565 2566
bounds-checked at compile-time for constant arrays being accessed with a constant index value.
Otherwise a check will be performed at run-time that will put the thread in a _panicked state_ if it fails.
S
Steve Klabnik 已提交
2567

S
Steve Klabnik 已提交
2568
```{should-fail}
S
Steve Klabnik 已提交
2569
([1, 2, 3, 4])[0];
2570 2571 2572 2573 2574 2575 2576 2577

let x = (["a", "b"])[10]; // compiler error: const index-expr is out of bounds

let n = 10;
let y = (["a", "b"])[n]; // panics

let arr = ["a", "b"];
arr[10]; // panics
S
Steve Klabnik 已提交
2578
```
S
Steve Klabnik 已提交
2579

T
tynopex 已提交
2580 2581 2582 2583 2584 2585 2586 2587 2588 2589 2590 2591 2592 2593 2594 2595 2596 2597 2598 2599
### Range expressions

The `..` operator will construct an object of one of the `std::ops::Range` variants.

```
1..2;   // std::ops::Range
3..;    // std::ops::RangeFrom
..4;    // std::ops::RangeTo
..;     // std::ops::RangeFull
```

The following expressions are equivalent.

```
let x = std::ops::Range {start: 0, end: 10};
let y = 0..10;

assert_eq!(x,y);
```

S
Steve Klabnik 已提交
2600 2601
### Unary operator expressions

2602 2603
Rust defines three unary operators. They are all written as prefix operators,
before the expression they apply to.
S
Steve Klabnik 已提交
2604 2605 2606 2607 2608

* `-`
  : Negation. May only be applied to numeric types.
* `*`
  : Dereference. When applied to a [pointer](#pointer-types) it denotes the
S
Steve Klabnik 已提交
2609
    pointed-to location. For pointers to mutable locations, the resulting
S
Steve Klabnik 已提交
2610 2611 2612 2613 2614 2615 2616 2617 2618 2619 2620 2621 2622 2623 2624 2625 2626 2627 2628 2629
    [lvalue](#lvalues,-rvalues-and-temporaries) can be assigned to.
    On non-pointer types, it calls the `deref` method of the `std::ops::Deref`
    trait, or the `deref_mut` method of the `std::ops::DerefMut` trait (if
    implemented by the type and required for an outer expression that will or
    could mutate the dereference), and produces the result of dereferencing the
    `&` or `&mut` borrowed pointer returned from the overload method.

* `!`
  : Logical negation. On the boolean type, this flips between `true` and
    `false`. On integer types, this inverts the individual bits in the
    two's complement representation of the value.

### Binary operator expressions

Binary operators expressions are given in terms of [operator
precedence](#operator-precedence).

#### Arithmetic operators

Binary arithmetic expressions are syntactic sugar for calls to built-in traits,
S
Steve Klabnik 已提交
2630 2631
defined in the `std::ops` module of the `std` library. This means that
arithmetic operators can be overridden for user-defined types. The default
S
Steve Klabnik 已提交
2632 2633 2634 2635 2636 2637 2638 2639 2640 2641 2642 2643 2644 2645 2646 2647 2648 2649 2650 2651 2652
meaning of the operators on standard types is given here.

* `+`
  : Addition and array/string concatenation.
    Calls the `add` method on the `std::ops::Add` trait.
* `-`
  : Subtraction.
    Calls the `sub` method on the `std::ops::Sub` trait.
* `*`
  : Multiplication.
    Calls the `mul` method on the `std::ops::Mul` trait.
* `/`
  : Quotient.
    Calls the `div` method on the `std::ops::Div` trait.
* `%`
  : Remainder.
    Calls the `rem` method on the `std::ops::Rem` trait.

#### Bitwise operators

Like the [arithmetic operators](#arithmetic-operators), bitwise operators are
S
Steve Klabnik 已提交
2653 2654
syntactic sugar for calls to methods of built-in traits. This means that
bitwise operators can be overridden for user-defined types. The default
S
Steve Klabnik 已提交
2655 2656 2657 2658 2659 2660 2661 2662 2663 2664 2665 2666
meaning of the operators on standard types is given here.

* `&`
  : And.
    Calls the `bitand` method of the `std::ops::BitAnd` trait.
* `|`
  : Inclusive or.
    Calls the `bitor` method of the `std::ops::BitOr` trait.
* `^`
  : Exclusive or.
    Calls the `bitxor` method of the `std::ops::BitXor` trait.
* `<<`
S
Steve Klabnik 已提交
2667
  : Left shift.
S
Steve Klabnik 已提交
2668 2669
    Calls the `shl` method of the `std::ops::Shl` trait.
* `>>`
S
Steve Klabnik 已提交
2670
  : Right shift.
S
Steve Klabnik 已提交
2671 2672 2673 2674
    Calls the `shr` method of the `std::ops::Shr` trait.

#### Lazy boolean operators

S
Steve Klabnik 已提交
2675
The operators `||` and `&&` may be applied to operands of boolean type. The
S
Steve Klabnik 已提交
2676
`||` operator denotes logical 'or', and the `&&` operator denotes logical
S
Steve Klabnik 已提交
2677
'and'. They differ from `|` and `&` in that the right-hand operand is only
S
Steve Klabnik 已提交
2678
evaluated when the left-hand operand does not already determine the result of
S
Steve Klabnik 已提交
2679
the expression. That is, `||` only evaluates its right-hand operand when the
S
Steve Klabnik 已提交
2680 2681 2682 2683 2684 2685 2686
left-hand operand evaluates to `false`, and `&&` only when it evaluates to
`true`.

#### Comparison operators

Comparison operators are, like the [arithmetic
operators](#arithmetic-operators), and [bitwise operators](#bitwise-operators),
S
Steve Klabnik 已提交
2687 2688
syntactic sugar for calls to built-in traits. This means that comparison
operators can be overridden for user-defined types. The default meaning of the
S
Steve Klabnik 已提交
2689 2690 2691 2692 2693 2694 2695 2696 2697 2698 2699 2700 2701 2702 2703 2704 2705 2706 2707 2708 2709 2710 2711 2712 2713 2714 2715 2716 2717 2718
operators on standard types is given here.

* `==`
  : Equal to.
    Calls the `eq` method on the `std::cmp::PartialEq` trait.
* `!=`
  : Unequal to.
    Calls the `ne` method on the `std::cmp::PartialEq` trait.
* `<`
  : Less than.
    Calls the `lt` method on the `std::cmp::PartialOrd` trait.
* `>`
  : Greater than.
    Calls the `gt` method on the `std::cmp::PartialOrd` trait.
* `<=`
  : Less than or equal.
    Calls the `le` method on the `std::cmp::PartialOrd` trait.
* `>=`
  : Greater than or equal.
    Calls the `ge` method on the `std::cmp::PartialOrd` trait.

#### Type cast expressions

A type cast expression is denoted with the binary operator `as`.

Executing an `as` expression casts the value on the left-hand side to the type
on the right-hand side.

An example of an `as` expression:

S
Steve Klabnik 已提交
2719
```
S
Steve Klabnik 已提交
2720
# fn sum(v: &[f64]) -> f64 { 0.0 }
2721
# fn len(v: &[f64]) -> i32 { 0 }
S
Steve Klabnik 已提交
2722 2723 2724 2725 2726 2727

fn avg(v: &[f64]) -> f64 {
  let sum: f64 = sum(v);
  let sz: f64 = len(v) as f64;
  return sum / sz;
}
S
Steve Klabnik 已提交
2728
```
S
Steve Klabnik 已提交
2729 2730 2731 2732 2733 2734 2735 2736 2737 2738 2739

#### Assignment expressions

An _assignment expression_ consists of an
[lvalue](#lvalues,-rvalues-and-temporaries) expression followed by an equals
sign (`=`) and an [rvalue](#lvalues,-rvalues-and-temporaries) expression.

Evaluating an assignment expression [either copies or
moves](#moved-and-copied-types) its right-hand operand to its left-hand
operand.

S
Steve Klabnik 已提交
2740
```
2741
# let mut x = 0;
S
Steve Klabnik 已提交
2742 2743 2744
# let y = 0;

x = y;
S
Steve Klabnik 已提交
2745
```
S
Steve Klabnik 已提交
2746 2747 2748 2749 2750 2751 2752 2753 2754 2755 2756 2757 2758 2759

#### Compound assignment expressions

The `+`, `-`, `*`, `/`, `%`, `&`, `|`, `^`, `<<`, and `>>` operators may be
composed with the `=` operator. The expression `lval OP= val` is equivalent to
`lval = lval OP val`. For example, `x = x + 1` may be written as `x += 1`.

Any such expression always has the [`unit`](#primitive-types) type.

#### Operator precedence

The precedence of Rust binary operators is ordered as follows, going from
strong to weak:

S
Steve Klabnik 已提交
2760
```{.text .precedence}
S
Steve Klabnik 已提交
2761
as
2762
* / %
S
Steve Klabnik 已提交
2763 2764 2765 2766 2767
+ -
<< >>
&
^
|
2768
== != < > <= >=
S
Steve Klabnik 已提交
2769 2770
&&
||
2771
= ..
S
Steve Klabnik 已提交
2772
```
S
Steve Klabnik 已提交
2773 2774

Operators at the same precedence level are evaluated left-to-right. [Unary
A
Alfie John 已提交
2775 2776
operators](#unary-operator-expressions) have the same precedence level and are
stronger than any of the binary operators.
S
Steve Klabnik 已提交
2777 2778 2779 2780

### Grouped expressions

An expression enclosed in parentheses evaluates to the result of the enclosed
S
Steve Klabnik 已提交
2781
expression. Parentheses can be used to explicitly specify evaluation order
S
Steve Klabnik 已提交
2782 2783 2784 2785
within an expression.

An example of a parenthesized expression:

S
Steve Klabnik 已提交
2786
```
2787
let x: i32 = (2 + 3) * 4;
S
Steve Klabnik 已提交
2788
```
S
Steve Klabnik 已提交
2789 2790 2791 2792


### Call expressions

2793 2794 2795
A _call expression_ invokes a function, providing zero or more input variables
and an optional location to move the function's output into. If the function
eventually returns, then the expression completes.
S
Steve Klabnik 已提交
2796 2797 2798

Some examples of call expressions:

S
Steve Klabnik 已提交
2799
```
2800
# fn add(x: i32, y: i32) -> i32 { 0 }
S
Steve Klabnik 已提交
2801

2802
let x: i32 = add(1i32, 2i32);
2803
let pi: Result<f32, _> = "3.14".parse();
S
Steve Klabnik 已提交
2804
```
S
Steve Klabnik 已提交
2805 2806 2807 2808

### Lambda expressions

A _lambda expression_ (sometimes called an "anonymous function expression")
S
Steve Klabnik 已提交
2809
defines a function and denotes it as a value, in a single expression. A lambda
S
Steve Klabnik 已提交
2810 2811 2812 2813
expression is a pipe-symbol-delimited (`|`) list of identifiers followed by an
expression.

A lambda expression denotes a function that maps a list of parameters
S
Steve Klabnik 已提交
2814 2815
(`ident_list`) onto the expression that follows the `ident_list`. The
identifiers in the `ident_list` are the parameters to the function. These
S
Steve Klabnik 已提交
2816 2817 2818 2819 2820 2821 2822
parameters' types need not be specified, as the compiler infers them from
context.

Lambda expressions are most useful when passing functions as arguments to other
functions, as an abbreviation for defining and capturing a separate function.

Significantly, lambda expressions _capture their environment_, which regular
S
Steve Klabnik 已提交
2823 2824
[function definitions](#functions) do not. The exact type of capture depends
on the [function type](#function-types) inferred for the lambda expression. In
S
Steve Klabnik 已提交
2825 2826 2827 2828
the simplest and least-expensive form (analogous to a ```|| { }``` expression),
the lambda expression captures its environment by reference, effectively
borrowing pointers to all outer variables mentioned inside the function.
Alternately, the compiler may infer that a lambda expression should copy or
2829
move values (depending on their type) from the environment into the lambda
S
Steve Klabnik 已提交
2830 2831 2832
expression's captured environment.

In this example, we define a function `ten_times` that takes a higher-order
2833
function argument, and call it with a lambda expression as an argument:
S
Steve Klabnik 已提交
2834

2835
```
2836 2837
fn ten_times<F>(f: F) where F: Fn(i32) {
    let mut i = 0i32;
S
Steve Klabnik 已提交
2838 2839 2840 2841 2842 2843 2844
    while i < 10 {
        f(i);
        i += 1;
    }
}

ten_times(|j| println!("hello, {}", j));
S
Steve Klabnik 已提交
2845
```
S
Steve Klabnik 已提交
2846 2847 2848 2849 2850

### Infinite loops

A `loop` expression denotes an infinite loop.

L
Lee Aronson 已提交
2851 2852 2853 2854 2855
A `loop` expression may optionally have a _label_. The label is written as
a lifetime preceding the loop expression, as in `'foo: loop{ }`. If a
label is present, then labeled `break` and `continue` expressions nested
within this loop may exit out of this loop or return control to its head.
See [Break expressions](#break-expressions) and [Continue
S
Steve Klabnik 已提交
2856 2857 2858 2859
expressions](#continue-expressions).

### Break expressions

S
Steve Klabnik 已提交
2860
A `break` expression has an optional _label_. If the label is absent, then
S
Steve Klabnik 已提交
2861
executing a `break` expression immediately terminates the innermost loop
S
Steve Klabnik 已提交
2862
enclosing it. It is only permitted in the body of a loop. If the label is
L
Lee Aronson 已提交
2863
present, then `break 'foo` terminates the loop with label `'foo`, which need not
S
Steve Klabnik 已提交
2864 2865 2866 2867
be the innermost label enclosing the `break` expression, but must enclose it.

### Continue expressions

S
Steve Klabnik 已提交
2868
A `continue` expression has an optional _label_. If the label is absent, then
S
Steve Klabnik 已提交
2869
executing a `continue` expression immediately terminates the current iteration
S
Steve Klabnik 已提交
2870
of the innermost loop enclosing it, returning control to the loop *head*. In
S
Steve Klabnik 已提交
2871
the case of a `while` loop, the head is the conditional expression controlling
S
Steve Klabnik 已提交
2872
the loop. In the case of a `for` loop, the head is the call-expression
L
Lee Aronson 已提交
2873 2874
controlling the loop. If the label is present, then `continue 'foo` returns
control to the head of the loop with label `'foo`, which need not be the
S
Steve Klabnik 已提交
2875 2876 2877 2878
innermost label enclosing the `break` expression, but must enclose it.

A `continue` expression is only permitted in the body of a loop.

L
Lee Aronson 已提交
2879 2880 2881 2882 2883 2884 2885 2886 2887 2888 2889 2890 2891 2892 2893 2894 2895 2896 2897 2898 2899 2900 2901
### While loops

A `while` loop begins by evaluating the boolean loop conditional expression.
If the loop conditional expression evaluates to `true`, the loop body block
executes and control returns to the loop conditional expression. If the loop
conditional expression evaluates to `false`, the `while` expression completes.

An example:

```
let mut i = 0;

while i < 10 {
    println!("hello");
    i = i + 1;
}
```

Like `loop` expressions, `while` loops can be controlled with `break` or
`continue`, and may optionally have a _label_. See [infinite
loops](#infinite-loops), [break expressions](#break-expressions), and
[continue expressions](#continue-expressions) for more information.

S
Steve Klabnik 已提交
2902 2903 2904
### For expressions

A `for` expression is a syntactic construct for looping over elements provided
2905
by an implementation of `std::iter::IntoIterator`.
S
Steve Klabnik 已提交
2906 2907 2908

An example of a for loop over the contents of an array:

S
Steve Klabnik 已提交
2909
```
2910
# type Foo = i32;
2911
# fn bar(f: &Foo) { }
S
Steve Klabnik 已提交
2912 2913 2914 2915 2916 2917
# let a = 0;
# let b = 0;
# let c = 0;

let v: &[Foo] = &[a, b, c];

2918 2919
for e in v {
    bar(e);
S
Steve Klabnik 已提交
2920
}
S
Steve Klabnik 已提交
2921
```
S
Steve Klabnik 已提交
2922 2923 2924

An example of a for loop over a series of integers:

S
Steve Klabnik 已提交
2925
```
2926
# fn bar(b:usize) { }
2927
for i in 0..256 {
S
Steve Klabnik 已提交
2928 2929
    bar(i);
}
S
Steve Klabnik 已提交
2930
```
S
Steve Klabnik 已提交
2931

L
Lee Aronson 已提交
2932
Like `loop` expressions, `for` loops can be controlled with `break` or
L
Lee Aronson 已提交
2933 2934 2935 2936
`continue`, and may optionally have a _label_. See [infinite
loops](#infinite-loops), [break expressions](#break-expressions), and
[continue expressions](#continue-expressions) for more information.

S
Steve Klabnik 已提交
2937 2938 2939 2940 2941 2942 2943 2944 2945 2946 2947 2948 2949 2950 2951 2952 2953 2954 2955 2956 2957 2958 2959 2960
### If expressions

An `if` expression is a conditional branch in program control. The form of an
`if` expression is a condition expression, followed by a consequent block, any
number of `else if` conditions and blocks, and an optional trailing `else`
block. The condition expressions must have type `bool`. If a condition
expression evaluates to `true`, the consequent block is executed and any
subsequent `else if` or `else` block is skipped. If a condition expression
evaluates to `false`, the consequent block is skipped and any subsequent `else
if` condition is evaluated. If all `if` and `else if` conditions evaluate to
`false` then any `else` block is executed.

### Match expressions

A `match` expression branches on a *pattern*. The exact form of matching that
occurs depends on the pattern. Patterns consist of some combination of
literals, destructured arrays or enum constructors, structures and tuples,
variable binding specifications, wildcards (`..`), and placeholders (`_`). A
`match` expression has a *head expression*, which is the value to compare to
the patterns. The type of the patterns must equal the type of the head
expression.

In a pattern whose head expression has an `enum` type, a placeholder (`_`)
stands for a *single* data field, whereas a wildcard `..` stands for *all* the
2961
fields of a particular variant.
S
Steve Klabnik 已提交
2962 2963

A `match` behaves differently depending on whether or not the head expression
S
Steve Klabnik 已提交
2964
is an [lvalue or an rvalue](#lvalues,-rvalues-and-temporaries). If the head
S
Steve Klabnik 已提交
2965 2966 2967 2968 2969 2970 2971 2972 2973 2974 2975 2976 2977 2978
expression is an rvalue, it is first evaluated into a temporary location, and
the resulting value is sequentially compared to the patterns in the arms until
a match is found. The first arm with a matching pattern is chosen as the branch
target of the `match`, any variables bound by the pattern are assigned to local
variables in the arm's block, and control enters the block.

When the head expression is an lvalue, the match does not allocate a temporary
location (however, a by-value binding may copy or move from the lvalue). When
possible, it is preferable to match on lvalues, as the lifetime of these
matches inherits the lifetime of the lvalue, rather than being restricted to
the inside of the match.

An example of a `match` expression:

S
Steve Klabnik 已提交
2979
```
2980
let x = 1;
S
Steve Klabnik 已提交
2981

2982 2983 2984 2985 2986 2987 2988
match x {
    1 => println!("one"),
    2 => println!("two"),
    3 => println!("three"),
    4 => println!("four"),
    5 => println!("five"),
    _ => println!("something else"),
S
Steve Klabnik 已提交
2989
}
S
Steve Klabnik 已提交
2990
```
S
Steve Klabnik 已提交
2991 2992

Patterns that bind variables default to binding to a copy or move of the
S
Steve Klabnik 已提交
2993
matched value (depending on the matched value's type). This can be changed to
S
Steve Klabnik 已提交
2994 2995 2996 2997 2998 2999
bind to a reference by using the `ref` keyword, or to a mutable reference using
`ref mut`.

Subpatterns can also be bound to variables by the use of the syntax `variable @
subpattern`. For example:

S
Steve Klabnik 已提交
3000
```
3001
let x = 1;
S
Steve Klabnik 已提交
3002

3003 3004 3005
match x {
    e @ 1 ... 5 => println!("got a range element {}", e),
    _ => println!("anything"),
S
Steve Klabnik 已提交
3006
}
S
Steve Klabnik 已提交
3007
```
S
Steve Klabnik 已提交
3008

3009
Patterns can also dereference pointers by using the `&`, `&mut` and `box`
3010
symbols, as appropriate. For example, these two matches on `x: &i32` are
3011
equivalent:
S
Steve Klabnik 已提交
3012

S
Steve Klabnik 已提交
3013
```
3014
# let x = &3;
S
Steve Klabnik 已提交
3015 3016 3017 3018
let y = match *x { 0 => "zero", _ => "some" };
let z = match x { &0 => "zero", _ => "some" };

assert_eq!(y, z);
S
Steve Klabnik 已提交
3019
```
S
Steve Klabnik 已提交
3020 3021

A pattern that's just an identifier, like `Nil` in the previous example, could
S
Steve Klabnik 已提交
3022
either refer to an enum variant that's in scope, or bind a new variable. The
S
Steve Klabnik 已提交
3023
compiler resolves this ambiguity by forbidding variable bindings that occur in
S
Steve Klabnik 已提交
3024
`match` patterns from shadowing names of variants that are in scope. For
S
Steve Klabnik 已提交
3025
example, wherever `List` is in scope, a `match` pattern would not be able to
S
Steve Klabnik 已提交
3026 3027
bind `Nil` as a new name. The compiler interprets a variable pattern `x` as a
binding _only_ if there is no variant named `x` in scope. A convention you can
S
Steve Klabnik 已提交
3028 3029 3030
use to avoid conflicts is simply to name variants with upper-case letters, and
local variables with lower-case letters.

S
Steve Klabnik 已提交
3031
Multiple match patterns may be joined with the `|` operator. A range of values
3032
may be specified with `...`. For example:
S
Steve Klabnik 已提交
3033

S
Steve Klabnik 已提交
3034
```
3035
# let x = 2;
S
Steve Klabnik 已提交
3036 3037 3038

let message = match x {
  0 | 1  => "not many",
3039
  2 ... 9 => "a few",
S
Steve Klabnik 已提交
3040 3041
  _      => "lots"
};
S
Steve Klabnik 已提交
3042
```
S
Steve Klabnik 已提交
3043 3044

Range patterns only work on scalar types (like integers and characters; not
S
Steve Klabnik 已提交
3045
like arrays and structs, which have sub-components). A range pattern may not
S
Steve Klabnik 已提交
3046 3047 3048 3049 3050 3051 3052
be a sub-range of another range pattern inside the same `match`.

Finally, match patterns can accept *pattern guards* to further refine the
criteria for matching a case. Pattern guards appear after the pattern and
consist of a bool-typed expression following the `if` keyword. A pattern guard
may refer to the variables bound within the pattern they follow.

S
Steve Klabnik 已提交
3053
```
S
Steve Klabnik 已提交
3054
# let maybe_digit = Some(0);
3055 3056
# fn process_digit(i: i32) { }
# fn process_other(i: i32) { }
S
Steve Klabnik 已提交
3057 3058 3059 3060

let message = match maybe_digit {
  Some(x) if x < 10 => process_digit(x),
  Some(x) => process_other(x),
S
Steve Klabnik 已提交
3061
  None => panic!()
S
Steve Klabnik 已提交
3062
};
S
Steve Klabnik 已提交
3063
```
S
Steve Klabnik 已提交
3064

J
Jakub Wieczorek 已提交
3065 3066 3067 3068 3069 3070 3071
### If let expressions

An `if let` expression is semantically identical to an `if` expression but in place
of a condition expression it expects a refutable let statement. If the value of the
expression on the right hand side of the let statement matches the pattern, the corresponding
block will execute, otherwise flow proceeds to the first `else` block that follows.

J
Johann Hofmann 已提交
3072 3073
```
let dish = ("Ham", "Eggs");
J
Johann 已提交
3074 3075 3076 3077

// this body will be skipped because the pattern is refuted
if let ("Bacon", b) = dish {
    println!("Bacon is served with {}", b);
J
Johann Hofmann 已提交
3078 3079
}

J
Johann 已提交
3080 3081 3082
// this body will execute
if let ("Ham", b) = dish {
    println!("Ham is served with {}", b);
J
Johann Hofmann 已提交
3083 3084 3085
}
```

J
John Gallagher 已提交
3086 3087 3088 3089 3090 3091 3092 3093
### While let loops

A `while let` loop is semantically identical to a `while` loop but in place of a
condition expression it expects a refutable let statement. If the value of the
expression on the right hand side of the let statement matches the pattern, the
loop body block executes and control returns to the pattern matching statement.
Otherwise, the while expression completes.

S
Steve Klabnik 已提交
3094 3095 3096
### Return expressions

Return expressions are denoted with the keyword `return`. Evaluating a `return`
3097 3098 3099
expression moves its argument into the designated output location for the
current function call, destroys the current function activation frame, and
transfers control to the caller frame.
S
Steve Klabnik 已提交
3100 3101 3102

An example of a `return` expression:

S
Steve Klabnik 已提交
3103
```
3104
fn max(a: i32, b: i32) -> i32 {
S
Steve Klabnik 已提交
3105 3106 3107 3108 3109
   if a > b {
      return a;
   }
   return b;
}
S
Steve Klabnik 已提交
3110
```
S
Steve Klabnik 已提交
3111 3112 3113 3114 3115

# Type system

## Types

3116
Every variable, item and value in a Rust program has a type. The _type_ of a
S
Steve Klabnik 已提交
3117 3118 3119 3120 3121 3122 3123 3124 3125 3126 3127 3128 3129 3130 3131 3132 3133 3134 3135 3136 3137 3138 3139 3140 3141 3142 3143 3144 3145 3146 3147 3148
*value* defines the interpretation of the memory holding it.

Built-in types and type-constructors are tightly integrated into the language,
in nontrivial ways that are not possible to emulate in user-defined types.
User-defined types have limited capabilities.

### Primitive types

The primitive types are the following:

* The boolean type `bool` with values `true` and `false`.
* The machine types.
* The machine-dependent integer and floating-point types.

#### Machine types

The machine types are the following:

* The unsigned word types `u8`, `u16`, `u32` and `u64`, with values drawn from
  the integer intervals [0, 2^8 - 1], [0, 2^16 - 1], [0, 2^32 - 1] and
  [0, 2^64 - 1] respectively.

* The signed two's complement word types `i8`, `i16`, `i32` and `i64`, with
  values drawn from the integer intervals [-(2^(7)), 2^7 - 1],
  [-(2^(15)), 2^15 - 1], [-(2^(31)), 2^31 - 1], [-(2^(63)), 2^63 - 1]
  respectively.

* The IEEE 754-2008 `binary32` and `binary64` floating-point types: `f32` and
  `f64`, respectively.

#### Machine-dependent integer types

3149
The `usize` type is an unsigned integer type with the same number of bits as the
3150 3151
platform's pointer type. It can represent every memory address in the process.

3152
The `isize` type is a signed integer type with the same number of bits as the
3153
platform's pointer type. The theoretical upper bound on object and array size
3154
is the maximum `isize` value. This ensures that `isize` can be used to calculate
3155 3156
differences between pointers into an object or array and can address every byte
within an object along with one byte past the end.
S
Steve Klabnik 已提交
3157 3158 3159 3160 3161 3162

### Textual types

The types `char` and `str` hold textual data.

A value of type `char` is a [Unicode scalar value](
3163
http://www.unicode.org/glossary/#unicode_scalar_value) (i.e. a code point that
S
Steve Klabnik 已提交
3164
is not a surrogate), represented as a 32-bit unsigned word in the 0x0000 to
S
Steve Klabnik 已提交
3165
0xD7FF or 0xE000 to 0x10FFFF range. A `[char]` array is effectively an UCS-4 /
S
Steve Klabnik 已提交
3166 3167
UTF-32 string.

A
Alex Gaynor 已提交
3168
A value of type `str` is a Unicode string, represented as an array of 8-bit
M
Mike Boutin 已提交
3169
unsigned bytes holding a sequence of UTF-8 code points. Since `str` is of
3170
unknown size, it is not a _first-class_ type, but can only be instantiated
3171
through a pointer type, such as `&str`.
S
Steve Klabnik 已提交
3172 3173 3174 3175 3176 3177 3178 3179 3180 3181

### Tuple types

A tuple *type* is a heterogeneous product of other types, called the *elements*
of the tuple. It has no nominal name and is instead structurally typed.

Tuple types and values are denoted by listing the types or values of their
elements, respectively, in a parenthesized, comma-separated list.

Because tuple elements don't have a name, they can only be accessed by
3182 3183
pattern-matching or by using `N` directly as a field to access the
`N`th element.
S
Steve Klabnik 已提交
3184 3185 3186

An example of a tuple type and its use:

S
Steve Klabnik 已提交
3187
```
3188
type Pair<'a> = (i32, &'a str);
S
Steve Klabnik 已提交
3189 3190 3191
let p: Pair<'static> = (10, "hello");
let (a, b) = p;
assert!(b != "world");
3192
assert!(p.0 == 10);
S
Steve Klabnik 已提交
3193
```
S
Steve Klabnik 已提交
3194

S
Steve Klabnik 已提交
3195
### Array, and Slice types
S
Steve Klabnik 已提交
3196

S
Steve Klabnik 已提交
3197
Rust has two different types for a list of items:
S
Steve Klabnik 已提交
3198

3199
* `[T; N]`, an 'array'.
S
Steve Klabnik 已提交
3200 3201 3202 3203 3204
* `&[T]`, a 'slice'.

An array has a fixed size, and can be allocated on either the stack or the
heap.

S
Steve Klabnik 已提交
3205
A slice is a 'view' into an array. It doesn't own the data it points
S
Steve Klabnik 已提交
3206 3207 3208 3209 3210
to, it borrows it.

An example of each kind:

```{rust}
3211 3212
let vec: Vec<i32> = vec![1, 2, 3];
let arr: [i32; 3] = [1, 2, 3];
3213
let s: &[i32] = &vec[..];
S
Steve Klabnik 已提交
3214 3215 3216 3217 3218
```

As you can see, the `vec!` macro allows you to create a `Vec<T>` easily. The
`vec!` macro is also part of the standard library, rather than the language.

S
Steve Klabnik 已提交
3219 3220
All in-bounds elements of arrays, and slices are always initialized, and access
to an array or slice is always bounds-checked.
S
Steve Klabnik 已提交
3221 3222 3223 3224 3225 3226

### Structure types

A `struct` *type* is a heterogeneous product of other types, called the
*fields* of the type.[^structtype]

3227
[^structtype]: `struct` types are analogous to `struct` types in C,
S
Steve Klabnik 已提交
3228 3229 3230 3231 3232 3233 3234 3235
    the *record* types of the ML family,
    or the *structure* types of the Lisp family.

New instances of a `struct` can be constructed with a [struct
expression](#structure-expressions).

The memory layout of a `struct` is undefined by default to allow for compiler
optimizations like field reordering, but it can be fixed with the
S
Steve Klabnik 已提交
3236
`#[repr(...)]` attribute. In either case, fields may be given in any order in
S
Steve Klabnik 已提交
3237 3238 3239 3240
a corresponding struct *expression*; the resulting `struct` value will always
have the same memory layout.

The fields of a `struct` may be qualified by [visibility
3241
modifiers](#visibility-and-privacy), to allow access to data in a
S
Steve Klabnik 已提交
3242 3243 3244 3245 3246 3247
structure outside a module.

A _tuple struct_ type is just like a structure type, except that the fields are
anonymous.

A _unit-like struct_ type is like a structure type, except that it has no
S
Steve Klabnik 已提交
3248
fields. The one value constructed by the associated [structure
S
Steve Klabnik 已提交
3249 3250 3251 3252 3253 3254 3255 3256 3257 3258 3259 3260 3261 3262 3263 3264 3265 3266 3267 3268 3269 3270 3271 3272 3273 3274 3275
expression](#structure-expressions) is the only value that inhabits such a
type.

### Enumerated types

An *enumerated type* is a nominal, heterogeneous disjoint union type, denoted
by the name of an [`enum` item](#enumerations). [^enumtype]

[^enumtype]: The `enum` type is analogous to a `data` constructor declaration in
             ML, or a *pick ADT* in Limbo.

An [`enum` item](#enumerations) declares both the type and a number of *variant
constructors*, each of which is independently named and takes an optional tuple
of arguments.

New instances of an `enum` can be constructed by calling one of the variant
constructors, in a [call expression](#call-expressions).

Any `enum` value consumes as much memory as the largest variant constructor for
its corresponding `enum` type.

Enum types cannot be denoted *structurally* as types, but must be denoted by
named reference to an [`enum` item](#enumerations).

### Recursive types

Nominal types &mdash; [enumerations](#enumerated-types) and
S
Steve Klabnik 已提交
3276
[structures](#structure-types) &mdash; may be recursive. That is, each `enum`
S
Steve Klabnik 已提交
3277
constructor or `struct` field may refer, directly or indirectly, to the
S
Steve Klabnik 已提交
3278
enclosing `enum` or `struct` type itself. Such recursion has restrictions:
S
Steve Klabnik 已提交
3279 3280

* Recursive types must include a nominal type in the recursion
S
Steve Klabnik 已提交
3281
  (not mere [type definitions](grammar.html#type-definitions),
S
Steve Klabnik 已提交
3282
   or other structural types such as [arrays](#array,-and-slice-types) or [tuples](#tuple-types)).
S
Steve Klabnik 已提交
3283 3284 3285 3286 3287 3288 3289 3290 3291
* A recursive `enum` item must have at least one non-recursive constructor
  (in order to give the recursion a basis case).
* The size of a recursive type must be finite;
  in other words the recursive fields of the type must be [pointer types](#pointer-types).
* Recursive type definitions can cross module boundaries, but not module *visibility* boundaries,
  or crate boundaries (in order to simplify the module system and type checker).

An example of a *recursive* type and its use:

S
Steve Klabnik 已提交
3292
```
S
Steve Klabnik 已提交
3293
enum List<T> {
A
Alex Crichton 已提交
3294 3295
    Nil,
    Cons(T, Box<List<T>>)
S
Steve Klabnik 已提交
3296 3297
}

3298
let a: List<i32> = List::Cons(7, Box::new(List::Cons(13, Box::new(List::Nil))));
S
Steve Klabnik 已提交
3299
```
S
Steve Klabnik 已提交
3300 3301 3302

### Pointer types

S
Steve Klabnik 已提交
3303 3304
All pointers in Rust are explicit first-class values. They can be copied,
stored into data structures, and returned from functions. There are two
S
Steve Klabnik 已提交
3305 3306 3307 3308
varieties of pointer in Rust:

* References (`&`)
  : These point to memory _owned by some other value_.
3309 3310
    A reference type is written `&type`,
    or `&'a type` when you need to specify an explicit lifetime.
S
Steve Klabnik 已提交
3311 3312
    Copying a reference is a "shallow" operation:
    it involves only copying the pointer itself.
3313 3314 3315
    Releasing a reference has no effect on the value it points to,
    but a reference of a temporary value will keep it alive during the scope
    of the reference itself.
S
Steve Klabnik 已提交
3316 3317 3318 3319

* Raw pointers (`*`)
  : Raw pointers are pointers without safety or liveness guarantees.
    Raw pointers are written as `*const T` or `*mut T`,
3320
    for example `*const i32` means a raw pointer to a 32-bit integer.
S
Steve Klabnik 已提交
3321
    Copying or dropping a raw pointer has no effect on the lifecycle of any
S
Steve Klabnik 已提交
3322
    other value. Dereferencing a raw pointer or converting it to any other
S
Steve Klabnik 已提交
3323 3324 3325 3326 3327 3328 3329 3330 3331 3332
    pointer type is an [`unsafe` operation](#unsafe-functions).
    Raw pointers are generally discouraged in Rust code;
    they exist to support interoperability with foreign code,
    and writing performance-critical or low-level functions.

The standard library contains additional 'smart pointer' types beyond references
and raw pointers.

### Function types

S
Steve Klabnik 已提交
3333
The function type constructor `fn` forms new function types. A function type
S
Steve Klabnik 已提交
3334 3335 3336 3337 3338
consists of a possibly-empty set of function-type modifiers (such as `unsafe`
or `extern`), a sequence of input types and an output type.

An example of a `fn` type:

3339
```
3340
fn add(x: i32, y: i32) -> i32 {
S
Steve Klabnik 已提交
3341 3342 3343 3344 3345
  return x + y;
}

let mut x = add(5,7);

3346
type Binop = fn(i32, i32) -> i32;
S
Steve Klabnik 已提交
3347 3348
let bo: Binop = add;
x = bo(5,7);
S
Steve Klabnik 已提交
3349
```
S
Steve Klabnik 已提交
3350 3351 3352

### Closure types

3353 3354
A [lambda expression](#lambda-expressions) produces a closure value with
a unique, anonymous type that cannot be written out.
S
Steve Klabnik 已提交
3355

3356 3357
Depending on the requirements of the closure, its type implements one or
more of the closure traits:
S
Steve Klabnik 已提交
3358

3359 3360 3361
* `FnOnce`
  : The closure can be called once. A closure called as `FnOnce`
    can move out values from its environment.
S
Steve Klabnik 已提交
3362

3363 3364 3365 3366
* `FnMut`
  : The closure can be called multiple times as mutable. A closure called as
    `FnMut` can mutate values from its environment. `FnMut` implies
    `FnOnce`.
S
Steve Klabnik 已提交
3367

3368 3369 3370 3371
* `Fn`
  : The closure can be called multiple times through a shared reference.
    A closure called as `Fn` can neither move out from nor mutate values
    from its environment. `Fn` implies `FnMut` and `FnOnce`.
S
Steve Klabnik 已提交
3372 3373


N
nwin 已提交
3374
### Trait objects
S
Steve Klabnik 已提交
3375 3376

Every trait item (see [traits](#traits)) defines a type with the same name as
N
nwin 已提交
3377
the trait. This type is called the _trait object_ of the trait. Trait objects
S
Steve Klabnik 已提交
3378
permit "late binding" of methods, dispatched using _virtual method tables_
S
Steve Klabnik 已提交
3379
("vtables"). Whereas most calls to trait methods are "early bound" (statically
S
Steve Klabnik 已提交
3380
resolved) to specific implementations at compile time, a call to a method on an
N
nwin 已提交
3381
trait objects is only resolved to a vtable entry at compile time. The actual
S
Steve Klabnik 已提交
3382 3383 3384 3385
implementation for each vtable entry can vary on an object-by-object basis.

Given a pointer-typed expression `E` of type `&T` or `Box<T>`, where `T`
implements trait `R`, casting `E` to the corresponding pointer type `&R` or
N
nwin 已提交
3386
`Box<R>` results in a value of the _trait object_ `R`. This result is
S
Steve Klabnik 已提交
3387 3388 3389
represented as a pair of pointers: the vtable pointer for the `T`
implementation of `R`, and the pointer value of `E`.

N
typo  
nwin 已提交
3390
An example of a trait object:
S
Steve Klabnik 已提交
3391

S
Steve Klabnik 已提交
3392
```
S
Steve Klabnik 已提交
3393 3394 3395 3396
trait Printable {
  fn stringify(&self) -> String;
}

3397
impl Printable for i32 {
S
Steve Klabnik 已提交
3398 3399 3400 3401 3402 3403 3404 3405
  fn stringify(&self) -> String { self.to_string() }
}

fn print(a: Box<Printable>) {
   println!("{}", a.stringify());
}

fn main() {
3406
   print(Box::new(10) as Box<Printable>);
S
Steve Klabnik 已提交
3407
}
S
Steve Klabnik 已提交
3408
```
S
Steve Klabnik 已提交
3409

N
typo 2  
nwin 已提交
3410
In this example, the trait `Printable` occurs as a trait object in both the
S
Steve Klabnik 已提交
3411 3412 3413 3414 3415 3416 3417
type signature of `print`, and the cast expression in `main`.

### Type parameters

Within the body of an item that has type parameter declarations, the names of
its type parameters are types:

3418
```ignore
3419
fn to_vec<A: Clone>(xs: &[A]) -> Vec<A> {
3420
    if xs.is_empty() {
S
Steve Klabnik 已提交
3421 3422
       return vec![];
    }
3423 3424
    let first: A = xs[0].clone();
    let mut rest: Vec<A> = to_vec(&xs[1..]);
S
Steve Klabnik 已提交
3425
    rest.insert(0, first);
3426
    rest
S
Steve Klabnik 已提交
3427
}
S
Steve Klabnik 已提交
3428
```
S
Steve Klabnik 已提交
3429

3430 3431
Here, `first` has type `A`, referring to `to_vec`'s `A` type parameter; and `rest`
has type `Vec<A>`, a vector with element type `A`.
S
Steve Klabnik 已提交
3432 3433 3434 3435 3436 3437

### Self types

The special type `self` has a meaning within methods inside an impl item. It
refers to the type of the implicit `self` argument. For example, in:

S
Steve Klabnik 已提交
3438
```
S
Steve Klabnik 已提交
3439 3440 3441 3442 3443 3444 3445 3446 3447
trait Printable {
  fn make_string(&self) -> String;
}

impl Printable for String {
    fn make_string(&self) -> String {
        (*self).clone()
    }
}
S
Steve Klabnik 已提交
3448
```
S
Steve Klabnik 已提交
3449 3450 3451 3452

`self` refers to the value of type `String` that is the receiver for a call to
the method `make_string`.

3453
# Special traits
3454

3455
Several traits define special evaluation behavior.
3456

3457
## The `Copy` trait
3458

3459 3460
The `Copy` trait changes the semantics of a type implementing it. Values whose
type implements `Copy` are copied rather than moved upon assignment.
3461

3462 3463 3464 3465 3466
## The `Sized` trait

The `Sized` trait indicates that the size of this type is known at compile-time.

## The `Drop` trait
3467 3468 3469 3470 3471 3472 3473

The `Drop` trait provides a destructor, to be run whenever a value of this type
is to be destroyed.

# Memory model

A Rust program's memory consists of a static set of *items* and a *heap*.
3474 3475 3476 3477
Immutable portions of the heap may be safely shared between threads, mutable
portions may not be safely shared, but several mechanisms for effectively-safe
sharing of mutable values, built on unsafe code but enforcing a safe locking
discipline, exist in the standard library.
S
Steve Klabnik 已提交
3478

3479
Allocations in the stack consist of *variables*, and allocations in the heap
S
Steve Klabnik 已提交
3480 3481 3482 3483 3484 3485 3486 3487
consist of *boxes*.

### Memory allocation and lifetime

The _items_ of a program are those functions, modules and types that have their
value calculated at compile-time and stored uniquely in the memory image of the
rust process. Items are neither dynamically allocated nor freed.

S
Steve Klabnik 已提交
3488 3489 3490 3491
The _heap_ is a general term that describes boxes.  The lifetime of an
allocation in the heap depends on the lifetime of the box values pointing to
it. Since box values may themselves be passed in and out of frames, or stored
in the heap, heap allocations may outlive the frame they are allocated within.
S
Steve Klabnik 已提交
3492 3493 3494 3495

### Memory ownership

When a stack frame is exited, its local allocations are all released, and its
S
Steve Klabnik 已提交
3496
references to boxes are dropped.
S
Steve Klabnik 已提交
3497

3498
### Variables
S
Steve Klabnik 已提交
3499

3500 3501 3502
A _variable_ is a component of a stack frame, either a named function parameter,
an anonymous [temporary](#lvalues,-rvalues-and-temporaries), or a named local
variable.
S
Steve Klabnik 已提交
3503 3504 3505 3506 3507 3508 3509 3510

A _local variable_ (or *stack-local* allocation) holds a value directly,
allocated within the stack's memory. The value is a part of the stack frame.

Local variables are immutable unless declared otherwise like: `let mut x = ...`.

Function parameters are immutable unless declared with `mut`. The `mut` keyword
applies only to the following parameter (so `|mut x, y|` and `fn f(mut x:
3511
Box<i32>, y: Box<i32>)` declare one mutable variable `x` and one immutable
S
Steve Klabnik 已提交
3512 3513 3514
variable `y`).

Methods that take either `self` or `Box<Self>` can optionally place them in a
3515
mutable variable by prefixing them with `mut` (similar to regular arguments):
S
Steve Klabnik 已提交
3516

S
Steve Klabnik 已提交
3517
```
S
Steve Klabnik 已提交
3518 3519 3520 3521
trait Changer {
    fn change(mut self) -> Self;
    fn modify(mut self: Box<Self>) -> Box<Self>;
}
S
Steve Klabnik 已提交
3522
```
S
Steve Klabnik 已提交
3523 3524 3525 3526 3527 3528 3529

Local variables are not initialized when allocated; the entire frame worth of
local variables are allocated at once, on frame-entry, in an uninitialized
state. Subsequent statements within a function may or may not initialize the
local variables. Local variables can be used only after they have been
initialized; this is enforced by the compiler.

3530
# Linkage
S
Steve Klabnik 已提交
3531 3532 3533 3534

The Rust compiler supports various methods to link crates together both
statically and dynamically. This section will explore the various methods to
link Rust crates together, and more information about native libraries can be
S
Steve Klabnik 已提交
3535
found in the [ffi section of the book][ffi].
S
Steve Klabnik 已提交
3536 3537 3538 3539 3540 3541 3542

In one session of compilation, the compiler can generate multiple artifacts
through the usage of either command line flags or the `crate_type` attribute.
If one or more command line flag is specified, all `crate_type` attributes will
be ignored in favor of only building the artifacts specified by command line.

* `--crate-type=bin`, `#[crate_type = "bin"]` - A runnable executable will be
S
Steve Klabnik 已提交
3543
  produced. This requires that there is a `main` function in the crate which
S
Steve Klabnik 已提交
3544 3545 3546 3547 3548 3549 3550 3551 3552 3553 3554 3555 3556 3557 3558
  will be run when the program begins executing. This will link in all Rust and
  native dependencies, producing a distributable binary.

* `--crate-type=lib`, `#[crate_type = "lib"]` - A Rust library will be produced.
  This is an ambiguous concept as to what exactly is produced because a library
  can manifest itself in several forms. The purpose of this generic `lib` option
  is to generate the "compiler recommended" style of library. The output library
  will always be usable by rustc, but the actual type of library may change from
  time-to-time. The remaining output types are all different flavors of
  libraries, and the `lib` type can be seen as an alias for one of them (but the
  actual one is compiler-defined).

* `--crate-type=dylib`, `#[crate_type = "dylib"]` - A dynamic Rust library will
  be produced. This is different from the `lib` output type in that this forces
  dynamic library generation. The resulting dynamic library can be used as a
S
Steve Klabnik 已提交
3559
  dependency for other libraries and/or executables. This output type will
S
Steve Klabnik 已提交
3560 3561 3562 3563 3564 3565 3566 3567 3568 3569 3570 3571 3572 3573
  create `*.so` files on linux, `*.dylib` files on osx, and `*.dll` files on
  windows.

* `--crate-type=staticlib`, `#[crate_type = "staticlib"]` - A static system
  library will be produced. This is different from other library outputs in that
  the Rust compiler will never attempt to link to `staticlib` outputs. The
  purpose of this output type is to create a static library containing all of
  the local crate's code along with all upstream dependencies. The static
  library is actually a `*.a` archive on linux and osx and a `*.lib` file on
  windows. This format is recommended for use in situations such as linking
  Rust code into an existing non-Rust application because it will not have
  dynamic dependencies on other Rust code.

* `--crate-type=rlib`, `#[crate_type = "rlib"]` - A "Rust library" file will be
S
Steve Klabnik 已提交
3574
  produced. This is used as an intermediate artifact and can be thought of as a
S
Steve Klabnik 已提交
3575 3576 3577 3578 3579 3580 3581 3582 3583 3584 3585 3586 3587 3588 3589 3590 3591 3592 3593 3594 3595 3596 3597 3598 3599 3600 3601 3602 3603 3604 3605 3606 3607 3608 3609 3610 3611 3612 3613 3614 3615 3616 3617 3618 3619 3620 3621 3622 3623 3624 3625 3626 3627 3628 3629 3630 3631 3632 3633 3634 3635 3636 3637 3638 3639 3640 3641 3642 3643
  "static Rust library". These `rlib` files, unlike `staticlib` files, are
  interpreted by the Rust compiler in future linkage. This essentially means
  that `rustc` will look for metadata in `rlib` files like it looks for metadata
  in dynamic libraries. This form of output is used to produce statically linked
  executables as well as `staticlib` outputs.

Note that these outputs are stackable in the sense that if multiple are
specified, then the compiler will produce each form of output at once without
having to recompile. However, this only applies for outputs specified by the
same method. If only `crate_type` attributes are specified, then they will all
be built, but if one or more `--crate-type` command line flag is specified,
then only those outputs will be built.

With all these different kinds of outputs, if crate A depends on crate B, then
the compiler could find B in various different forms throughout the system. The
only forms looked for by the compiler, however, are the `rlib` format and the
dynamic library format. With these two options for a dependent library, the
compiler must at some point make a choice between these two formats. With this
in mind, the compiler follows these rules when determining what format of
dependencies will be used:

1. If a static library is being produced, all upstream dependencies are
   required to be available in `rlib` formats. This requirement stems from the
   reason that a dynamic library cannot be converted into a static format.

   Note that it is impossible to link in native dynamic dependencies to a static
   library, and in this case warnings will be printed about all unlinked native
   dynamic dependencies.

2. If an `rlib` file is being produced, then there are no restrictions on what
   format the upstream dependencies are available in. It is simply required that
   all upstream dependencies be available for reading metadata from.

   The reason for this is that `rlib` files do not contain any of their upstream
   dependencies. It wouldn't be very efficient for all `rlib` files to contain a
   copy of `libstd.rlib`!

3. If an executable is being produced and the `-C prefer-dynamic` flag is not
   specified, then dependencies are first attempted to be found in the `rlib`
   format. If some dependencies are not available in an rlib format, then
   dynamic linking is attempted (see below).

4. If a dynamic library or an executable that is being dynamically linked is
   being produced, then the compiler will attempt to reconcile the available
   dependencies in either the rlib or dylib format to create a final product.

   A major goal of the compiler is to ensure that a library never appears more
   than once in any artifact. For example, if dynamic libraries B and C were
   each statically linked to library A, then a crate could not link to B and C
   together because there would be two copies of A. The compiler allows mixing
   the rlib and dylib formats, but this restriction must be satisfied.

   The compiler currently implements no method of hinting what format a library
   should be linked with. When dynamically linking, the compiler will attempt to
   maximize dynamic dependencies while still allowing some dependencies to be
   linked in via an rlib.

   For most situations, having all libraries available as a dylib is recommended
   if dynamically linking. For other situations, the compiler will emit a
   warning if it is unable to determine which formats to link each library with.

In general, `--crate-type=bin` or `--crate-type=lib` should be sufficient for
all compilation needs, and the other options are just available if more
fine-grained control is desired over the output format of a Rust crate.

# Appendix: Rationales and design tradeoffs

*TODO*.

B
Brendan Zabarauskas 已提交
3644 3645 3646 3647 3648 3649 3650 3651 3652 3653 3654 3655 3656
# Appendix: Influences

Rust is not a particularly original language, with design elements coming from
a wide range of sources. Some of these are listed below (including elements
that have since been removed):

* SML, OCaml: algebraic datatypes, pattern matching, type inference,
  semicolon statement separation
* C++: references, RAII, smart pointers, move semantics, monomorphisation,
  memory model
* ML Kit, Cyclone: region based memory management
* Haskell (GHC): typeclasses, type families
* Newsqueak, Alef, Limbo: channels, concurrency
3657
* Erlang: message passing, thread failure, ~~linked thread failure~~,
B
Brendan Zabarauskas 已提交
3658 3659 3660 3661 3662 3663 3664 3665
  ~~lightweight concurrency~~
* Swift: optional bindings
* Scheme: hygienic macros
* C#: attributes
* Ruby: ~~block syntax~~
* NIL, Hermes: ~~typestate~~
* [Unicode Annex #31](http://www.unicode.org/reports/tr31/): identifier and
  pattern syntax
S
Steve Klabnik 已提交
3666

S
Steve Klabnik 已提交
3667
[ffi]: book/ffi.html
3668
[plugin]: book/compiler-plugins.html