Skip to content

Commit dfe3148

Browse files
committed
---
yaml --- r: 134269 b: refs/heads/auto c: 4ef9e1e h: refs/heads/master i: 134267: 5dcde18 v: v3
1 parent 2747be7 commit dfe3148

File tree

116 files changed

+921
-3726
lines changed

Some content is hidden

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

116 files changed

+921
-3726
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,7 @@ refs/heads/try3: 9387340aab40a73e8424c48fd42f0c521a4875c0
1313
refs/tags/release-0.3.1: 495bae036dfe5ec6ceafd3312b4dca48741e845b
1414
refs/tags/release-0.4: e828ea2080499553b97dfe33b3f4d472b4562ad7
1515
refs/tags/release-0.5: 7e3bcfbf21278251ee936ad53e92e9b719702d73
16-
refs/heads/auto: 35be9b817d897d9a15cbf84eb450ab8ea80b7207
16+
refs/heads/auto: 4ef9e1eca277f550cc08ca09a56dfc5240f7635c
1717
refs/heads/servo: af82457af293e2a842ba6b7759b70288da276167
1818
refs/tags/release-0.6: b4ebcfa1812664df5e142f0134a5faea3918544c
1919
refs/tags/0.1: b19db808c2793fe2976759b85a355c3ad8c8b336

branches/auto/configure

Lines changed: 1 addition & 20 deletions
Original file line numberDiff line numberDiff line change
@@ -453,8 +453,6 @@ valopt datadir "${CFG_PREFIX}/share" "install data"
453453
valopt infodir "${CFG_PREFIX}/share/info" "install additional info"
454454
valopt mandir "${CFG_PREFIX}/share/man" "install man pages in PATH"
455455

456-
valopt release-channel "source" "the name of the release channel to build"
457-
458456
# On windows we just store the libraries in the bin directory because
459457
# there's no rpath. This is where the build system itself puts libraries;
460458
# --libdir is used to configure the installation directory.
@@ -483,23 +481,6 @@ CFG_BUILD=`echo "${CFG_BUILD}" | sed 's/-pc-mingw32/-w64-mingw32/g'`
483481
CFG_HOST=`echo "${CFG_HOST}" | sed 's/-pc-mingw32/-w64-mingw32/g'`
484482
CFG_TARGET=`echo "${CFG_TARGET}" | sed 's/-pc-mingw32/-w64-mingw32/g'`
485483

486-
# Validate the release channel
487-
case "$CFG_RELEASE_CHANNEL" in
488-
(source | nightly | beta | stable)
489-
;;
490-
(*)
491-
err "release channel must be 'source', 'nightly', 'beta' or 'stable'"
492-
;;
493-
esac
494-
495-
# Continue supporting the old --enable-nightly flag to transition the bots
496-
# XXX Remove me
497-
if [ $CFG_ENABLE_NIGHTLY -eq 1 ]
498-
then
499-
CFG_RELEASE_CHANNEL=nightly
500-
putvar CFG_RELEASE_CHANNEL
501-
fi
502-
503484
step_msg "looking for build programs"
504485

505486
probe_need CFG_PERL perl
@@ -655,7 +636,7 @@ then
655636
# check that gcc, cc and g++ all point to the same compiler.
656637
# note that for xcode 5, g++ points to clang, not clang++
657638
if !((chk_cc gcc clang && chk_cc g++ clang) ||
658-
(chk_cc gcc gcc &&( chk_cc g++ g++ || chk g++ gcc))); then
639+
(chk_cc gcc gcc &&( chk_cc g++ g++ || chk g++ gcc))) then
659640
err "the gcc and g++ in your path point to different compilers.
660641
Check which versions are in your path with gcc --version and g++ --version.
661642
To resolve this problem, either fix your PATH or run configure with --enable-clang"

branches/auto/man/rustc.1

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
.TH RUSTC "1" "March 2014" "rustc 0.12.0" "User Commands"
1+
.TH RUSTC "1" "March 2014" "rustc 0.12.0-pre" "User Commands"
22
.SH NAME
33
rustc \- The Rust compiler
44
.SH SYNOPSIS

branches/auto/man/rustdoc.1

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
.TH RUSTDOC "1" "March 2014" "rustdoc 0.12.0" "User Commands"
1+
.TH RUSTDOC "1" "March 2014" "rustdoc 0.12.0-pre" "User Commands"
22
.SH NAME
33
rustdoc \- generate documentation from Rust source code
44
.SH SYNOPSIS

