Auto merge of #31993 - steveklabnik:rollup, r=steveklabnik

- Successful merges: #31965, #31969, #31973, #31978, #31984, #31987, #31992
- Failed merges:
This commit is contained in:
bors 2016-03-01 20:09:00 +00:00
commit 84d8fec9b0
16 changed files with 48 additions and 34 deletions

View File

@ -1,16 +1,6 @@
Version 1.7.0 (2016-03-03) Version 1.7.0 (2016-03-03)
========================== ==========================
Language
--------
* Soundness fixes to the interactions between associated types and
lifetimes, specified in [RFC 1214], [now generate errors][1.7sf] for
code that violates the new rules. This is a significant change that
is known to break existing code, so it has emitted warnings for the
new error cases since 1.4 to give crate authors time to adapt. The
details of what is changing are subtle; read the RFC for more.
Libraries Libraries
--------- ---------
@ -59,6 +49,17 @@ Libraries
* [`IntoStringError::into_cstring`] * [`IntoStringError::into_cstring`]
* [`IntoStringError::utf8_error`] * [`IntoStringError::utf8_error`]
* `Error for IntoStringError` * `Error for IntoStringError`
* Hashing
* [`std::hash::BuildHasher`]
* [`BuildHasher::Hasher`]
* [`BuildHasher::build_hasher`]
* [`std::hash::BuildHasherDefault`]
* [`HashMap::with_hasher`]
* [`HashMap::with_capacity_and_hasher`]
* [`HashSet::with_hasher`]
* [`HashSet::with_capacity_and_hasher`]
* [`std::collections::hash_map::RandomState`]
* [`RandomState::new`]
* [Validating UTF-8 is faster by a factor of between 7 and 14x for * [Validating UTF-8 is faster by a factor of between 7 and 14x for
ASCII input][1.7utf8]. This means that creating `String`s and `str`s ASCII input][1.7utf8]. This means that creating `String`s and `str`s
from bytes is faster. from bytes is faster.
@ -80,9 +81,6 @@ Libraries
Misc Misc
---- ----
* [The `--error-format=json` flag to `rustc` causes it to emit errors
in JSON format][1.7j]. This is an unstable flag and so also requires
the `-Z unstable-options` flag.
* [When running tests with `--test`, rustdoc will pass `--cfg` * [When running tests with `--test`, rustdoc will pass `--cfg`
arguments to the compiler][1.7dt]. arguments to the compiler][1.7dt].
* [The compiler is built with RPATH information by default][1.7rpa]. * [The compiler is built with RPATH information by default][1.7rpa].
@ -104,6 +102,12 @@ Cargo
Compatibility Notes Compatibility Notes
------------------- -------------------
* Soundness fixes to the interactions between associated types and
lifetimes, specified in [RFC 1214], [now generate errors][1.7sf] for
code that violates the new rules. This is a significant change that
is known to break existing code, so it has emitted warnings for the
new error cases since 1.4 to give crate authors time to adapt. The
details of what is changing are subtle; read the RFC for more.
* [Several bugs in the compiler's visibility calculations were * [Several bugs in the compiler's visibility calculations were
fixed][1.7v]. Since this was found to break significant amounts of fixed][1.7v]. Since this was found to break significant amounts of
code, the new errors will be emitted as warnings for several release code, the new errors will be emitted as warnings for several release
@ -126,7 +130,6 @@ Compatibility Notes
[1.7dta]: https://github.com/rust-lang/rust/pull/30394 [1.7dta]: https://github.com/rust-lang/rust/pull/30394
[1.7f]: https://github.com/rust-lang/rust/pull/30672 [1.7f]: https://github.com/rust-lang/rust/pull/30672
[1.7h]: https://github.com/rust-lang/rust/pull/30818 [1.7h]: https://github.com/rust-lang/rust/pull/30818
[1.7j]: https://github.com/rust-lang/rust/pull/30711
[1.7ll]: https://github.com/rust-lang/rust/pull/30663 [1.7ll]: https://github.com/rust-lang/rust/pull/30663
[1.7m]: https://github.com/rust-lang/rust/pull/30381 [1.7m]: https://github.com/rust-lang/rust/pull/30381
[1.7p]: https://github.com/rust-lang/rust/pull/30681 [1.7p]: https://github.com/rust-lang/rust/pull/30681
@ -137,11 +140,15 @@ Compatibility Notes
[1.7utf8]: https://github.com/rust-lang/rust/pull/30740 [1.7utf8]: https://github.com/rust-lang/rust/pull/30740
[1.7v]: https://github.com/rust-lang/rust/pull/29973 [1.7v]: https://github.com/rust-lang/rust/pull/29973
[RFC 1214]: https://github.com/rust-lang/rfcs/blob/master/text/1214-projections-lifetimes-and-wf.md [RFC 1214]: https://github.com/rust-lang/rfcs/blob/master/text/1214-projections-lifetimes-and-wf.md
[`clone_from_slice`]: http://doc.rust-lang.org/nightly/std/primitive.slice.html#method.clone_from_slice [`BuildHasher::Hasher`]: http://doc.rust-lang.org/nightly/std/hash/trait.Hasher.html
[`sort_by_key`]: http://doc.rust-lang.org/nightly/std/primitive.slice.html#method.sort_by_key [`BuildHasher::build_hasher`]: http://doc.rust-lang.org/nightly/std/hash/trait.BuildHasher.html#tymethod.build_hasher
[`CString::into_bytes_with_nul`]: http://doc.rust-lang.org/nightly/std/ffi/struct.CString.html#method.into_bytes_with_nul [`CString::into_bytes_with_nul`]: http://doc.rust-lang.org/nightly/std/ffi/struct.CString.html#method.into_bytes_with_nul
[`CString::into_bytes`]: http://doc.rust-lang.org/nightly/std/ffi/struct.CString.html#method.into_bytes [`CString::into_bytes`]: http://doc.rust-lang.org/nightly/std/ffi/struct.CString.html#method.into_bytes
[`CString::into_string`]: http://doc.rust-lang.org/nightly/std/ffi/struct.CString.html#method.into_string [`CString::into_string`]: http://doc.rust-lang.org/nightly/std/ffi/struct.CString.html#method.into_string
[`HashMap::with_capacity_and_hasher`]: http://doc.rust-lang.org/nightly/std/collections/struct.HashMap.html#method.with_capacity_and_hasher
[`HashMap::with_hasher`]: http://doc.rust-lang.org/nightly/std/collections/struct.HashMap.html#method.with_hasher
[`HashSet::with_capacity_and_hasher`]: http://doc.rust-lang.org/nightly/std/collections/struct.HashSet.html#method.with_capacity_and_hasher
[`HashSet::with_hasher`]: http://doc.rust-lang.org/nightly/std/collections/struct.HashSet.html#method.with_hasher
[`IntoStringError::into_cstring`]: http://doc.rust-lang.org/nightly/std/ffi/struct.IntoStringError.html#method.into_cstring [`IntoStringError::into_cstring`]: http://doc.rust-lang.org/nightly/std/ffi/struct.IntoStringError.html#method.into_cstring
[`IntoStringError::utf8_error`]: http://doc.rust-lang.org/nightly/std/ffi/struct.IntoStringError.html#method.utf8_error [`IntoStringError::utf8_error`]: http://doc.rust-lang.org/nightly/std/ffi/struct.IntoStringError.html#method.utf8_error
[`Ipv4Addr::is_broadcast`]: http://doc.rust-lang.org/nightly/std/net/struct.Ipv4Addr.html#method.is_broadcast [`Ipv4Addr::is_broadcast`]: http://doc.rust-lang.org/nightly/std/net/struct.Ipv4Addr.html#method.is_broadcast
@ -154,10 +161,12 @@ Compatibility Notes
[`Ipv6Addr::is_multicast`]: http://doc.rust-lang.org/nightly/std/net/struct.Ipv6Addr.html#method.is_multicast [`Ipv6Addr::is_multicast`]: http://doc.rust-lang.org/nightly/std/net/struct.Ipv6Addr.html#method.is_multicast
[`Ipv6Addr::is_unspecified`]: http://doc.rust-lang.org/nightly/std/net/struct.Ipv6Addr.html#method.is_unspecified [`Ipv6Addr::is_unspecified`]: http://doc.rust-lang.org/nightly/std/net/struct.Ipv6Addr.html#method.is_unspecified
[`Path::strip_prefix`]: http://doc.rust-lang.org/nightly/std/path/struct.Path.html#method.strip_prefix [`Path::strip_prefix`]: http://doc.rust-lang.org/nightly/std/path/struct.Path.html#method.strip_prefix
[`RandomState::new`]: http://doc.rust-lang.org/nightly/std/collections/hash_map/struct.RandomState.html#method.new
[`String::as_mut_str`]: http://doc.rust-lang.org/nightly/std/string/struct.String.html#method.as_mut_str [`String::as_mut_str`]: http://doc.rust-lang.org/nightly/std/string/struct.String.html#method.as_mut_str
[`String::as_str`]: http://doc.rust-lang.org/nightly/std/string/struct.String.html#method.as_str [`String::as_str`]: http://doc.rust-lang.org/nightly/std/string/struct.String.html#method.as_str
[`Vec::as_mut_slice`]: http://doc.rust-lang.org/nightly/std/vec/struct.Vec.html#method.as_mut_slice [`Vec::as_mut_slice`]: http://doc.rust-lang.org/nightly/std/vec/struct.Vec.html#method.as_mut_slice
[`Vec::as_slice`]: http://doc.rust-lang.org/nightly/std/vec/struct.Vec.html#method.as_slice [`Vec::as_slice`]: http://doc.rust-lang.org/nightly/std/vec/struct.Vec.html#method.as_slice
[`clone_from_slice`]: http://doc.rust-lang.org/nightly/std/primitive.slice.html#method.clone_from_slice
[`ffi::IntoStringError`]: http://doc.rust-lang.org/nightly/std/ffi/struct.IntoStringError.html [`ffi::IntoStringError`]: http://doc.rust-lang.org/nightly/std/ffi/struct.IntoStringError.html
[`i32::checked_neg`]: http://doc.rust-lang.org/nightly/std/primitive.i32.html#method.checked_neg [`i32::checked_neg`]: http://doc.rust-lang.org/nightly/std/primitive.i32.html#method.checked_neg
[`i32::checked_rem`]: http://doc.rust-lang.org/nightly/std/primitive.i32.html#method.checked_rem [`i32::checked_rem`]: http://doc.rust-lang.org/nightly/std/primitive.i32.html#method.checked_rem
@ -173,8 +182,13 @@ Compatibility Notes
[`i32::overflowing_sub`]: http://doc.rust-lang.org/nightly/std/primitive.i32.html#method.overflowing_sub [`i32::overflowing_sub`]: http://doc.rust-lang.org/nightly/std/primitive.i32.html#method.overflowing_sub
[`i32::saturating_mul`]: http://doc.rust-lang.org/nightly/std/primitive.i32.html#method.saturating_mul [`i32::saturating_mul`]: http://doc.rust-lang.org/nightly/std/primitive.i32.html#method.saturating_mul
[`path::StripPrefixError`]: http://doc.rust-lang.org/nightly/std/path/struct.StripPrefixError.html [`path::StripPrefixError`]: http://doc.rust-lang.org/nightly/std/path/struct.StripPrefixError.html
[`sort_by_key`]: http://doc.rust-lang.org/nightly/std/primitive.slice.html#method.sort_by_key
[`std::collections::hash_map::RandomState`]: http://doc.rust-lang.org/nightly/std/collections/hash_map/struct.RandomState.html
[`std::hash::BuildHasherDefault`]: http://doc.rust-lang.org/nightly/std/hash/struct.BuildHasherDefault.html
[`std::hash::BuildHasher`]: http://doc.rust-lang.org/nightly/std/hash/trait.BuildHasher.html
[`u32::checked_neg`]: http://doc.rust-lang.org/nightly/std/primitive.u32.html#method.checked_neg [`u32::checked_neg`]: http://doc.rust-lang.org/nightly/std/primitive.u32.html#method.checked_neg
[`u32::checked_rem`]: http://doc.rust-lang.org/nightly/std/primitive.u32.html#method.checked_rem [`u32::checked_rem`]: http://doc.rust-lang.org/nightly/std/primitive.u32.html#method.checked_rem
[`u32::checked_neg`]: http://doc.rust-lang.org/nightly/std/primitive.u32.html#method.checked_neg
[`u32::checked_shl`]: http://doc.rust-lang.org/nightly/std/primitive.u32.html#method.checked_shl [`u32::checked_shl`]: http://doc.rust-lang.org/nightly/std/primitive.u32.html#method.checked_shl
[`u32::overflowing_add`]: http://doc.rust-lang.org/nightly/std/primitive.u32.html#method.overflowing_add [`u32::overflowing_add`]: http://doc.rust-lang.org/nightly/std/primitive.u32.html#method.overflowing_add
[`u32::overflowing_div`]: http://doc.rust-lang.org/nightly/std/primitive.u32.html#method.overflowing_div [`u32::overflowing_div`]: http://doc.rust-lang.org/nightly/std/primitive.u32.html#method.overflowing_div

