Skip to content

Commit 540722e

Browse files
committed
---
yaml --- r: 171046 b: refs/heads/try c: dd38f46 h: refs/heads/master v: v3
1 parent d7a0ba6 commit 540722e

File tree

147 files changed

+1763
-1181
lines changed

Some content is hidden

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

147 files changed

+1763
-1181
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@
22
refs/heads/master: 73a25f55ad748b4d3516417c711b99ce446591af
33
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
44
refs/heads/snap-stage3: 5b3cd3900ceda838f5798c30ab96ceb41f962534
5-
refs/heads/try: 321d9ddff21b532300a9ced6ae7ce5f902c0fbf5
5+
refs/heads/try: dd38f46d71872fba50833fd22313ef49eb01d079
66
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
77
refs/heads/dist-snap: ba4081a5a8573875fed17545846f6f6902c8ba8d
88
refs/tags/release-0.2: c870d2dffb391e14efb05aa27898f1f6333a9596

branches/try/configure

Lines changed: 12 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -599,6 +599,18 @@ then
599599
fi
600600
putvar CFG_RELEASE_CHANNEL
601601

602+
# A magic value that allows the compiler to use unstable features
603+
# during the bootstrap even when doing so would normally be an error
604+
# because of feature staging or because the build turns on
605+
# warnings-as-errors and unstable features default to warnings. The
606+
# build has to match this key in an env var. Meant to be a mild
607+
# deterrent from users just turning on unstable features on the stable
608+
# channel.
609+
# Basing CFG_BOOTSTRAP_KEY on CFG_BOOTSTRAP_KEY lets it get picked up
610+
# during a Makefile reconfig.
611+
CFG_BOOTSTRAP_KEY="${CFG_BOOTSTRAP_KEY-`date +%N`}"
612+
putvar CFG_BOOTSTRAP_KEY
613+
602614
step_msg "looking for build programs"
603615

604616
probe_need CFG_PERL perl

branches/try/mk/main.mk

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -25,11 +25,13 @@ ifeq ($(CFG_RELEASE_CHANNEL),stable)
2525
CFG_RELEASE=$(CFG_RELEASE_NUM)
2626
# This is the string used in dist artifact file names, e.g. "0.12.0", "nightly"
2727
CFG_PACKAGE_VERS=$(CFG_RELEASE_NUM)
28+
CFG_DISABLE_UNSTABLE_FEATURES=1
2829
endif
2930
ifeq ($(CFG_RELEASE_CHANNEL),beta)
3031
# The beta channel is temporarily called 'alpha'
3132
CFG_RELEASE=$(CFG_RELEASE_NUM)-alpha$(CFG_BETA_CYCLE)
3233
CFG_PACKAGE_VERS=$(CFG_RELEASE_NUM)-alpha$(CFG_BETA_CYCLE)
34+
CFG_DISABLE_UNSTABLE_FEATURES=1
3335
endif
3436
ifeq ($(CFG_RELEASE_CHANNEL),nightly)
3537
CFG_RELEASE=$(CFG_RELEASE_NUM)-nightly
@@ -319,11 +321,20 @@ export CFG_VERSION_WIN
319321
export CFG_RELEASE
320322
export CFG_PACKAGE_NAME
321323
export CFG_BUILD
324+
export CFG_RELEASE_CHANNEL
322325
export CFG_LLVM_ROOT
323326
export CFG_PREFIX
324327
export CFG_LIBDIR
325328
export CFG_LIBDIR_RELATIVE
326329
export CFG_DISABLE_INJECT_STD_VERSION
330+
ifdef CFG_DISABLE_UNSTABLE_FEATURES
331+
CFG_INFO := $(info cfg: disabling unstable features (CFG_DISABLE_UNSTABLE_FEATURES))
332+
# Turn on feature-staging
333+
export CFG_DISABLE_UNSTABLE_FEATURES
334+
endif
335+
# Subvert unstable feature lints to do the self-build
336+
export CFG_BOOTSTRAP_KEY
337+
export RUSTC_BOOTSTRAP_KEY:=$(CFG_BOOTSTRAP_KEY)
327338

328339
######################################################################
329340
# Per-stage targets and runner

branches/try/src/compiletest/compiletest.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,7 @@
99
// except according to those terms.
1010

1111
#![crate_type = "bin"]
12-
#![feature(slicing_syntax, unboxed_closures)]
12+
#![feature(slicing_syntax)]
1313

1414
#![deny(warnings)]
1515

branches/try/src/doc/footer.inc

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
<footer><p>
2-
Copyright &copy; 2011-2014 The Rust Project Developers. Licensed under the
2+
Copyright &copy; 2011-2015 The Rust Project Developers. Licensed under the
33
<a href="http://www.apache.org/licenses/LICENSE-2.0">Apache License, Version 2.0</a>
44
or the <a href="http://opensource.org/licenses/MIT">MIT license</a>, at your option.
55
</p><p>