branches/auto/mk/main.mk

Lines changed: 11 additions & 21 deletions
Original file line numberDiff line numberDiff line change
@@ -14,32 +14,22 @@
1414

1515
# The version number
1616
CFG_RELEASE_NUM=0.12.0
17+
CFG_RELEASE_LABEL=-pre
1718

1819
CFG_FILENAME_EXTRA=4e7c5e5c
1920

20-
ifeq ($(CFG_RELEASE_CHANNEL),stable)
21-
# This is the normal semver version string, e.g. "0.12.0", "0.12.0-nightly"
22-
CFG_RELEASE=$(CFG_RELEASE_NUM)
23-
# This is the string used in dist artifact file names, e.g. "0.12.0", "nightly"
24-
CFG_PACKAGE_VERS=$(CFG_RELEASE_NUM)
25-
endif
26-
ifeq ($(CFG_RELEASE_CHANNEL),beta)
27-
CFG_RELEASE=$(CFG_RELEASE_NUM)-beta
28-
# When building beta/nightly distributables just reuse the same "beta"
29-
# name so when we upload we'll always override the previous
30-
# nighly. This doesn't actually impact the version reported by rustc -
31-
# it's just for file naming.
32-
CFG_PACKAGE_VERS=beta
33-
endif
34-
ifeq ($(CFG_RELEASE_CHANNEL),nightly)
35-
CFG_RELEASE=$(CFG_RELEASE_NUM)-nightly
21+
ifndef CFG_ENABLE_NIGHTLY
22+
# This is the normal version string
23+
CFG_RELEASE=$(CFG_RELEASE_NUM)$(CFG_RELEASE_LABEL)
24+
CFG_PACKAGE_VERS=$(CFG_RELEASE)
25+
else
26+
# Modify the version label for nightly builds
27+
CFG_RELEASE=$(CFG_RELEASE_NUM)$(CFG_RELEASE_LABEL)-nightly
28+
# When building nightly distributables just reuse the same "rust-nightly" name
29+
# so when we upload we'll always override the previous nighly. This doesn't actually
30+
# impact the version reported by rustc - it's just for file naming.
3631
CFG_PACKAGE_VERS=nightly
3732
endif
38-
ifeq ($(CFG_RELEASE_CHANNEL),source)
39-
CFG_RELEASE=$(CFG_RELEASE_NUM)-pre
40-
CFG_PACKAGE_VERS=$(CFG_RELEASE_NUM)-pre
41-
endif
42-
4333
# The name of the package to use for creating tarballs, installers etc.
4434
CFG_PACKAGE_NAME=rust-$(CFG_PACKAGE_VERS)
4535

