Skip to content

Commit 78e205d

Browse files
committed
---
yaml --- r: 212319 b: refs/heads/tmp c: bea1c4a h: refs/heads/master i: 212317: 378c317 212315: d2584a5 212311: b68f2c8 212303: 8df802f 212287: d07e094 v: v3
1 parent a5a4ca4 commit 78e205d

Some content is hidden

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

87 files changed

+1446
-937
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -32,7 +32,7 @@ refs/heads/building: 126db549b038c84269a1e4fe46f051b2c15d6970
3232
refs/heads/beta: 62e70d35be3fe532c26a400b499c58a18f18dd3a
3333
refs/heads/windistfix: 7608dbad651f02e837ed05eef3d74a6662a6e928
3434
refs/tags/1.0.0-alpha: e42bd6d93a1d3433c486200587f8f9e12590a4d7
35-
refs/heads/tmp: ec078a033bdd2a4d076f78f2e655b8c3e5e4bf6a
35+
refs/heads/tmp: bea1c4a78e5233ea6f85a2028a26e08c26635fca
3636
refs/tags/1.0.0-alpha.2: 4c705f6bc559886632d3871b04f58aab093bfa2f
3737
refs/tags/homu-tmp: 0b0c89efb37d1f7f6a72bf1a82a505cd1ca8b8eb
3838
refs/heads/gate: 97c84447b65164731087ea82685580cc81424412

branches/tmp/AUTHORS.txt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -338,7 +338,7 @@ Hajime Morrita <[email protected]>
338338
Hanno Braun <[email protected]>
339339
Harry Marr <[email protected]>
340340
341-
Heejong Ahn <[email protected]
341+
Heejong Ahn <[email protected]>
342342
Henrik Schopmans <[email protected]>
343343
Herman J. Radtke III <[email protected]>
344344
HeroesGrave <[email protected]>

branches/tmp/configure

Lines changed: 25 additions & 22 deletions
Original file line numberDiff line numberDiff line change
@@ -582,6 +582,7 @@ valopt sysconfdir "/etc" "install system configuration files"
582582
valopt datadir "${CFG_PREFIX}/share" "install data"
583583
valopt infodir "${CFG_PREFIX}/share/info" "install additional info"
584584
valopt llvm-root "" "set LLVM root"
585+
valopt python "" "set path to python"
585586
valopt jemalloc-root "" "set directory where libjemalloc_pic.a is located"
586587
valopt build "${DEFAULT_BUILD}" "GNUs ./configure syntax LLVM build triple"
587588
valopt android-cross-path "/opt/ndk_standalone" "Android NDK standalone path"
@@ -695,7 +696,9 @@ putvar CFG_BOOTSTRAP_KEY
695696
step_msg "looking for build programs"
696697

697698
probe_need CFG_CURLORWGET curl wget
698-
probe_need CFG_PYTHON python2.7 python2.6 python2 python
699+
if [ -z "$CFG_PYTHON_PROVIDED" ]; then
700+
probe_need CFG_PYTHON python2.7 python2.6 python2 python
701+
fi
699702

700703
python_version=$($CFG_PYTHON -V 2>&1)
701704
if [ $(echo $python_version | grep -c '^Python 2\.[4567]') -ne 1 ]; then
@@ -849,13 +852,6 @@ then
849852
putvar CFG_LOCAL_RUST_ROOT
850853
fi
851854

852-
# Force freebsd to build with clang; gcc doesn't like us there
853-
if [ $CFG_OSTYPE = unknown-freebsd ]
854-
then
855-
step_msg "on FreeBSD, forcing use of clang"
856-
CFG_ENABLE_CLANG=1
857-
fi
858-
859855
# Force bitrig to build with clang; gcc doesn't like us there
860856
if [ $CFG_OSTYPE = unknown-bitrig ]
861857
then
@@ -973,8 +969,8 @@ fi
973969