branches/try/src/doc/intro.md

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -542,7 +542,7 @@ use std::thread::Thread;
542542
fn main() {
543543
let vec = vec![1i, 2, 3];
544544
545-
for i in range(1u, 3) {
545+
for i in range(0u, 3) {
546546
Thread::spawn(move || {
547547
println!("{}", vec[i]);
548548
}).detach();
@@ -558,7 +558,7 @@ a vector:
558558
```{rust}
559559
let vec = vec![1i, 2, 3];
560560
561-
for i in range(1u, vec.len()) {
561+
for i in range(0u, vec.len()) {
562562
println!("{}", vec[i]);
563563
}
564564
```

branches/try/src/liballoc/arc.rs

Lines changed: 13 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -67,21 +67,20 @@
6767
//! }
6868
//! ```
6969
70+
use core::prelude::*;
71+
7072
use core::atomic;
7173
use core::atomic::Ordering::{Relaxed, Release, Acquire, SeqCst};
7274
use core::borrow::BorrowFrom;
73-
use core::clone::Clone;
7475
use core::fmt::{self, Show};
75-
use core::cmp::{Eq, Ord, PartialEq, PartialOrd, Ordering};
76+
use core::cmp::{Ordering};
7677
use core::default::Default;
77-
use core::marker::{Sync, Send};
78-
use core::mem::{min_align_of, size_of, drop};
78+
use core::mem::{min_align_of, size_of};
7979
use core::mem;
8080
use core::nonzero::NonZero;
81-
use core::ops::{Drop, Deref};
82-
use core::option::Option;
83-
use core::option::Option::{Some, None};
84-
use core::ptr::{self, PtrExt};
81+
use core::ops::Deref;
82+
use core::ptr;
83+
use core::hash::{Hash, Hasher};
8584
use heap::deallocate;
8685

8786
/// An atomically reference counted wrapper for shared state.
@@ -591,6 +590,12 @@ impl<T: Default + Sync + Send> Default for Arc<T> {
591590
fn default() -> Arc<T> { Arc::new(Default::default()) }
592591
}
593592

593+
impl<H: Hasher, T: Hash<H>> Hash<H> for Arc<T> {
594+
fn hash(&self, state: &mut H) {
595+
(**self).hash(state)
596+
}
597+
}
598+
594599
#[cfg(test)]
595600
#[allow(experimental)]
596601
mod tests {

branches/try/src/liballoc/boxed.rs

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -106,12 +106,20 @@ impl<T: ?Sized + Ord> Ord for Box<T> {
106106
#[stable]}
107107
impl<T: ?Sized + Eq> Eq for Box<T> {}
108108

109+
#[cfg(stage0)]
109110
impl<S: hash::Writer, T: ?Sized + Hash<S>> Hash<S> for Box<T> {
110111
#[inline]
111112
fn hash(&self, state: &mut S) {
112113
(**self).hash(state);
113114
}
114115
}
116+
#[cfg(not(stage0))]
117+
impl<S: hash::Hasher, T: ?Sized + Hash<S>> Hash<S> for Box<T> {
118+
#[inline]
119+
fn hash(&self, state: &mut S) {
120+
(**self).hash(state);
121+
}
122+
}
115123

116124
/// Extension methods for an owning `Any` trait object.
117125
#[unstable = "post-DST and coherence changes, this will not be a trait but \

branches/try/src/liballoc/heap.rs

Lines changed: 27 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -115,16 +115,20 @@ unsafe fn exchange_free(ptr: *mut u8, old_size: uint, align: uint) {
115115
// The minimum alignment guaranteed by the architecture. This value is used to
116116
// add fast paths for low alignment values. In practice, the alignment is a
117117
// constant at the call site and the branch will be optimized out.
118-
#[cfg(any(target_arch = "arm",
119-
target_arch = "mips",
120-
target_arch = "mipsel"))]
118+
#[cfg(all(not(feature = "external_funcs"),
119+
not(feature = "external_crate"),
120+
any(target_arch = "arm",
121+
target_arch = "mips",
122+
target_arch = "mipsel")))]
121123
const MIN_ALIGN: uint = 8;
122-
#[cfg(any(target_arch = "x86",
123-
target_arch = "x86_64",
124-
target_arch = "aarch64"))]
124+
#[cfg(all(not(feature = "external_funcs"),
125+
not(feature = "external_crate"),
126+
any(target_arch = "x86",
127+
target_arch = "x86_64",
128+
target_arch = "aarch64"))]
125129
const MIN_ALIGN: uint = 16;
126130