branches/auto/src/doc/guide-tasks.md

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -235,7 +235,7 @@ fn partial_sum(start: uint) -> f64 {
235235
}
236236
237237
fn main() {
238-
let mut futures = Vec::from_fn(200, |ind| Future::spawn( proc() { partial_sum(ind) }));
238+
let mut futures = Vec::from_fn(1000, |ind| Future::spawn( proc() { partial_sum(ind) }));
239239
240240
let mut final_res = 0f64;
241241
for ft in futures.iter_mut() {

branches/auto/src/doc/guide.md

Lines changed: 17 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -29,11 +29,8 @@ $ curl -s https://static.rust-lang.org/rustup.sh | sudo sh
2929
(If you're concerned about `curl | sudo sh`, please keep reading. Disclaimer
3030
below.)
3131

32-
If you're on Windows, please download either the [32-bit
33-
installer](https://static.rust-lang.org/dist/rust-nightly-i686-w64-mingw32.exe)
34-
or the [64-bit
35-
installer](https://static.rust-lang.org/dist/rust-nightly-x86_64-w64-mingw32.exe)
36-
and run it.
32+
If you're on Windows, please [download this .exe and run
33+
it](https://static.rust-lang.org/dist/rust-nightly-install.exe).
3734

3835
If you decide you don't want Rust anymore, we'll be a bit sad, but that's okay.
3936
Not every programming language is great for everyone. Just pass an argument to
@@ -188,8 +185,8 @@ Next up is this line:
188185
This line does all of the work in our little program. There are a number of
189186
details that are important here. The first is that it's indented with four
190187
spaces, not tabs. Please configure your editor of choice to insert four spaces
191-
with the tab key. We provide some [sample configurations for various
192-
editors](https://github.com/rust-lang/rust/tree/master/src/etc).
188+
with the tab key. We provide some sample configurations for various editors
189+
[here](https://github.com/rust-lang/rust/tree/master/src/etc).
193190

194191
The second point is the `println!()` part. This is calling a Rust **macro**,
195192
which is how metaprogramming is done in Rust. If it were a function instead, it
@@ -395,10 +392,14 @@ By the way, in these examples, `i` indicates that the number is an integer.
395392

396393
Rust is a statically typed language, which means that we specify our types up
397394
front. So why does our first example compile? Well, Rust has this thing called
398-
"type inference." If it can figure out what the type of something is, Rust
395+
"[Hindley-Milner type
396+
inference](http://en.wikipedia.org/wiki/Hindley%E2%80%93Milner_type_system)",
397+
named after some really smart type theorists. If you clicked that link, don't
398+
be scared: what this means for you is that Rust will attempt to infer the types
399+
in your program, and it's pretty good at it. If it can infer the type, Rust
399400
doesn't require you to actually type it out.
400401

401-
We can add the type if we want to, though. Types come after a colon (`:`):
402+
We can add the type if we want to. Types come after a colon (`:`):
402403

403404
```{rust}
404405
let x: int = 5;
@@ -1280,15 +1281,15 @@ two main looping constructs: `for` and `while`.
12801281

12811282
The `for` loop is used to loop a particular number of times. Rust's `for` loops
12821283
work a bit differently than in other systems languages, however. Rust's `for`
1283-
loop doesn't look like this "C style" `for` loop:
1284+
loop doesn't look like this C `for` loop:
12841285

1285-
```{c}
1286+
```{ignore,c}
12861287
for (x = 0; x < 10; x++) {
12871288
printf( "%d\n", x );
12881289
}
12891290
```
12901291

1291-
Instead, it looks like this:
1292+
It looks like this:
12921293

12931294
```{rust}
12941295
for x in range(0i, 10i) {
@@ -1311,9 +1312,10 @@ valid for the loop body. Once the body is over, the next value is fetched from
13111312
the iterator, and we loop another time. When there are no more values, the
13121313
`for` loop is over.
13131314

1314-
In our example, `range` is a function that takes a start and an end position,
1315-
and gives an iterator over those values. The upper bound is exclusive, though,
1316-
so our loop will print `0` through `9`, not `10`.
1315+
In our example, the `range` function is a function, provided by Rust, that
1316+
takes a start and an end position, and gives an iterator over those values. The
1317+
upper bound is exclusive, though, so our loop will print `0` through `9`, not
1318+
`10`.
13171319

13181320
Rust does not have the "C style" `for` loop on purpose. Manually controlling
13191321
each element of the loop is complicated and error prone, even for experienced C

branches/auto/src/doc/index.md

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -86,10 +86,10 @@ There are questions that are asked quite often, and so we've made FAQs for them:
8686

8787
# The standard library
8888

89-
We have [API documentation for the entire standard
90-
library](std/index.html). There's a list of crates on the left with more
91-
specific sections, or you can use the search bar at the top to search for
92-
something if you know its name.
89+
You can find function-level documentation for the entire standard library
90+
[here](std/index.html). There's a list of crates on the left with more specific
91+
sections, or you can use the search bar at the top to search for something if
92+
you know its name.
9393

9494
# External documentation
9595

branches/auto/src/doc/rust.md

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2557,8 +2557,6 @@ The currently implemented features of the reference compiler are:
25572557

25582558
* `tuple_indexing` - Allows use of tuple indexing (expressions like `expr.0`)
25592559

2560-
* `associated_types` - Allows type aliases in traits. Experimental.
2561-
25622560
If a feature is promoted to a language feature, then all existing programs will
25632561
start to receive compilation warnings about #[feature] directives which enabled
25642562
the new feature (because the directive is no longer necessary). However, if

branches/auto/src/etc/kate/rust.xml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -7,7 +7,7 @@
77
<!ENTITY rustIdent "[a-zA-Z_][a-zA-Z_0-9]*">
88
<!ENTITY rustIntSuf "([iu](8|16|32|64)?)?">
99
]>
10-
<language name="Rust" version="0.12.0" kateversion="2.4" section="Sources" extensions="*.rs" mimetype="text/x-rust" priority="15">
10+
<language name="Rust" version="0.12.0-pre" kateversion="2.4" section="Sources" extensions="*.rs" mimetype="text/x-rust" priority="15">
1111
<highlighting>
1212
<list name="fn">
1313
<item> fn </item>

branches/auto/src/etc/licenseck.py

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -45,14 +45,13 @@
4545
"test/bench/shootout-binarytrees.rs", # BSD
4646
"test/bench/shootout-chameneos-redux.rs", # BSD
4747
"test/bench/shootout-fannkuch-redux.rs", # BSD
48-
"test/bench/shootout-fasta.rs", # BSD
4948
"test/bench/shootout-k-nucleotide.rs", # BSD
5049
"test/bench/shootout-mandelbrot.rs", # BSD
5150
"test/bench/shootout-meteor.rs", # BSD
5251
"test/bench/shootout-nbody.rs", # BSD
52+
"test/bench/shootout-pidigits.rs", # BSD
5353
"test/bench/shootout-regex-dna.rs", # BSD
5454
"test/bench/shootout-reverse-complement.rs", # BSD
55-
"test/bench/shootout-spectralnorm.rs", # BSD
5655
"test/bench/shootout-threadring.rs", # BSD
5756
]
5857

branches/auto/src/jemalloc

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1 +1 @@
1-
Subproject commit aae04170ccbfeea620502106b581c3c216cd132a
1+
Subproject commit 2dba541881fb8e35246d653bbe2e7c7088777a4a

branches/auto/src/liballoc/heap.rs

Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -10,6 +10,9 @@
1010

1111
// FIXME: #13996: mark the `allocate` and `reallocate` return value as `noalias`
1212

13+
#[cfg(stage0, not(test))] use core::raw;
14+
#[cfg(stage0, not(test))] use util;
15+
1316
/// Returns a pointer to `size` bytes of memory.
1417
///
1518
/// Behavior is undefined if the requested size is 0 or the alignment is not a
@@ -108,6 +111,21 @@ unsafe fn exchange_free(ptr: *mut u8, size: uint, align: uint) {
108111
deallocate(ptr, size, align);
109112
}
110113

114+
#[cfg(stage0, not(test))]
115+
#[lang="closure_exchange_malloc"]
116+
#[inline]
117+
#[allow(deprecated)]
118+
unsafe fn closure_exchange_malloc(drop_glue: fn(*mut u8), size: uint,
119+
align: uint) -> *mut u8 {
120+
let total_size = util::get_box_size(size, align);
121+
let p = allocate(total_size, 8);
122+
123+
let alloc = p as *mut raw::Box<()>;
124+
(*alloc).drop_glue = drop_glue;
125+
126+
alloc as *mut u8
127+
}
128+
111129
// The minimum alignment guaranteed by the architecture. This value is used to
112130
// add fast paths for low alignment values. In practice, the alignment is a
113131
// constant at the call site and the branch will be optimized out.
@@ -137,6 +155,9 @@ mod imp {
137155
flags: c_int) -> *mut c_void;
138156
fn je_xallocx(ptr: *mut c_void, size: size_t, extra: size_t,
139157
flags: c_int) -> size_t;
158+
#[cfg(stage0)]
159+
fn je_dallocx(ptr: *mut c_void, flags: c_int);
160+
#[cfg(not(stage0))]
140161
fn je_sdallocx(ptr: *mut c_void, size: size_t, flags: c_int);
141162
fn je_nallocx(size: size_t, flags: c_int) -> size_t;
142163
fn je_malloc_stats_print(write_cb: Option<extern "C" fn(cbopaque: *mut c_void,
@@ -188,6 +209,14 @@ mod imp {
188209
}
189210

190211
#[inline]
212+
#[cfg(stage0)]
213+
pub unsafe fn deallocate(ptr: *mut u8, _size: uint, align: uint) {
214+
let flags = align_to_flags(align);
215+
je_dallocx(ptr as *mut c_void, flags)
216+
}
217+
218+
#[inline]
219+
#[cfg(not(stage0))]
191220
pub unsafe fn deallocate(ptr: *mut u8, size: uint, align: uint) {
192221
let flags = align_to_flags(align);
193222
je_sdallocx(ptr as *mut c_void, size as size_t, flags)

branches/auto/src/libcore/fmt/rt.rs

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -14,6 +14,13 @@
1414
//! These definitions are similar to their `ct` equivalents, but differ in that
1515
//! these can be statically allocated and are slightly optimized for the runtime
1616
17+
#[cfg(stage0)]
18+
#[doc(hidden)]
19+
pub enum Piece<'a> {
20+
String(&'a str),
21+
Argument(Argument<'a>),
22+
}
23+
1724
#[doc(hidden)]
1825
pub struct Argument<'a> {
1926
pub position: Position,

0 commit comments

Comments
 (0)