974970
if [ ! -z "$CFG_ENABLE_CLANG" ]
975971
then
976-
if [ -z "$CC" ] || [[ $CC == *clang ]]
977-
then
972+
case "$CC" in
973+
(''|*clang)
978974
CFG_CLANG_VERSION=$($CFG_CC \
979975
--version \
980976
| grep version \
@@ -994,9 +990,11 @@ then
994990
err "bad CLANG version: $CFG_CLANG_VERSION, need >=3.0svn"
995991
;;
996992
esac
997-
else
993+
;;
994+
(*)
998995
msg "skipping CFG_ENABLE_CLANG version check; provided CC=$CC"
999-
fi
996+
;;
997+
esac
1000998
fi
1001999

10021000
if [ ! -z "$CFG_ENABLE_CCACHE" ]
@@ -1309,6 +1307,12 @@ CFG_LLVM_SRC_DIR=${CFG_SRC_DIR}src/llvm/
13091307
for t in $CFG_HOST
13101308
do
13111309
do_reconfigure=1
1310+
is_msvc=0
1311+
case "$t" in
1312+
(*-msvc)
1313+
is_msvc=1
1314+
;;
1315+
esac
13121316

13131317
if [ -z $CFG_LLVM_ROOT ]
13141318
then
@@ -1328,7 +1332,13 @@ do
13281332
LLVM_ASSERTION_OPTS="--disable-assertions"
13291333
else
13301334
LLVM_ASSERTION_OPTS="--enable-assertions"
1331-
LLVM_INST_DIR=${LLVM_INST_DIR}+Asserts
1335+
1336+
# Apparently even if we request assertions be enabled for MSVC,
1337+
# LLVM's CMake build system ignore this and outputs in `Release`
1338+
# anyway.
1339+
if [ ${is_msvc} -eq 0 ]; then
1340+
LLVM_INST_DIR=${LLVM_INST_DIR}+Asserts
1341+
fi
13321342
fi
13331343
else
13341344
msg "not reconfiguring LLVM, external LLVM root"
@@ -1358,14 +1368,7 @@ do
13581368
done
13591369
fi
13601370

1361-
use_cmake=0
1362-
case "$t" in
1363-
(*-msvc)
1364-
use_cmake=1
1365-
;;
1366-
esac
1367-
1368-
if [ ${do_reconfigure} -ne 0 ] && [ ${use_cmake} -ne 0 ]
1371+
if [ ${do_reconfigure} -ne 0 ] && [ ${is_msvc} -ne 0 ]
13691372
then
13701373
msg "configuring LLVM for $t with cmake"
13711374

@@ -1390,7 +1393,7 @@ do
13901393
need_ok "LLVM cmake configure failed"
13911394
fi
13921395

1393-
if [ ${do_reconfigure} -ne 0 ] && [ ${use_cmake} -eq 0 ]
1396+
if [ ${do_reconfigure} -ne 0 ] && [ ${is_msvc} -eq 0 ]
13941397
then
13951398
# LLVM's configure doesn't recognize the new Windows triples yet
13961399
gnu_t=$(to_gnu_triple $t)

branches/tmp/mk/docs.mk

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -265,7 +265,7 @@ endef
265265
$(foreach crate,$(CRATES),$(eval $(call DEF_LIB_DOC,$(crate))))
266266

267267
COMPILER_DOC_TARGETS := $(CRATES:%=doc/%/index.html)
268-
ifdef CFG_COMPILER_DOCS
268+
ifdef CFG_ENABLE_COMPILER_DOCS
269269
DOC_TARGETS += $(COMPILER_DOC_TARGETS)
270270
else
271271
DOC_TARGETS += $(DOC_CRATES:%=doc/%/index.html)

branches/tmp/src/compiletest/runtest.rs

Lines changed: 5 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -24,7 +24,6 @@ use std::fmt;
2424
use std::fs::{self, File};
2525
use std::io::BufReader;
2626
use std::io::prelude::*;
27-
use std::iter::repeat;
2827
use std::net::TcpStream;
2928
use std::path::{Path, PathBuf};
3029
use std::process::{Command, Output, ExitStatus};
@@ -928,12 +927,12 @@ fn check_forbid_output(props: &TestProps,
928927
}
929928
}
930929

