Skip to content

Commit b6474e3

Browse files
committed
---
yaml --- r: 160765 b: refs/heads/auto c: 641e2a1 h: refs/heads/master i: 160763: 4a7494f v: v3
1 parent 66b2b87 commit b6474e3

File tree

273 files changed

+2497
-8214
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

273 files changed

+2497
-8214
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -10,7 +10,7 @@ refs/tags/release-0.3: b5f0d0f648d9a6153664837026ba1be43d3e2503
1010
refs/tags/release-0.3.1: 495bae036dfe5ec6ceafd3312b4dca48741e845b
1111
refs/tags/release-0.4: e828ea2080499553b97dfe33b3f4d472b4562ad7
1212
refs/tags/release-0.5: 7e3bcfbf21278251ee936ad53e92e9b719702d73
13-
refs/heads/auto: 8ca27a633ed393438a12bbf074b4f2e6063baa6f
13+
refs/heads/auto: 641e2a110de4bb1b2c2b596ef1168ae7865aa529
1414
refs/heads/servo: af82457af293e2a842ba6b7759b70288da276167
1515
refs/tags/release-0.6: b4ebcfa1812664df5e142f0134a5faea3918544c
1616
refs/tags/0.1: b19db808c2793fe2976759b85a355c3ad8c8b336

branches/auto/AUTHORS.txt

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -121,6 +121,7 @@ Cole Mickens <[email protected]>
121121
Colin Davidson <[email protected]>
122122
Colin Sherratt <[email protected]>
123123
Conrad Kleinespel <[email protected]>
124+
Corey Farwell <[email protected]>
124125
Corey Ford <[email protected]>
125126
Corey Richardson <[email protected]>
126127

branches/auto/configure

Lines changed: 25 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -550,9 +550,19 @@ CFG_LIBDIR_RELATIVE=lib
550550
if [ "$CFG_OSTYPE" = "pc-windows-gnu" ]
551551
then
552552
CFG_LIBDIR_RELATIVE=bin
553-
fi
553+
CFG_LIBDIR="${CFG_PREFIX}/${CFG_LIBDIR_RELATIVE}"
554+
else
555+
valopt libdir "${CFG_PREFIX}/${CFG_LIBDIR_RELATIVE}" "install libraries (ignored on windows platform)"
554556