View File

@ -13,7 +13,7 @@
###################################################################### ######################################################################
# The version number # The version number
CFG_RELEASE_NUM=1.8.0 CFG_RELEASE_NUM=1.9.0
# An optional number to put after the label, e.g. '.2' -> '-beta.2' # An optional number to put after the label, e.g. '.2' -> '-beta.2'
# NB Make sure it starts with a dot to conform to semver pre-release # NB Make sure it starts with a dot to conform to semver pre-release

View File

@ -211,9 +211,10 @@ fn main() {
``` ```
In other words, the mutable borrow is held through the rest of our example. What In other words, the mutable borrow is held through the rest of our example. What
we want is for the mutable borrow to end _before_ we try to call `println!` and we want is for the mutable borrow by `y` to end so that the resource can be
make an immutable borrow. In Rust, borrowing is tied to the scope that the returned to the owner, `x`. `x` can then provide a mutable borrow to `println!`.
borrow is valid for. And our scopes look like this: In Rust, borrowing is tied to the scope that the borrow is valid for. And our
scopes look like this:
```rust,ignore ```rust,ignore
let mut x = 5; let mut x = 5;
@ -378,4 +379,3 @@ statement 1 at 3:14
In the above example, `y` is declared before `x`, meaning that `y` lives longer In the above example, `y` is declared before `x`, meaning that `y` lives longer
than `x`, which is not allowed. than `x`, which is not allowed.

View File

@ -4,7 +4,7 @@ Rusts main draw is its powerful static guarantees about behavior. But safety
checks are conservative by nature: there are some programs that are actually checks are conservative by nature: there are some programs that are actually
safe, but the compiler is not able to verify this is true. To write these kinds safe, but the compiler is not able to verify this is true. To write these kinds
of programs, we need to tell the compiler to relax its restrictions a bit. For of programs, we need to tell the compiler to relax its restrictions a bit. For
this, Rust has a keyword, `unsafe`. Code using `unsafe` has less restrictions this, Rust has a keyword, `unsafe`. Code using `unsafe` has fewer restrictions
than normal code does. than normal code does.
Lets go over the syntax, and then well talk semantics. `unsafe` is used in Lets go over the syntax, and then well talk semantics. `unsafe` is used in

View File

@ -12,7 +12,7 @@
//! up to a certain length. Eventually we should able to generalize //! up to a certain length. Eventually we should able to generalize
//! to all lengths. //! to all lengths.
//! //!
//! *[See also the array primitive type](../primitive.array.html).* //! *[See also the array primitive type](../../std/primitive.array.html).*
#![unstable(feature = "fixed_size_array", #![unstable(feature = "fixed_size_array",
reason = "traits and impls are better expressed through generic \ reason = "traits and impls are better expressed through generic \

View File

@ -10,7 +10,7 @@
//! The 16-bit signed integer type. //! The 16-bit signed integer type.
//! //!
//! *[See also the `i16` primitive type](../primitive.i16.html).* //! *[See also the `i16` primitive type](../../std/primitive.i16.html).*
#![stable(feature = "rust1", since = "1.0.0")] #![stable(feature = "rust1", since = "1.0.0")]

View File

@ -10,7 +10,7 @@
//! The 32-bit signed integer type. //! The 32-bit signed integer type.
//! //!
//! *[See also the `i32` primitive type](../primitive.i32.html).* //! *[See also the `i32` primitive type](../../std/primitive.i32.html).*
#![stable(feature = "rust1", since = "1.0.0")] #![stable(feature = "rust1", since = "1.0.0")]

View File

@ -10,7 +10,7 @@
//! The 64-bit signed integer type. //! The 64-bit signed integer type.
//! //!
//! *[See also the `i64` primitive type](../primitive.i64.html).* //! *[See also the `i64` primitive type](../../std/primitive.i64.html).*
#![stable(feature = "rust1", since = "1.0.0")] #![stable(feature = "rust1", since = "1.0.0")]

View File

@ -10,7 +10,7 @@
//! The 8-bit signed integer type. //! The 8-bit signed integer type.
//! //!
//! *[See also the `i8` primitive type](../primitive.i8.html).* //! *[See also the `i8` primitive type](../../std/primitive.i8.html).*
#![stable(feature = "rust1", since = "1.0.0")] #![stable(feature = "rust1", since = "1.0.0")]

View File

@ -10,7 +10,7 @@
//! The pointer-sized signed integer type. //! The pointer-sized signed integer type.
//! //!
//! *[See also the `isize` primitive type](../primitive.isize.html).* //! *[See also the `isize` primitive type](../../std/primitive.isize.html).*
#![stable(feature = "rust1", since = "1.0.0")] #![stable(feature = "rust1", since = "1.0.0")]

View File

@ -10,7 +10,7 @@
//! The 16-bit unsigned integer type. //! The 16-bit unsigned integer type.
//! //!
//! *[See also the `u16` primitive type](../primitive.u16.html).* //! *[See also the `u16` primitive type](../../std/primitive.u16.html).*
#![stable(feature = "rust1", since = "1.0.0")] #![stable(feature = "rust1", since = "1.0.0")]

View File

@ -10,7 +10,7 @@
//! The 32-bit unsigned integer type. //! The 32-bit unsigned integer type.
//! //!
//! *[See also the `u32` primitive type](../primitive.u32.html).* //! *[See also the `u32` primitive type](../../std/primitive.u32.html).*
#![stable(feature = "rust1", since = "1.0.0")] #![stable(feature = "rust1", since = "1.0.0")]

View File

@ -10,7 +10,7 @@
//! The 64-bit unsigned integer type. //! The 64-bit unsigned integer type.
//! //!
//! *[See also the `u64` primitive type](../primitive.u64.html).* //! *[See also the `u64` primitive type](../../std/primitive.u64.html).*
#![stable(feature = "rust1", since = "1.0.0")] #![stable(feature = "rust1", since = "1.0.0")]

View File

@ -10,7 +10,7 @@
//! The 8-bit unsigned integer type. //! The 8-bit unsigned integer type.
//! //!
//! *[See also the `u8` primitive type](../primitive.u8.html).* //! *[See also the `u8` primitive type](../../std/primitive.u8.html).*
#![stable(feature = "rust1", since = "1.0.0")] #![stable(feature = "rust1", since = "1.0.0")]

View File

@ -10,7 +10,7 @@
//! The pointer-sized unsigned integer type. //! The pointer-sized unsigned integer type.
//! //!
//! *[See also the `usize` primitive type](../primitive.usize.html).* //! *[See also the `usize` primitive type](../../std/primitive.usize.html).*
#![stable(feature = "rust1", since = "1.0.0")] #![stable(feature = "rust1", since = "1.0.0")]

View File

@ -12,7 +12,7 @@
//! Raw, unsafe pointers, `*const T`, and `*mut T` //! Raw, unsafe pointers, `*const T`, and `*mut T`
//! //!
//! *[See also the pointer primitive types](../primitive.pointer.html).* //! *[See also the pointer primitive types](../../std/primitive.pointer.html).*
#![stable(feature = "rust1", since = "1.0.0")] #![stable(feature = "rust1", since = "1.0.0")]