931-
fn check_expected_errors(expected_errors: Vec<errors::ExpectedError> ,
930+
fn check_expected_errors(expected_errors: Vec<errors::ExpectedError>,
932931
testfile: &Path,
933932
proc_res: &ProcRes) {
934933

935934
// true if we found the error in question
936-
let mut found_flags: Vec<_> = repeat(false).take(expected_errors.len()).collect();
935+
let mut found_flags = vec![false; expected_errors.len()];
937936

938937
if proc_res.status.success() {
939938
fatal("process did not return an error status");
@@ -954,14 +953,10 @@ fn check_expected_errors(expected_errors: Vec<errors::ExpectedError> ,
954953
}
955954
}
956955

957-
// A multi-line error will have followup lines which will always
958-
// start with one of these strings.
956+
// A multi-line error will have followup lines which start with a space
957+
// or open paren.
959958
fn continuation( line: &str) -> bool {
960-
line.starts_with(" expected") ||
961-
line.starts_with(" found") ||
962-
// 1234
963-
// Should have 4 spaces: see issue 18946
964-
line.starts_with("(")
959+
line.starts_with(" ") || line.starts_with("(")
965960
}
966961

967962
// Scan and extract our error/warning messages,

branches/tmp/src/doc/index.md

Lines changed: 7 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -25,7 +25,7 @@ series of small examples.
2525
If you need help with something, or just want to talk about Rust with others,
2626
there are a few places you can do that:
2727

28-
The Rust IRC channels on [irc.mozilla.org](http://irc.mozilla.org/) are the
28+
The Rust IRC channels on [irc.mozilla.org](irc://irc.mozilla.org/) are the
2929
fastest way to get help.
3030
[`#rust`](http://chat.mibbit.com/?server=irc.mozilla.org&channel=%23rust) is
3131
the general discussion channel, and you'll find people willing to help you with
@@ -40,15 +40,15 @@ There's also
4040
[`#rust-internals`](http://chat.mibbit.com/?server=irc.mozilla.org&channel=%23rust-internals), which is for discussion of the development of Rust itself.
4141

4242
You can also get help on [Stack
43-
Overflow](http://stackoverflow.com/questions/tagged/rust). Searching for your
43+
Overflow](https://stackoverflow.com/questions/tagged/rust). Searching for your
4444
problem might reveal someone who has asked it before!
4545

46-
There is an active [subreddit](http://reddit.com/r/rust) with lots of
46+
There is an active [subreddit](https://reddit.com/r/rust) with lots of
4747
discussion and news about Rust.
4848

49-
There is also a [user forum](http://users.rust-lang.org), for all
50-
user-oriented discussion, and a [developer
51-
forum](http://internals.rust-lang.org/), where the development of Rust
49+
There is also a [user forum](https://users.rust-lang.org), for all
50+
user-oriented discussion, and a [developer
51+
forum](https://internals.rust-lang.org/), where the development of Rust
5252
itself is discussed.
5353

5454
# Specification
@@ -61,7 +61,7 @@ the language in as much detail as possible is in [the reference](reference.html)
6161
Rust is still a young language, so there isn't a ton of tooling yet, but the
6262
tools we have are really nice.
6363

64-
[Cargo](http://crates.io) is Rust's package manager, and its website contains
64+
[Cargo](https://crates.io) is Rust's package manager, and its website contains
6565
lots of good documentation.
6666

6767
[`rustdoc`](book/documentation.html) is used to generate documentation for Rust code.

branches/tmp/src/doc/reference.md

Lines changed: 141 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -1943,9 +1943,6 @@ macro scope.
19431943
- `simd` - on certain tuple structs, derive the arithmetic operators, which
19441944
lower to the target's SIMD instructions, if any; the `simd` feature gate
19451945
is necessary to use this attribute.
1946-
- `static_assert` - on statics whose type is `bool`, terminates compilation
1947-
with an error if it is not initialized to `true`. To use this, the `static_assert`
1948-
feature gate must be enabled.
19491946
- `unsafe_no_drop_flag` - on structs, remove the flag that prevents
19501947
destructors from being run twice. Destructors might be run multiple times on
19511948
the same object with this attribute. To use this, the `unsafe_no_drop_flag` feature
@@ -2301,12 +2298,6 @@ The currently implemented features of the reference compiler are:
23012298
crate. Stability markers are also attributes: `#[stable]`,
23022299
`#[unstable]`, and `#[deprecated]` are the three levels.
23032300

2304-
* `static_assert` - The `#[static_assert]` functionality is experimental and
2305-
unstable. The attribute can be attached to a `static` of
2306-
type `bool` and the compiler will error if the `bool` is
2307-
`false` at compile time. This version of this functionality
2308-
is unintuitive and suboptimal.
2309-
23102301
* `start` - Allows use of the `#[start]` attribute, which changes the entry point
23112302
into a Rust program. This capability, especially the signature for the
23122303
annotated function, is subject to change.
@@ -3608,6 +3599,147 @@ The notation `&self` is a shorthand for `self: &Self`. In this case,
36083599
in the impl, `Self` refers to the value of type `String` that is the
36093600
receiver for a call to the method `make_string`.
36103601

3602+
## Subtyping
3603+
3604+
Subtyping is implicit and can occur at any stage in type checking or
3605+
inference. Subtyping in Rust is very restricted and occurs only due to
3606+
variance with respect to lifetimes and between types with higher ranked
3607+
lifetimes. If we were to erase lifetimes from types, then the only subtyping
3608+
would be due to type equality.
3609+
3610+
Consider the following example: string literals always have `'static`
3611+
lifetime. Nevertheless, we can assign `s` to `t`:
3612+
3613+
```
3614+
fn bar<'a>() {
3615+
let s: &'static str = "hi";
3616+
let t: &'a str = s;
3617+
}
3618+
```
3619+
Since `'static` "lives longer" than `'a`, `&'static str` is a subtype of
3620+
`&'a str`.
3621+
3622+
## Type coercions
3623+
3624+
Coercions are defined in [RFC401]. A coercion is implicit and has no syntax.
3625+
3626+
[RFC401]: https://github.com/rust-lang/rfcs/blob/master/text/0401-coercions.md
3627+
3628+
### Coercion sites
3629+
3630+
A coercion can only occur at certain coercion sites in a program; these are
3631+
typically places where the desired type is explicit or can be dervied by
3632+
propagation from explicit types (without type inference). Possible coercion
3633+
sites are:
3634+
3635+
* `let` statements where an explicit type is given.
3636+
3637+
In `let _: U = e;`, `e` is coerced to have type `U`.
3638+
3639+
* `static` and `const` statements (similar to `let` statements).
3640+
3641+
* arguments for function calls.
3642+
3643+
The value being coerced is the
3644+
actual parameter and it is coerced to the type of the formal parameter. For
3645+
example, let `foo` be defined as `fn foo(x: U) { ... }` and call it as
3646+
`foo(e);`. Then `e` is coerced to have type `U`;
3647+
3648+
* instantiations of struct or variant fields.
3649+
3650+
Assume we have a `struct
3651+
Foo { x: U }` and instantiate it as `Foo { x: e }`. Then `e` is coerced to
3652+
have type `U`.
3653+
3654+
* function results (either the final line of a block if it is not semicolon
3655+
terminated or any expression in a `return` statement).
3656+
3657+
In `fn foo() -> U { e }`, `e` is coerced to to have type `U`.
3658+
3659+
If the expression in one of these coercion sites is a coercion-propagating
3660+
expression, then the relevant sub-expressions in that expression are also
3661+
coercion sites. Propagation recurses from these new coercion sites.
3662+
Propagating expressions and their relevant sub-expressions are:
3663+
3664+
* array literals, where the array has type `[U; n]`. Each sub-expression in
3665+
the array literal is a coercion site for coercion to type `U`.
3666+
3667+
* array literals with repeating syntax, where the array has type `[U; n]`. The
3668+
repeated sub-expression is a coercion site for coercion to type `U`.
3669+
3670+
* tuples, where a tuple is a coercion site to type `(U_0, U_1, ..., U_n)`.
3671+
Each sub-expression is a coercion site to the respective type, e.g. the
3672+
zeroth sub-expression is a coercion site to type `U_0`.
3673+
3674+
* parenthesised sub-expressions (`(e)`). If the expression has type `U`, then
3675+
the sub-expression is a coercion site to `U`.
3676+
3677+
* blocks. If a block has type `U`, then the last expression in the block (if
3678+
it is not semicolon-terminated) is a coercion site to `U`. This includes
3679+
blocks which are part of control flow statements, such as `if`/`else`, if
3680+
the block has a known type.
3681+
3682+
### Coercion types
3683+
3684+
Coercion is allowed between the following types:
3685+
3686+
* `T` to `U` if `T` is a subtype of `U` (*reflexive case*).
3687+
3688+
* `T_1` to `T_3` where `T_1` coerces to `T_2` and `T_2` coerces to `T_3`
3689+
(*transitive case*).
3690+
3691+
Note that this is not fully supported yet
3692+
3693+
* `&mut T` to `&T`.
3694+
3695+
* `*mut T` to `*const T`.
3696+
3697+
* `&T` to `*const T`.
3698+
3699+
* `&mut T` to `*mut T`.
3700+
3701+
* `&T` to `&U` if `T` implements `Deref<Target = U>`. For example:
3702+
3703+
```rust
3704+
use std::ops::Deref;
3705+
3706+
struct CharContainer {
3707+
value: char
3708+
}
3709+
3710+
impl Deref for CharContainer {
3711+
type Target = char;
3712+
3713+
fn deref<'a>(&'a self) -> &'a char {
3714+
&self.value
3715+
}
3716+
}
3717+
3718+
fn foo(arg: &char) {}
3719+
3720+
fn main() {
3721+
let x = &mut CharContainer { value: 'y' };
3722+
foo(x); //&mut CharContainer is coerced to &char.
3723+
}
3724+
```
3725+
* `&mut T` to `&mut U` if `T` implements `DerefMut<Target = U>`.
3726+
3727+
* TyCtor(`T`) to TyCtor(coerce_inner(`T`)), where TyCtor(`T`) is one of
3728+
- `&T`
3729+
- `&mut T`
3730+
- `*const T`
3731+
- `*mut T`
3732+
- `Box<T>`
3733+
3734+
and where
3735+
- coerce_inner(`[T, ..n]`) = `[T]`
3736+
- coerce_inner(`T`) = `U` where `T` is a concrete type which implements the
3737+
trait `U`.
3738+
3739+
In the future, coerce_inner will be recursively extended to tuples and
3740+
structs. In addition, coercions from sub-traits to super-traits will be
3741+
added. See [RFC401] for more details.
3742+
36113743
# Special traits
36123744

36133745
Several traits define special evaluation behavior.

0 commit comments

Comments
 (0)