127-
#[cfg(external_funcs)]
131+
#[cfg(feature = "external_funcs")]
128132
mod imp {
129133
extern {
130134
fn rust_allocate(size: uint, align: uint) -> *mut u8;
@@ -142,14 +146,13 @@ mod imp {
142146
}
143147

144148
#[inline]
145-
pub unsafe fn reallocate_inplace(ptr: *mut u8, old_size: uint, size: uint,
146-
align: uint) -> uint {
147-
rust_reallocate_inplace(ptr, old_size, size, align)
149+
pub unsafe fn deallocate(ptr: *mut u8, old_size: uint, align: uint) {
150+
rust_deallocate(ptr, old_size, align)
148151
}
149152

150153
#[inline]
151-
pub unsafe fn deallocate(ptr: *mut u8, old_size: uint, align: uint) {
152-
rust_deallocate(ptr, old_size, align)
154+
pub unsafe fn reallocate(ptr: *mut u8, old_size: uint, size: uint, align: uint) -> *mut u8 {
155+
rust_reallocate(ptr, old_size, size, align)
153156
}
154157

155158
#[inline]
@@ -169,14 +172,16 @@ mod imp {
169172
}
170173
}
171174

172-
#[cfg(external_crate)]
175+
#[cfg(feature = "external_crate")]
173176
mod imp {
174177
extern crate external;
175178
pub use self::external::{allocate, deallocate, reallocate_inplace, reallocate};
176179
pub use self::external::{usable_size, stats_print};
177180
}
178181

179-
#[cfg(all(not(external_funcs), not(external_crate), jemalloc))]
182+
#[cfg(all(not(feature = "external_funcs"),
183+
not(feature = "external_crate"),
184+
jemalloc))]
180185
mod imp {
181186
use core::option::Option;
182187
use core::option::Option::None;
@@ -253,7 +258,10 @@ mod imp {
253258
}
254259
}
255260