555-
valopt libdir "${CFG_PREFIX}/${CFG_LIBDIR_RELATIVE}" "install libraries"
557+
case "$CFG_LIBDIR" in
558+
"$CFG_PREFIX"/*) CAT_INC=2;;
559+
"$CFG_PREFIX"*) CAT_INC=1;;
560+
*)
561+
err "libdir must begin with the prefix. Use --prefix to set it accordingly.";;
562+
esac
563+
564+
CFG_LIBDIR_RELATIVE=`echo ${CFG_LIBDIR} | cut -c$((${#CFG_PREFIX}+${CAT_INC}))-`
565+
fi
556566

557567
if [ $HELP -eq 1 ]
558568
then
@@ -883,7 +893,10 @@ CFG_PREFIX=${CFG_PREFIX%/}
883893
CFG_MANDIR=${CFG_MANDIR%/}
884894
CFG_HOST="$(echo $CFG_HOST | tr ',' ' ')"
885895
CFG_TARGET="$(echo $CFG_TARGET | tr ',' ' ')"
886-
CFG_SUPPORTED_TARGET="$(ls ${CFG_SRC_DIR}mk/cfg)"
896+
CFG_SUPPORTED_TARGET=""
897+
for target_file in ${CFG_SRC_DIR}mk/cfg/*.mk; do
898+
CFG_SUPPORTED_TARGET="${CFG_SUPPORTED_TARGET} $(basename "$target_file" .mk)"
899+
done
887900

888901
# copy host-triples to target-triples so that hosts are a subset of targets
889902
V_TEMP=""
@@ -989,6 +1002,15 @@ for h in $CFG_HOST
9891002
do
9901003
for t in $CFG_TARGET
9911004
do
1005+
# host lib dir stage0
1006+
make_dir $h/stage0/lib
1007+
1008+
# target bin dir stage0
1009+
make_dir $h/stage0/lib/rustlib/$t/bin
1010+
1011+
# target lib dir stage0
1012+
make_dir $h/stage0/lib/rustlib/$t/lib
1013+
9921014
for i in 0 1 2 3
9931015
do
9941016
# host bin dir

branches/auto/mk/crates.mk

Lines changed: 5 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -37,7 +37,7 @@
3737
#
3838
# DEPS_<crate>
3939
# These lists are the dependencies of the <crate> that is to be built.
40-
# Rust dependencies are listed bare (i.e. std, green) and native
40+
# Rust dependencies are listed bare (i.e. std) and native
4141
# dependencies have a "native:" prefix (i.e. native:hoedown). All deps
4242
# will be built before the crate itself is built.
4343
#
@@ -49,7 +49,7 @@
4949
# automatically generated for all stage/host/target combinations.
5050
################################################################################
5151

52-
TARGET_CRATES := libc std green native flate arena term \
52+
TARGET_CRATES := libc std flate arena term \
5353
serialize sync getopts collections test time rand \
5454
log regex graphviz core rbml alloc rustrt \
5555
unicode
@@ -66,8 +66,6 @@ DEPS_rustrt := alloc core libc collections native:rustrt_native
6666
DEPS_std := core libc rand alloc collections rustrt sync unicode \
6767
native:rust_builtin native:backtrace
6868
DEPS_graphviz := std
69-
DEPS_green := std native:context_switch
70-
DEPS_native := std
7169
DEPS_syntax := std term serialize log fmt_macros arena libc
7270
DEPS_rustc_trans := rustc rustc_back rustc_llvm libc
7371
DEPS_rustc := syntax flate arena serialize getopts rbml \
@@ -95,9 +93,9 @@ DEPS_regex := std
9593
DEPS_regex_macros = rustc syntax std regex
9694
DEPS_fmt_macros = std
9795

98-
TOOL_DEPS_compiletest := test getopts native
99-
TOOL_DEPS_rustdoc := rustdoc native
100-
TOOL_DEPS_rustc := rustc_trans native
96+
TOOL_DEPS_compiletest := test getopts
97+
TOOL_DEPS_rustdoc := rustdoc
98+
TOOL_DEPS_rustc := rustc_trans
10199
TOOL_SOURCE_compiletest := $(S)src/compiletest/compiletest.rs
102100
TOOL_SOURCE_rustdoc := $(S)src/driver/driver.rs
103101
TOOL_SOURCE_rustc := $(S)src/driver/driver.rs

branches/auto/mk/main.mk

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -332,7 +332,15 @@ define SREQ
332332
# Destinations of artifacts for the host compiler
333333
HROOT$(1)_H_$(3) = $(3)/stage$(1)
334334
HBIN$(1)_H_$(3) = $$(HROOT$(1)_H_$(3))/bin
335+
ifeq ($$(CFG_WINDOWSY_$(3)),1)
335336
HLIB$(1)_H_$(3) = $$(HROOT$(1)_H_$(3))/$$(CFG_LIBDIR_RELATIVE)
337+
else
338+
ifeq ($(1),0)
339+
HLIB$(1)_H_$(3) = $$(HROOT$(1)_H_$(3))/lib
340+
else
341+
HLIB$(1)_H_$(3) = $$(HROOT$(1)_H_$(3))/$$(CFG_LIBDIR_RELATIVE)
342+
endif
343+
endif
336344

337345
# Destinations of artifacts for target architectures
338346
TROOT$(1)_T_$(2)_H_$(3) = $$(HLIB$(1)_H_$(3))/rustlib/$(2)

branches/auto/mk/platform.mk

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -113,7 +113,7 @@ $(foreach cvar,CC CXX CPP CFLAGS CXXFLAGS CPPFLAGS, \
113113

114114
CFG_RLIB_GLOB=lib$(1)-*.rlib
115115

116-
include $(wildcard $(CFG_SRC_DIR)mk/cfg/*)
116+
include $(wildcard $(CFG_SRC_DIR)mk/cfg/*.mk)
117117

118118
# The -Qunused-arguments sidesteps spurious warnings from clang
119119
define FILTER_FLAGS

branches/auto/src/README.md

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -9,8 +9,6 @@ Source layout:
99
| `libcore/` | The Rust core library |
1010
| `libdebug/` | Debugging utilities |
1111
| `libstd/` | The standard library (imported and linked by default) |
12-
| `libgreen/` | The M:N runtime library |
13-
| `libnative/` | The 1:1 runtime library |
1412
| `libsyntax/` | The Rust parser and pretty-printer |
1513
| `libtest/` | Rust's test-runner code |
1614
| ------------------- | --------------------------------------------------------- |

branches/auto/src/compiletest/runtest.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1566,7 +1566,7 @@ fn _arm_exec_compiled_test(config: &Config,
15661566

15671567
let mut exitcode: int = 0;
15681568
for c in exitcode_out.as_slice().chars() {
1569-
if !c.is_digit() { break; }
1569+
if !c.is_numeric() { break; }
15701570
exitcode = exitcode * 10 + match c {
15711571
'0' ... '9' => c as int - ('0' as int),
15721572
_ => 101,

branches/auto/src/doc/reference.md

Lines changed: 78 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -225,6 +225,52 @@ reserved for future extension, that is, the above gives the lexical
225225
grammar, but a Rust parser will reject everything but the 12 special
226226
cases mentioned in [Number literals](#number-literals) below.
227227

228+
#### Examples
229+
230+
##### Characters and strings
231+
232+
| | Example | Number of `#` pairs allowed | Available characters | Escapes | Equivalent to |
233+
|---|---------|-----------------------------|----------------------|---------|---------------|
234+
| [Character](#character-literals) | `'H'` | `N/A` | All unicode | `\'` & [Byte escapes](#byte-escapes) & [Unicode escapes](#unicode-escapes) | `N/A` |
235+
| [String](#string-literals) | `"hello"` | `N/A` | All unicode | `\"` & [Byte escapes](#byte-escapes) & [Unicode escapes](#unicode-escapes) | `N/A` |
236+
| [Raw](#raw-string-literals) | `r##"hello"##` | `0...` | All unicode | `N/A` | `N/A` |
237+
| [Byte](#byte-literals) | `b'H'` | `N/A` | All ASCII | `\'` & [Byte escapes](#byte-escapes) | `u8` |
238+
| [Byte string](#byte-string-literals) | `b"hello"` | `N/A` | All ASCII | `\"` & [Byte escapes](#byte-escapes) | `&'static [u8]` |
239+
| [Raw byte string](#raw-byte-string-literals) | `br##"hello"##` | `0...` | All ASCII | `N/A` | `&'static [u8]` (unsure...not stated) |
240+
241+
##### Byte escapes
242+
243+
| | Name |
244+
|---|------|
245+
| `\x7F` | 8-bit character code (exactly 2 digits) |
246+
| `\n` | Newline |
247+
| `\r` | Carriage return |
248+
| `\t` | Tab |
249+
| `\\` | Backslash |
250+
251+
##### Unicode escapes
252+
| | Name |
253+
|---|------|
254+
| `\u7FFF` | 16-bit character code (exactly 4 digits) |
255+
| `\U7EEEFFFF` | 32-bit character code (exactly 8 digits) |
256+
257+
##### Numbers
258+
259+
| [Number literals](#number-literals)`*` | Example | Exponentiation | Suffixes |
260+
|----------------------------------------|---------|----------------|----------|
261+
| Decimal integer | `98_222i` | `N/A` | Integer suffixes |
262+
| Hex integer | `0xffi` | `N/A` | Integer suffixes |
263+
| Octal integer | `0o77i` | `N/A` | Integer suffixes |
264+
| Binary integer | `0b1111_0000i` | `N/A` | Integer suffixes |
265+
| Floating-point | `123.0E+77f64` | `Optional` | Floating-point suffixes |
266+
267+
`*` All number literals allow `_` as a visual separator: `1_234.0E+18f64`
268+
269+
##### Suffixes
270+
| Integer | Floating-point |
271+
|---------|----------------|
272+
| `i` (`int`), `u` (`uint`), `u8`, `i8`, `u16`, `i16`, `u32`, `i32`, `u64`, `i64` | `f32`, `f64` |
273+
228274
#### Character and string literals
229275

230276
```{.ebnf .gram}
@@ -253,15 +299,21 @@ nonzero_dec: '1' | '2' | '3' | '4'
253299
| '5' | '6' | '7' | '8' | '9' ;
254300
```
255301

302+
##### Character literals
303+
256304
A _character literal_ is a single Unicode character enclosed within two
257305
`U+0027` (single-quote) characters, with the exception of `U+0027` itself,
258306
which must be _escaped_ by a preceding U+005C character (`\`).
259307

308+
##### String literals
309+
260310
A _string literal_ is a sequence of any Unicode characters enclosed within two
261311
`U+0022` (double-quote) characters, with the exception of `U+0022` itself,
262312
which must be _escaped_ by a preceding `U+005C` character (`\`), or a _raw
263313
string literal_.
264314

315+
##### Character escapes
316+
265317
Some additional _escapes_ are available in either character or non-raw string
266318
literals. An escape starts with a `U+005C` (`\`) and continues with one of the
267319
following forms:
@@ -281,6 +333,8 @@ following forms:
281333
* The _backslash escape_ is the character `U+005C` (`\`) which must be
282334
escaped in order to denote *itself*.
283335

336+
##### Raw string literals
337+
284338
Raw string literals do not process any escapes. They start with the character
285339
`U+0072` (`r`), followed by zero or more of the character `U+0023` (`#`) and a
286340
`U+0022` (double-quote) character. The _raw string body_ is not defined in the
@@ -322,12 +376,16 @@ raw_byte_string : '"' raw_byte_string_body '"' | '#' raw_byte_string '#' ;
322376
323377
```
324378

379+
##### Byte literals
380+
325381
A _byte literal_ is a single ASCII character (in the `U+0000` to `U+007F`
326382
range) enclosed within two `U+0027` (single-quote) characters, with the
327383
exception of `U+0027` itself, which must be _escaped_ by a preceding U+005C
328384
character (`\`), or a single _escape_. It is equivalent to a `u8` unsigned
329385
8-bit integer _number literal_.
330386

387+
##### Byte string literals
388+
331389
A _byte string literal_ is a sequence of ASCII characters and _escapes_
332390
enclosed within two `U+0022` (double-quote) characters, with the exception of
333391
`U+0022` itself, which must be _escaped_ by a preceding `U+005C` character
@@ -347,6 +405,8 @@ following forms:
347405
* The _backslash escape_ is the character `U+005C` (`\`) which must be
348406
escaped in order to denote its ASCII encoding `0x5C`.
349407

408+
##### Raw byte string literals
409+
350410
Raw byte string literals do not process any escapes. They start with the
351411
character `U+0062` (`b`), followed by `U+0072` (`r`), followed by zero or more
352412
of the character `U+0023` (`#`), and a `U+0022` (double-quote) character. The
@@ -999,14 +1059,14 @@ An example of what will and will not work for `use` items:
9991059

10001060
```
10011061
# #![allow(unused_imports)]
1002-
use foo::native::start; // good: foo is at the root of the crate
1062+
use foo::core::iter; // good: foo is at the root of the crate
10031063
use foo::baz::foobaz; // good: foo is at the root of the crate
10041064
10051065
mod foo {
1006-
extern crate native;
1066+
extern crate core;
10071067
1008-
use foo::native::start; // good: foo is at crate root
1009-
// use native::start; // bad: native is not at the crate root
1068+
use foo::core::iter; // good: foo is at crate root
1069+
// use core::iter; // bad: native is not at the crate root
10101070
use self::baz::foobaz; // good: self refers to module 'foo'
10111071
use foo::bar::foobar; // good: foo is at crate root
10121072
@@ -1114,13 +1174,13 @@ Rust:
11141174
##### Unsafe functions
11151175

11161176
Unsafe functions are functions that are not safe in all contexts and/or for all
1117-
possible inputs. Such a function must be prefixed with the keyword `unsafe`.
1177+
possible inputs. Such a function must be prefixed with the keyword `unsafe` and
1178+
can only be called from an `unsafe` block or another `unsafe` function.
11181179

11191180
##### Unsafe blocks
11201181

1121-
A block of code can also be prefixed with the `unsafe` keyword, to permit
1122-
calling `unsafe` functions or dereferencing raw pointers within a safe
1123-
function.
1182+
A block of code can be prefixed with the `unsafe` keyword, to permit calling
1183+
`unsafe` functions or dereferencing raw pointers within a safe function.
11241184

11251185
When a programmer has sufficient conviction that a sequence of potentially
11261186
unsafe operations is actually safe, they can encapsulate that sequence (taken
@@ -1140,12 +1200,11 @@ represented with reference-counted pointers in safe code. By using `unsafe`
11401200
blocks to represent the reverse links as raw pointers, it can be implemented
11411201
with only boxes.
11421202

1143-
##### Behavior considered unsafe
1203+
##### Behavior considered undefined
11441204

1145-
This is a list of behavior which is forbidden in all Rust code. Type checking
1146-
provides the guarantee that these issues are never caused by safe code. An
1147-
`unsafe` block or function is responsible for never invoking this behaviour or
1148-
exposing an API making it possible for it to occur in safe code.
1205+
The following is a list of behavior which is forbidden in all Rust code,
1206+
including within `unsafe` blocks and `unsafe` functions. Type checking provides
1207+
the guarantee that these issues are never caused by safe code.
11491208

11501209
* Data races
11511210
* Dereferencing a null/dangling raw pointer
@@ -1275,7 +1334,12 @@ specific type; the type-specified aspects of a value include:
12751334
For example, the type `(u8, u8)` defines the set of immutable values that are
12761335
composite pairs, each containing two unsigned 8-bit integers accessed by
12771336
pattern-matching and laid out in memory with the `x` component preceding the
1278-
`y` component.
1337+
`y` component:
1338+
1339+
```
1340+
type Point = (u8, u8);
1341+
let p: Point = (41, 68);
1342+
```
12791343

12801344
### Structures
12811345

branches/auto/src/driver/driver.rs

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -8,6 +8,8 @@
88
// option. This file may not be copied, modified, or distributed
99
// except according to those terms.
1010

11+
#![no_start]
12+
1113
#[cfg(rustdoc)]
1214
extern crate "rustdoc" as this;
1315

branches/auto/src/etc/install.sh

Lines changed: 11 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -301,9 +301,16 @@ fi
301301
flag uninstall "only uninstall from the installation prefix"
302302
opt verify 1 "verify that the installed binaries run correctly"
303303
valopt prefix "/usr/local" "set installation prefix"
304-
# NB This isn't quite the same definition as in `configure`.
305-
# just using 'lib' instead of CFG_LIBDIR_RELATIVE
304+
# NB This is exactly the same definition as in `configure`.
306305
valopt libdir "${CFG_PREFIX}/${CFG_LIBDIR_RELATIVE}" "install libraries"
306+
case "$CFG_LIBDIR" in
307+
"$CFG_PREFIX"/*) CAT_INC=2;;
308+
"$CFG_PREFIX"*) CAT_INC=1;;
309+
*)
310+
err "libdir must begin with the prefix. Use --prefix to set it accordingly.";;
311+
esac
312+
CFG_LIBDIR_RELATIVE=`echo ${CFG_LIBDIR} | cut -c$((${#CFG_PREFIX}+${CAT_INC}))-`
313+
307314
valopt mandir "${CFG_PREFIX}/share/man" "install man pages in PATH"
308315

309316
if [ $HELP -eq 1 ]
@@ -428,9 +435,9 @@ while read p; do
428435
# Decide the destination of the file
429436
FILE_INSTALL_PATH="${CFG_PREFIX}/$p"
430437

431-
if echo "$p" | grep "^lib/" > /dev/null
438+
if echo "$p" | grep "^${CFG_LIBDIR_RELATIVE}/" > /dev/null
432439
then
433-
pp=`echo $p | sed 's/^lib\///'`
440+
pp=`echo $p | sed "s%^${CFG_LIBDIR_RELATIVE}/%%"`
434441
FILE_INSTALL_PATH="${CFG_LIBDIR}/$pp"
435442
fi
436443

0 commit comments

Comments
 (0)