256-
#[cfg(all(not(external_funcs), not(external_crate), not(jemalloc), unix))]
261+
#[cfg(all(not(feature = "external_funcs"),
262+
not(feature = "external_crate"),
263+
not(jemalloc),
264+
unix))]
257265
mod imp {
258266
use core::cmp;
259267
use core::ptr;
@@ -314,7 +322,10 @@ mod imp {
314322
pub fn stats_print() {}
315323
}
316324

317-
#[cfg(all(not(external_funcs), not(external_crate), not(jemalloc), windows))]
325+
#[cfg(all(not(feature = "external_funcs"),
326+
not(feature = "external_crate"),
327+
not(jemalloc),
328+
windows))]
318329
mod imp {
319330
use libc::{c_void, size_t};
320331
use libc;

branches/try/src/liballoc/lib.rs

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -58,6 +58,7 @@
5858
5959
#![crate_name = "alloc"]
6060
#![experimental]
61+
#![staged_api]
6162
#![crate_type = "rlib"]
6263
#![doc(html_logo_url = "http://www.rust-lang.org/logos/rust-logo-128x128-blk-v2.png",
6364
html_favicon_url = "http://www.rust-lang.org/favicon.ico",
@@ -69,6 +70,8 @@
6970

7071
#[macro_use]
7172
extern crate core;
73+
74+
#[cfg(all(not(feature = "external_funcs"), not(feature = "external_crate")))]
7275
extern crate libc;
7376

7477
// Allow testing this library

branches/try/src/liballoc/rc.rs

Lines changed: 23 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -10,23 +10,26 @@
1010

1111
//! Thread-local reference-counted boxes (the `Rc<T>` type).
1212
//!
13-
//! The `Rc<T>` type provides shared ownership of an immutable value. Destruction is deterministic,
14-
//! and will occur as soon as the last owner is gone. It is marked as non-sendable because it
15-
//! avoids the overhead of atomic reference counting.
13+
//! The `Rc<T>` type provides shared ownership of an immutable value.
14+
//! Destruction is deterministic, and will occur as soon as the last owner is
15+
//! gone. It is marked as non-sendable because it avoids the overhead of atomic
16+
//! reference counting.
1617
//!
17-
//! The `downgrade` method can be used to create a non-owning `Weak<T>` pointer to the box. A
18-
//! `Weak<T>` pointer can be upgraded to an `Rc<T>` pointer, but will return `None` if the value
19-
//! has already been dropped.
18+
//! The `downgrade` method can be used to create a non-owning `Weak<T>` pointer
19+
//! to the box. A `Weak<T>` pointer can be upgraded to an `Rc<T>` pointer, but
20+
//! will return `None` if the value has already been dropped.
2021
//!
21-
//! For example, a tree with parent pointers can be represented by putting the nodes behind strong
22-
//! `Rc<T>` pointers, and then storing the parent pointers as `Weak<T>` pointers.
22+
//! For example, a tree with parent pointers can be represented by putting the
23+
//! nodes behind strong `Rc<T>` pointers, and then storing the parent pointers
24+
//! as `Weak<T>` pointers.
2325
//!
2426
//! # Examples
2527
//!
26-
//! Consider a scenario where a set of `Gadget`s are owned by a given `Owner`. We want to have our
27-
//! `Gadget`s point to their `Owner`. We can't do this with unique ownership, because more than one
28-
//! gadget may belong to the same `Owner`. `Rc<T>` allows us to share an `Owner` between multiple
29-
//! `Gadget`s, and have the `Owner` remain allocated as long as any `Gadget` points at it.
28+
//! Consider a scenario where a set of `Gadget`s are owned by a given `Owner`.
29+
//! We want to have our `Gadget`s point to their `Owner`. We can't do this with
30+
//! unique ownership, because more than one gadget may belong to the same
31+
//! `Owner`. `Rc<T>` allows us to share an `Owner` between multiple `Gadget`s,
32+
//! and have the `Owner` remain allocated as long as any `Gadget` points at it.
3033
//!
3134
//! ```rust
3235
//! use std::rc::Rc;
@@ -597,12 +600,20 @@ impl<T: Ord> Ord for Rc<T> {
597600
}
598601

599602
// FIXME (#18248) Make `T` `Sized?`
603+
#[cfg(stage0)]
600604
impl<S: hash::Writer, T: Hash<S>> Hash<S> for Rc<T> {
601605
#[inline]
602606
fn hash(&self, state: &mut S) {
603607
(**self).hash(state);
604608
}
605609
}
610+
#[cfg(not(stage0))]
611+
impl<S: hash::Hasher, T: Hash<S>> Hash<S> for Rc<T> {
612+
#[inline]
613+
fn hash(&self, state: &mut S) {
614+
(**self).hash(state);
615+
}
616+
}
606617

607618
#[experimental = "Show is experimental."]
608619
impl<T: fmt::Show> fmt::Show for Rc<T> {

branches/try/src/libarena/lib.rs

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -21,6 +21,7 @@
2121
2222
#![crate_name = "arena"]
2323
#![experimental]
24+
#![staged_api]
2425
#![crate_type = "rlib"]
2526
#![crate_type = "dylib"]
2627
#![doc(html_logo_url = "http://www.rust-lang.org/logos/rust-logo-128x128-blk-v2.png",

branches/try/src/libcollections/bit.rs

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -982,7 +982,7 @@ impl fmt::Show for Bitv {
982982
}
983983

984984
#[stable]
985-
impl<S: hash::Writer> hash::Hash<S> for Bitv {
985+
impl<S: hash::Writer + hash::Hasher> hash::Hash<S> for Bitv {
986986
fn hash(&self, state: &mut S) {
987987
self.nbits.hash(state);
988988
for elem in self.blocks() {
@@ -1742,7 +1742,7 @@ impl fmt::Show for BitvSet {
17421742
}
17431743
}
17441744

1745-
impl<S: hash::Writer> hash::Hash<S> for BitvSet {
1745+
impl<S: hash::Writer + hash::Hasher> hash::Hash<S> for BitvSet {
17461746
fn hash(&self, state: &mut S) {
17471747
for pos in self.iter() {
17481748
pos.hash(state);

branches/try/src/libcollections/btree/map.rs

Lines changed: 13 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -23,7 +23,9 @@ use core::borrow::BorrowFrom;
2323
use core::cmp::Ordering;
2424
use core::default::Default;
2525
use core::fmt::Show;
26-
use core::hash::{Writer, Hash};
26+
use core::hash::{Hash, Hasher};
27+
#[cfg(stage0)]
28+
use core::hash::Writer;
2729
use core::iter::{Map, FromIterator};
2830
use core::ops::{Index, IndexMut};
2931
use core::{iter, fmt, mem};
@@ -820,13 +822,23 @@ impl<K: Ord, V> Extend<(K, V)> for BTreeMap<K, V> {
820822
}
821823

822824
#[stable]
825+
#[cfg(stage0)]
823826
impl<S: Writer, K: Hash<S>, V: Hash<S>> Hash<S> for BTreeMap<K, V> {
824827
fn hash(&self, state: &mut S) {
825828
for elt in self.iter() {
826829
elt.hash(state);
827830
}
828831
}
829832
}
833+
#[stable]
834+
#[cfg(not(stage0))]
835+
impl<S: Hasher, K: Hash<S>, V: Hash<S>> Hash<S> for BTreeMap<K, V> {
836+
fn hash(&self, state: &mut S) {
837+
for elt in self.iter() {
838+
elt.hash(state);
839+
}
840+
}
841+
}
830842

831843
#[stable]
832844
impl<K: Ord, V> Default for BTreeMap<K, V> {

0 commit comments

Comments
 (0)