]> git.lizzy.rs Git - rust.git/log
rust.git
6 years agoRemove deprecated message
Kornel [Tue, 7 Nov 2017 11:23:20 +0000 (11:23 +0000)]
Remove deprecated message

Second stage of #43067

6 years agoAuto merge of #45571 - zackmdavis:regenerate_char_private, r=alexcrichton
bors [Tue, 7 Nov 2017 02:07:34 +0000 (02:07 +0000)]
Auto merge of #45571 - zackmdavis:regenerate_char_private, r=alexcrichton

regenerate libcore/char_private.rs

(filed separately from the work in #45569, because of this matter of the updated Unicode data; see also #45567)

char_private.rs is generated programmatically by char_private.py, using data retrieved from the Unicode Consortium's website.

The motivation here was to make `is_printable` crate-visible (with `pub(crate)`), but it would seem that the Unicode data has changed slightly since char_private.rs was last generated.

6 years agoAuto merge of #45668 - nikomatsakis:nll-free-region, r=arielb1
bors [Mon, 6 Nov 2017 23:30:57 +0000 (23:30 +0000)]
Auto merge of #45668 - nikomatsakis:nll-free-region, r=arielb1

extend NLL with preliminary support for free regions on functions

This PR extends https://github.com/rust-lang/rust/pull/45538 with support for free regions. This is pretty preliminary and will no doubt want to change in various ways, particularly as we add support for closures, but it's enough to get the basic idea in place:

- We now create specific regions to represent each named lifetime declared on the function.
- Region values can contain references to these regions (represented for now as a `BTreeSet<RegionIndex>`).
- If we wind up trying to infer that `'a: 'b` must hold, but no such relationship was declared, we report an error.

It also does a number of drive-by refactorings.

r? @arielb1

cc @spastorino

6 years agoAuto merge of #45811 - DSpeckhals:update-rustfmt-rls, r=nikomatsakis
bors [Mon, 6 Nov 2017 20:43:46 +0000 (20:43 +0000)]
Auto merge of #45811 - DSpeckhals:update-rustfmt-rls, r=nikomatsakis

tools: Fix rustfmt and the RLS

These tools have been corrected in their upstream repo's, and the submodules have been updated here to reflect that. I also had to update Cargo to match what the RLS is expecting.

The tool states for `rustfmt` and `rls` where both changed from "Broken" to "Testing" in this commit, thus enabling testing and distribution again.

6 years agoAuto merge of #45322 - infinity0:master, r=alexcrichton
bors [Mon, 6 Nov 2017 18:04:13 +0000 (18:04 +0000)]
Auto merge of #45322 - infinity0:master, r=alexcrichton

When cross-compiling, also build target-arch tarballs for libstd. (Closes: #42320)

Half of the logic is actually in there already in install.rs:install_std but it fails with an error like:

sh: 0: Can't open /<<BUILDDIR>>/rustc-1.21.0+dfsg1/build/tmp/dist/rust-std-1.21.0-powerpc64le-unknown-linux-gnu/install.sh

because the target-arch dist tarball wasn't built as well. This commit fixes that so the overall install works.

There is one minor bug in the existing code which this commit doesn't fix - the install.log from multiple runs of the installer gets clobbered, which seems like it might interfere with the uninstall process (I didn't look very deeply into this, because it doesn't affect what I need to do.) The actual installed files under DESTDIR seem fine though - either they are installed under an arch-specific path, or the multiple runs will clobber the same path with the same arch-independent file.

6 years agotools: Fix rustfmt and the RLS
Dustin Speckhals [Mon, 6 Nov 2017 17:59:33 +0000 (12:59 -0500)]
tools: Fix rustfmt and the RLS

These tools have been corrected in their upstream repo's, and the
submodules have been updated here to reflect that. I also had to update
Cargo to match what the RLS is expecting.

The tool states for `rustfmt` and `rls` where both changed from "Broken"
to "Testing" in this commit, thus enabling testing and distribution
again.

6 years agoAuto merge of #45369 - fintelia:patch-1, r=BurntSushi
bors [Mon, 6 Nov 2017 15:19:48 +0000 (15:19 +0000)]
Auto merge of #45369 - fintelia:patch-1, r=BurntSushi

Implement is_empty() for BufReader

Simple implementation of `is_empty` method for BufReader so it is possible to tell whether there is any data in its buffer.

I didn't know correct stability annotation to place on the function. Presumably there is no reason to place this feature behind a feature flag, but I wasn't sure how to tag it as an unstable feature without that.

CC: #45323
6 years agoAuto merge of #45737 - oli-obk:json, r=petrochenkov
bors [Mon, 6 Nov 2017 12:18:12 +0000 (12:18 +0000)]
Auto merge of #45737 - oli-obk:json, r=petrochenkov

Pretty print json in ui tests

I found the json output in one line to not be useful for reviewing

r? @petrochenkov

6 years agoEnsure dist::Std for every libstd target. (Closes: #42320)
Ximin Luo [Mon, 6 Nov 2017 10:34:18 +0000 (11:34 +0100)]
Ensure dist::Std for every libstd target. (Closes: #42320)

This fixes cross-compile installation. Half of the logic is actually in there
already in install.rs:install_std but it fails with an error like:

sh: 0: Can't open /<<BUILDDIR>>/rustc-1.21.0+dfsg1/build/tmp/dist/rust-std-1.21.0-powerpc64le-unknown-linux-gnu/install.sh

because the target-arch dist tarball wasn't built as well.

6 years agoAdjust json errors to byte changes
Oliver Schneider [Mon, 6 Nov 2017 09:34:23 +0000 (10:34 +0100)]
Adjust json errors to byte changes

6 years agoAuto merge of #45798 - nrc:rls-bugs-3, r=eddyb
bors [Mon, 6 Nov 2017 08:48:11 +0000 (08:48 +0000)]
Auto merge of #45798 - nrc:rls-bugs-3, r=eddyb

A couple more save-analysis fixes

r? @eddyb

6 years agoAuto merge of #45758 - nzig:explain-span-ctxt, r=petrochenkov
bors [Mon, 6 Nov 2017 05:16:15 +0000 (05:16 +0000)]
Auto merge of #45758 - nzig:explain-span-ctxt, r=petrochenkov

Add comment explaining the ctxt field in Span

As discussed in #45747.

r? @petrochenkov

6 years agosave-analysis: fix bugs in method chains
Nick Cameron [Mon, 6 Nov 2017 02:52:42 +0000 (15:52 +1300)]
save-analysis: fix bugs in method chains

Use the span we save in the PathSegment for a method call, rather than searching for it in the text.

Fixes https://github.com/nrc/rls-analysis/issues/111

6 years agoAuto merge of #45756 - topecongiro:fix-typos/librustc_typeck, r=kennytm
bors [Mon, 6 Nov 2017 02:02:11 +0000 (02:02 +0000)]
Auto merge of #45756 - topecongiro:fix-typos/librustc_typeck, r=kennytm

Fix typos in README.md

This nitpicky PR fixes few typos I found while reading `README.md`s.

6 years agosave-analysis: give better info for Unions
Nick Cameron [Mon, 6 Nov 2017 01:56:43 +0000 (14:56 +1300)]
save-analysis: give better info for Unions

6 years agoAuto merge of #45770 - spastorino:newtype_index, r=nikomatsakis
bors [Sun, 5 Nov 2017 22:06:15 +0000 (22:06 +0000)]
Auto merge of #45770 - spastorino:newtype_index, r=nikomatsakis

Make last structs indexes definitions use newtype_index macro

This PR makes the last two index structs not using newtype_index macro to use it and also fixes this https://github.com/rust-lang/rust/issues/45763 issue.

6 years agoAuto merge of #45723 - sinkuu:ice_45493, r=arielb1
bors [Sun, 5 Nov 2017 19:19:59 +0000 (19:19 +0000)]
Auto merge of #45723 - sinkuu:ice_45493, r=arielb1

Fix MIR inlining panic in generic function

MIR inlining calls `Instance::resolve` with a substs containing param, and `trans_apply_param_substs` panics. ~~This PR fixes it by making `Instance::resolve` return `None` if `substs.has_param_types()`, though I'm not sure if this is a right fix.~~

Fixes #45493.

6 years agoAuto merge of #45072 - nikomatsakis:issue-38714, r=arielb1
bors [Sun, 5 Nov 2017 16:49:08 +0000 (16:49 +0000)]
Auto merge of #45072 - nikomatsakis:issue-38714, r=arielb1

new rules for merging expected and supplied types in closure signatures

As uncovered in #38714, we currently have some pretty bogus code for combining the "expected signature" of a closure with the "supplied signature". To set the scene, consider a case like this:

```rust
fn foo<F>(f: F)
where
  F: for<'a> FnOnce(&'a u32) -> &'a u32
  // ^ *expected* signature comes from this where-clause
{
    ...
}

fn main() {
    foo(|x: &u32| -> &u32 { .. }
     // ^^^^^^^^^^^^^^^^^ supplied signature
     // comes from here
}
```

In this case, the supplied signature (a) includes all the parts and (b) is the same as the expected signature, modulo the names used for the regions. But often people supply only *some* parts of the signature. For example, one might write `foo(|x| ..)`, leaving *everything* to be inferred, or perhaps `foo(|x: &u32| ...)`, which leaves the return type to be inferred.

In the current code, we use the expected type to supply the types that are not given, but otherwise use the type the user gave, except for one case: if the user writes `fn foo(|x: _| ..)` (i.e., an underscore at the outermost level), then we will take the expected type (rather than instantiating a fresh type variable). This can result in nonsensical situations, particularly with bound regions that link the types of parameters to one another or to the return type. Consider `foo(|x: &u32| ...)` -- if we *literally* splice the expected return type of `&'a u32` together with what the user gave, we wind up with a signature like `for<'a> fn(&u32) -> &'a u32`. This is not even permitted as a type, because bound regions like `'a` must appear also in the arguments somewhere, which is why #38714 leads to an ICE.

This PR institutes some new rules. These are not meant to be the *final* set of rules, but they are a kind of "lower bar" for what kind of code we accept (i.e., we can extend these rules in the future to be smarter in some cases, but -- as we will see -- these rules do accept some things that we then would not be able to back off from).

These rules are derived from a few premises:

- First and foremost, anonymous regions in closure annotation are mostly requests for the code to "figure out the right lifetime" and shouldn't be read too closely. So for example when people write a closure signature like `|x: &u32|`, they are really intended for us to "figure out" the right region for `x`.
    - In contrast, the current code treats this supplied type as being more definitive. In particular, writing `|x: &u32|` would always result in the region of `x` being bound in the closure type. In other words, the signature would be something like `for<'a> fn(&'a u32)` -- this is derived from the fact that `fn(&u32)` expands to a type where the region is bound in the fn type.
    - This PR takes a different approach. The "binding level" for reference types appearing in closure signatures can be informed in some cases by the expected signature. So, for example, if the expected signature is something like `(&'f u32)`, where the region of the first argument appears free, then for `|x: &u32|`, the new code would infer `x` to also have the free region `'f`.
        - This inference has some limits. We don't do this for bindings that appear within the selected types themselves. So e.g. `|x: fn(&u32)|`, when combined with an expected type of `fn(fn(&'f u32))`, would still result in a closure that expects `for<'a> fn(&'a u32)`. Such an annotation will ultimately result in an error, as it happens, since `foo` is supplying a `fn(&'f u32)` to the closure, but the closure signature demands a `for<'a> fn(&'a u32)`. But still we choose to trust it and have the user change it.
        - I wanted to preserve the rough intuition that one can copy-and-paste a type out of the fn signature and into the fn body without dramatically changing its meaning. Interestingly, if one has `|x: &u32|`, then regardless of whether the region of `x` is bound or free in the closure signature, it is also free in the region body, and that is also true when one writes `let x: &u32`, so that intuition holds here. But the same would not be true for `fn(&u32)`, hence the different behavior.
- Second, we must take either **all** the references to bound regions from the expected type or **none**. The current code, as we saw, will happily take a bound region in the return type but drop the other place where it is used, in the parameters. Since bound regions are all about linking multiple things together, I think it's important not to do that. (That said, we could conceivably be a bit less strict here, since the subtyping rules will get our back, but we definitely don't want any bound regions that appear only in the return type.)
- Finally, we cannot take the bound region names from the supplied types and "intermix" them with the names from the expected types.
    - We *could* potentially do some alpha renaming, but I didn't do that.
- Ultimately, if the types the user supplied do not match expectations in some way that we cannot recover from, we fallback to deriving the closure signature solely from those expected types.
    - For example, if the expected type is `u32` but the user wrote `i32`.
    - Or, more subtle, if the user wrote e.g. `&'x u32` for some named lifetime `'x`, but the expected type includes a bound lifetime (`for<'a> (&'a u32)`). In that case, preferring the type that the user explicitly wrote would hide an appearance of a bound name from the expected type, and we try to never do that.

The detailed rules that I came up with are found in the code, but for ease of reading I've also [excerpted them into a gist](https://gist.github.com/nikomatsakis/e69252a2b57e6d97d044c2f254c177f1). I am not convinced they are correct and would welcome feedback for alternative approaches.

(As an aside, the way I think I would ultimately *prefer* to think about this is that the conversion from HIR types to internal types could be parameterized by an "expected type" that it uses to guide itself. However, since that would be a pain, I opted *in the code* to first instantiate the supplied types as `Ty<'tcx>` and then "merge" those types with the `Ty<'tcx>` from the expected signature.)

I think we should probably FCP this before landing.

cc @rust-lang/lang
r? @arielb1

6 years agoAuto merge of #45759 - alexcrichton:update-openssl, r=sfackler
bors [Sun, 5 Nov 2017 14:18:21 +0000 (14:18 +0000)]
Auto merge of #45759 - alexcrichton:update-openssl, r=sfackler

rustbuild: Update the OpenSSL version to link

This updates the OpenSSL tarball download to reflect OpenSSL's newest release.

6 years agoFix MIR inlining panic in generic function
sinkuu [Sun, 5 Nov 2017 13:57:53 +0000 (22:57 +0900)]
Fix MIR inlining panic in generic function

6 years agoAuto merge of #44042 - LukasKalbertodt:ascii-methods-on-instrinsics, r=alexcrichton
bors [Sun, 5 Nov 2017 11:42:59 +0000 (11:42 +0000)]
Auto merge of #44042 - LukasKalbertodt:ascii-methods-on-instrinsics, r=alexcrichton

Copy all `AsciiExt` methods to the primitive types directly in order to deprecate it later

**EDIT:** [this PR is ready now](https://github.com/rust-lang/rust/pull/44042#issuecomment-333883548). I edited this post to reflect the current status of discussion, which is (apart from code review) pretty much settled.

---

This is my current progress in order to prepare stabilization of #39658. As discussed there (and in #39659), the idea is to deprecated `AsciiExt` and copy all methods to the type directly. Apparently there isn't really a reason to have those methods in an extension trait¹.

~~This is **work in progress**: copy&pasting code while slightly modifying the documentation isn't the most exciting thing to do. Therefore I wanted to already open this WIP PR after doing basically 1/4 of the job (copying methods to `&[u8]`, `char` and `&str` is still missing) to get some feedback before I continue. Some questions possibly worth discussing:~~

1. ~~Does everyone agree that deprecating `AsciiExt` is a good idea? Does everyone agree with the goal of this PR?~~ => apparently yes
2. ~~Are my changes OK so far? Did I do something wrong?~~
3. ~~The issue of the unstable-attribute is currently set to 0. I would wait until you say "Ok" to the whole thing, then create a tracking issue and then insert the correct issue id. Is that ok?~~
4. ~~I tweaked `eq_ignore_ascii_case()`: it now takes the argument `other: u8` instead of `other: &u8`. The latter was enforced by the trait. Since we're not bound to a trait anymore, we can drop the reference, ok?~~ => I reverted this, because the interface has to match the `AsciiExt` interface exactly.

¹ ~~Could it be that we can't write `impl [u8] {}`? This might be the reason for `AsciiExt`. If that is the case: is there a good reason we can't write such an impl block? What can we do instead?~~ => we couldn't at the time this PR was opened, but Simon made it possible.

/cc @SimonSapin @zackw

6 years agoRelax #[deny(warnings)] in some crate for cargotest
Lukas Kalbertodt [Sun, 5 Nov 2017 09:40:06 +0000 (10:40 +0100)]
Relax #[deny(warnings)] in some crate for cargotest

Otherwise changes to the compiler are unable to introduce new
warnings: some crates tested by cargotest deny all warnings and
thus, the CI build fails.

Thanks SimonSapin for the patch!

6 years agoAuto merge of #45754 - scottmcm:checked-npot, r=dtolnay
bors [Sun, 5 Nov 2017 09:11:45 +0000 (09:11 +0000)]
Auto merge of #45754 - scottmcm:checked-npot, r=dtolnay

Fix #18604: next_power_of_two should panic on overflow

Fixes https://github.com/rust-lang/rust/issues/18604

Is it possible to write a test for this?  My experiments showed `x.py test` running in release mode, so my attempt at a `#[should_panic]` didn't work.

6 years agoAuto merge of #45748 - petrochenkov:short, r=alexcrichton
bors [Sun, 5 Nov 2017 06:42:17 +0000 (06:42 +0000)]
Auto merge of #45748 - petrochenkov:short, r=alexcrichton

Shorten paths to auxiliary files created by tests

I'm hitting issues with long file paths to object files created by the test suite, similar to https://github.com/rust-lang/rust/issues/45103#issuecomment-335622075.

If we look at the object file path in https://github.com/rust-lang/rust/issues/45103 we can see that the patch contains of few components:
```
specialization-cross-crate-defaults.stage2-x86_64-pc-windows-gnu.run-pass.libaux\specialization_cross_crate_defaults.specialization_cross_crate_defaults0.rust-cgu.o
```
=>

1. specialization-cross-crate-defaults // test name, required
2. stage2 // stage disambiguator, required
3. x86_64-pc-windows-gnu // target disambiguator, required
4. run-pass // mode disambiguator, rarely required
5. libaux // suffix, can be shortened
6. specialization_cross_crate_defaults // required, there may be several libraries in the directory
7. specialization_cross_crate_defaults0 // codegen unit name, can be shortened?
8. rust-cgu // suffix, can be shortened?
9. o // object file extension

This patch addresses items `4`, `5` and `8`.
`libaux` is shortened to `aux`, `rust-cgu` is shortened to `rcgu`, mode disambiguator is omitted unless it's necessary (for pretty-printing and debuginfo tests, see https://github.com/rust-lang/rust/pull/24537/commits/38d26d811a44ba93637c84ce77a58af88c47f0ac)

I haven't touched names of codegen units though (`specialization_cross_crate_defaults0`).
Is it useful for them to have descriptive names including the crate name, as opposed to just `0` or `cgu0` or something?

6 years agoAuto merge of #45710 - alexcrichton:std-symbols, r=michaelwoerister
bors [Sun, 5 Nov 2017 04:02:07 +0000 (04:02 +0000)]
Auto merge of #45710 - alexcrichton:std-symbols, r=michaelwoerister

rustc: Handle some libstd symbole exports better

Right now symbol exports, particularly in a cdylib, are handled by
assuming that `pub extern` combined with `#[no_mangle]` means "export
this". This isn't actually what we want for some symbols that the
standard library uses to implement itself, for example symbols related
to allocation. Additionally other special symbols like
`rust_eh_personallity` have no need to be exported from cdylib crate
types (only needed in dylib crate types).

This commit updates how rustc handles these special symbols by adding to
the hardcoded logic of symbols like `rust_eh_personallity` but also
adding a new attribute, `#[rustc_std_internal_symbol]`, which forces the
export level to be considered the same as all other Rust functions
instead of looking like a C function.

The eventual goal here is to prevent functions like `__rdl_alloc` from
showing up as part of a Rust cdylib as it's just an internal
implementation detail. This then further allows such symbols to get gc'd
by the linker when creating a cdylib.

6 years agorustc: Handle some libstd symbole exports better
Alex Crichton [Wed, 1 Nov 2017 20:16:36 +0000 (13:16 -0700)]
rustc: Handle some libstd symbole exports better

Right now symbol exports, particularly in a cdylib, are handled by
assuming that `pub extern` combined with `#[no_mangle]` means "export
this". This isn't actually what we want for some symbols that the
standard library uses to implement itself, for example symbols related
to allocation. Additionally other special symbols like
`rust_eh_personallity` have no need to be exported from cdylib crate
types (only needed in dylib crate types).

This commit updates how rustc handles these special symbols by adding to
the hardcoded logic of symbols like `rust_eh_personallity` but also
adding a new attribute, `#[rustc_std_internal_symbol]`, which forces the
export level to be considered the same as all other Rust functions
instead of looking like a C function.

The eventual goal here is to prevent functions like `__rdl_alloc` from
showing up as part of a Rust cdylib as it's just an internal
implementation detail. This then further allows such symbols to get gc'd
by the linker when creating a cdylib.

6 years agoUse Add::add for overflow checks instead of [rustc_inherit_overflow_checks]
Scott McMurray [Sun, 5 Nov 2017 00:10:51 +0000 (17:10 -0700)]
Use Add::add for overflow checks instead of [rustc_inherit_overflow_checks]

6 years agoFix comment formatting
Nadav Zingerman [Sat, 4 Nov 2017 23:24:20 +0000 (01:24 +0200)]
Fix comment formatting

6 years agoAuto merge of #45711 - tirr-c:unicode-span, r=estebank
bors [Sat, 4 Nov 2017 23:09:19 +0000 (23:09 +0000)]
Auto merge of #45711 - tirr-c:unicode-span, r=estebank

Display spans correctly when there are zero-width or wide characters

Hopefully...
* fixes #45211
* fixes #8706

---

Before:
```
error: invalid width `7` for integer literal
  --> unicode_2.rs:12:25
   |
12 |     let _ = ("a̐éö̲", 0u7);
   |                         ^^^
   |
   = help: valid widths are 8, 16, 32, 64 and 128

error: invalid width `42` for integer literal
  --> unicode_2.rs:13:20
   |
13 |     let _ = ("아あ", 1i42);
   |                    ^^^^
   |
   = help: valid widths are 8, 16, 32, 64 and 128

error: aborting due to 2 previous errors
```

After:
```
error: invalid width `7` for integer literal
  --> unicode_2.rs:12:25
   |
12 |     let _ = ("a̐éö̲", 0u7);
   |                     ^^^
   |
   = help: valid widths are 8, 16, 32, 64 and 128

error: invalid width `42` for integer literal
  --> unicode_2.rs:13:20
   |
13 |     let _ = ("아あ", 1i42);
   |                      ^^^^
   |
   = help: valid widths are 8, 16, 32, 64 and 128

error: aborting due to 2 previous errors
```

Spans might display incorrectly on the browser.

r? @estebank

6 years agoMake DefIndex use newtype_index macro
Santiago Pastorino [Sat, 4 Nov 2017 20:48:05 +0000 (17:48 -0300)]
Make DefIndex use newtype_index macro

6 years agoMake DEBUG_FORMAT = custom work
Santiago Pastorino [Sat, 4 Nov 2017 22:09:47 +0000 (19:09 -0300)]
Make DEBUG_FORMAT = custom work

Fixes #45763, ht by @durka

6 years agoRemove import of now unused AsciiExt
Lukas Kalbertodt [Fri, 3 Nov 2017 20:24:20 +0000 (21:24 +0100)]
Remove import of now unused AsciiExt

I also replaced a wildcard import with a specific one, while I was
at it.

6 years agoAuto merge of #45394 - davidtwco:rfc-2008, r=petrochenkov
bors [Sat, 4 Nov 2017 18:07:07 +0000 (18:07 +0000)]
Auto merge of #45394 - davidtwco:rfc-2008, r=petrochenkov

RFC 2008: Future-proofing enums/structs with #[non_exhaustive] attribute

This work-in-progress pull request contains my changes to implement [RFC 2008](https://github.com/rust-lang/rfcs/pull/2008). The related tracking issue is #44109.

As of writing, enum-related functionality is not included and there are some issues related to tuple/unit structs. Enum related tests are currently ignored.

WIP PR requested by @nikomatsakis [in Gitter](https://gitter.im/rust-impl-period/WG-compiler-middle?at=59e90e6297cedeb0482ade3e).

6 years agoIgnoring pretty print for test due to #37199
David Wood [Sat, 4 Nov 2017 18:01:35 +0000 (18:01 +0000)]
Ignoring pretty print for test due to #37199

6 years agoMake DepNodeIndex use newtype_index macro
Santiago Pastorino [Sat, 4 Nov 2017 16:41:53 +0000 (13:41 -0300)]
Make DepNodeIndex use newtype_index macro

6 years agoAuto merge of #45709 - nrc:rls-bugs-2, r=eddyb
bors [Sat, 4 Nov 2017 15:30:20 +0000 (15:30 +0000)]
Auto merge of #45709 - nrc:rls-bugs-2, r=eddyb

Fix a bunch of minor save-analysis bugs

r? @eddyb

6 years agorustbuild: Update the OpenSSL version to link
Alex Crichton [Sat, 4 Nov 2017 15:05:46 +0000 (08:05 -0700)]
rustbuild: Update the OpenSSL version to link

This updates the OpenSSL tarball download to reflect OpenSSL's newest release.

6 years agoAdd comment explaining the ctxt field in Span
Nadav Zingerman [Sat, 4 Nov 2017 13:54:03 +0000 (15:54 +0200)]
Add comment explaining the ctxt field in Span

6 years agoAuto merge of #45617 - GuillaumeGomez:search-fixes, r=QuietMisdreavus
bors [Sat, 4 Nov 2017 12:54:34 +0000 (12:54 +0000)]
Auto merge of #45617 - GuillaumeGomez:search-fixes, r=QuietMisdreavus

Search fixes

Fixes #45608.

r? @QuietMisdreavus

6 years agoAuto merge of #45605 - Nashenas88:derive-newtype, r=nikomatsakis
bors [Sat, 4 Nov 2017 10:24:20 +0000 (10:24 +0000)]
Auto merge of #45605 - Nashenas88:derive-newtype, r=nikomatsakis

Add derive and doc comment capabilities to newtype_index macro

This moves `RustcDecodable` and `RustcEncodable` out of the macro definition and into the macro uses. They were conflicting with `CrateNum`'s impls of `serialize::UseSpecializedEncodable` and `serialize::UseSpecializedDecodable`, and now it's not :). `CrateNum` is now defined with the `newtype_index` macro. I also added support for doc comments on constant definitions and allowed a type to remove the pub specification on the tuple param (otherwise a LOT of code would refuse to compile for `CrateNum`). I was getting dozens of errors like this if `CrateNum` was defined as `pub struct CrateNum(pub u32)`:
```
error[E0530]: match bindings cannot shadow tuple structs
   --> src/librustc/dep_graph/dep_node.rs:624:25
    |
63  | use hir::def_id::{CrateNum, DefId, DefIndex, CRATE_DEF_INDEX};
    |                   -------- a tuple struct `CrateNum` is imported here
...
624 |     [] MissingLangItems(CrateNum),
    |                         ^^^^^^^^ cannot be named the same as a tuple struct
```

I also cleaned up the formatting of the macro bodies as they were getting impossibly long. Should I go back and fix the matching rules to this style too?

I also want to see what the test results look like because `CrateNum` used to just derive `Debug`, but the `newtype_index` macro has a custom implementation. This might require further pushes.

Feel free to bikeshed on the macro language, I have no preference here.

6 years agoFix typos
topecongiro [Sat, 4 Nov 2017 09:23:54 +0000 (18:23 +0900)]
Fix typos

6 years agoAuto merge of #45755 - kennytm:rollup, r=kennytm
bors [Sat, 4 Nov 2017 06:59:29 +0000 (06:59 +0000)]
Auto merge of #45755 - kennytm:rollup, r=kennytm

Rollup of 9 pull requests

- Successful merges: #45548, #45610, #45639, #45669, #45681, #45718, #45722, #45739, #45746
- Failed merges:

6 years agoRollup merge of #45746 - GuillaumeGomez:methods-doc-test, r=steveklabnik
kennytm [Sat, 4 Nov 2017 05:49:33 +0000 (13:49 +0800)]
Rollup merge of #45746 - GuillaumeGomez:methods-doc-test, r=steveklabnik

Add tests for methods listing in rust docs

r? @rust-lang/docs

6 years agoRollup merge of #45739 - rkarp:master, r=petrochenkov
kennytm [Sat, 4 Nov 2017 05:49:33 +0000 (13:49 +0800)]
Rollup merge of #45739 - rkarp:master, r=petrochenkov

Fix libstd compile error for windows-gnu targets without `backtrace`

This is basically an addition to #44979. Compiling `libstd` still fails when targeting `windows-gnu` with `panic = "abort"` because the items in the `...c::gnu` module are not used. They are only referenced from `backtrace_gnu.rs`, which is indirectly feature gated behind `backtrace` [here](https://github.com/rust-lang/rust/blob/9f3b09116b742b2606dc5f36f9145e0c89e4010b/src/libstd/sys/windows/mod.rs#L23).

6 years agoRollup merge of #45722 - mikhail-m1:improve-mir-opt-error-output, r=alexcrichton
kennytm [Sat, 4 Nov 2017 05:49:32 +0000 (13:49 +0800)]
Rollup merge of #45722 - mikhail-m1:improve-mir-opt-error-output, r=alexcrichton

improve compiletest output for errors from mir-opt tests

improvement:
1. Report filename against general cannot open error
2. Report current MIR block

6 years agoRollup merge of #45718 - Ljzn:patch-2, r=BurntSushi
kennytm [Sat, 4 Nov 2017 05:49:31 +0000 (13:49 +0800)]
Rollup merge of #45718 - Ljzn:patch-2, r=BurntSushi

Fix typo

`accomodate` -> `accommodate`

6 years agoRollup merge of #45681 - Ljzn:patch-1, r=kennytm
kennytm [Sat, 4 Nov 2017 05:49:30 +0000 (13:49 +0800)]
Rollup merge of #45681 - Ljzn:patch-1, r=kennytm

Fix typo.

6 years agoRollup merge of #45669 - cardoe:metadata, r=kennytm
kennytm [Sat, 4 Nov 2017 05:49:29 +0000 (13:49 +0800)]
Rollup merge of #45669 - cardoe:metadata, r=kennytm

add Cargo metadata to libstd

Add license and repository metadata to libstd

6 years agoRollup merge of #45639 - LaurentMazare:master, r=petrochenkov
kennytm [Sat, 4 Nov 2017 05:49:28 +0000 (13:49 +0800)]
Rollup merge of #45639 - LaurentMazare:master, r=petrochenkov

Add a nicer error message for missing  in for loop, fixes #40782.

As suggested by @estebank in issue #40782, this works in the same way as #42578: if the in keyword is missing, we continue parsing the expression and if this works correctly an adapted error message is produced. Otherwise we return the old error.

A specific test case has also been added.
This is my first PR on rust-lang/rust so any feedback is very welcome.

6 years agoRollup merge of #45610 - strake:atomic_from, r=nagisa
kennytm [Sat, 4 Nov 2017 05:49:27 +0000 (13:49 +0800)]
Rollup merge of #45610 - strake:atomic_from, r=nagisa

impl From<T> for AtomicT

6 years agoRollup merge of #45548 - ratmice:master, r=oli-obk
kennytm [Sat, 4 Nov 2017 05:49:26 +0000 (13:49 +0800)]
Rollup merge of #45548 - ratmice:master, r=oli-obk

issue #45357 don't build clippy stage 1

#45357
Wasn't sure top_stage was the right thing, but seemed to go ahead building clippy stage 2.

6 years agoAdd overflow tests for next_power_of_two
Scott McMurray [Sat, 4 Nov 2017 05:33:34 +0000 (22:33 -0700)]
Add overflow tests for next_power_of_two

6 years agoFix #18604: next_power_of_two should panic on overflow
Scott McMurray [Sat, 4 Nov 2017 04:48:33 +0000 (21:48 -0700)]
Fix #18604: next_power_of_two should panic on overflow

6 years agoAuto merge of #45514 - gnzlbg:jemalloc_realloc2, r=sfackler
bors [Sat, 4 Nov 2017 04:28:13 +0000 (04:28 +0000)]
Auto merge of #45514 - gnzlbg:jemalloc_realloc2, r=sfackler

[jemalloc] set correct excess in realloc_excess

6 years agoAuto merge of #45384 - mikhail-m1:mir_add_false_edges_terminator_kind, r=arielb1
bors [Sat, 4 Nov 2017 00:09:14 +0000 (00:09 +0000)]
Auto merge of #45384 - mikhail-m1:mir_add_false_edges_terminator_kind, r=arielb1

add TerminatorKind::FalseEdges and use it in matches

impl #45184 and fixes #45043 right way.

False edges unexpectedly affects uninitialized variables analysis in MIR borrowck.

6 years agoMark several ascii methods as unstable again
Lukas Kalbertodt [Tue, 3 Oct 2017 15:39:31 +0000 (17:39 +0200)]
Mark several ascii methods as unstable again

We don't want to stabilize them now already. The goal of this set of
commits is just to add inherent methods to the four types. Stabilizing
all of those methods can be done later.

6 years agoRemove unused AsciiExt imports and fix tests related to ascii methods
Lukas Kalbertodt [Mon, 2 Oct 2017 07:50:36 +0000 (09:50 +0200)]
Remove unused AsciiExt imports and fix tests related to ascii methods

Many AsciiExt imports have become useless thanks to the inherent ascii
methods added in the last commits. These were removed. In some places, I
fully specified the ascii method being called to enforce usage of the
AsciiExt trait. Note that some imports are not removed but tagged with
a `#[cfg(stage0)]` attribute. This is necessary, because certain ascii
methods are not yet available in stage0. All those imports will be
removed later.

Additionally, failing tests were fixed. The test suite should exit
successfully now.

6 years agoCopy `AsciiExt` methods to `str` directly
Lukas Kalbertodt [Sun, 1 Oct 2017 19:46:17 +0000 (21:46 +0200)]
Copy `AsciiExt` methods to `str` directly

This is done in order to deprecate AsciiExt eventually. Note that
this commit contains a bunch of `cfg(stage0)` statements. This is
due to a new compiler feature this commit depends on: the
`slice_u8` lang item. Once this lang item is available in the
stage0 compiler, all those cfg flags (and more) can be removed.

6 years agoCopy `AsciiExt` methods to `[u8]` directly
Lukas Kalbertodt [Sun, 1 Oct 2017 19:13:49 +0000 (21:13 +0200)]
Copy `AsciiExt` methods to `[u8]` directly

This is done in order to deprecate AsciiExt eventually. Note that
this commit contains a bunch of `cfg(stage0)` statements. This is
due to a new compiler feature I am using: the `slice_u8` lang item.
Once this lang item is available in the stage0 compiler, all those
cfg flags (and more) can be removed.

6 years agoAdd a lang item to allow `impl [u8] {…}` in the standard library
Simon Sapin [Sun, 1 Oct 2017 15:05:35 +0000 (17:05 +0200)]
Add a lang item to allow `impl [u8] {…}` in the standard library

6 years agoFix lists in doc comments for ascii methods of u8 and char
Lukas Kalbertodt [Fri, 29 Sep 2017 16:34:39 +0000 (18:34 +0200)]
Fix lists in doc comments for ascii methods of u8 and char

6 years agoAdd missing space in match arm
Lukas Kalbertodt [Fri, 29 Sep 2017 14:55:31 +0000 (16:55 +0200)]
Add missing space in match arm

6 years agoTweak documentation for `u8::eq_ignore_ascii_case()`
Lukas Kalbertodt [Fri, 29 Sep 2017 14:54:24 +0000 (16:54 +0200)]
Tweak documentation for `u8::eq_ignore_ascii_case()`

6 years agoRemove examples in doc-comments of `AsciiExt` methods
Lukas Kalbertodt [Fri, 29 Sep 2017 13:23:02 +0000 (15:23 +0200)]
Remove examples in doc-comments of `AsciiExt` methods

The doc comments were incorrect before: since the inherent ascii methods
shadow the `AsciiExt` methods, the examples didn't use the `AsciiExt` at
all. Since the trait will be deprecated soon anyway, the easiest solution
was to remove the examples and already mention that the methods will be
deprecated in the near future.

6 years agoUse direct implementation on u8/char to implement AsciiExt
Lukas Kalbertodt [Thu, 28 Sep 2017 16:25:16 +0000 (18:25 +0200)]
Use direct implementation on u8/char to implement AsciiExt

The methods were copied to u8/char, so we can just use it in
AsciiExt impls to avoid duplicate code.

6 years agoCopy `AsciiExt` methods to `char` directly
Lukas Kalbertodt [Thu, 28 Sep 2017 15:04:38 +0000 (17:04 +0200)]
Copy `AsciiExt` methods to `char` directly

This is done in order to deprecate AsciiExt eventually.

6 years agoRevert signature of eq_ignore_ascii_case() to original
Lukas Kalbertodt [Thu, 28 Sep 2017 14:41:21 +0000 (16:41 +0200)]
Revert signature of eq_ignore_ascii_case() to original

Since the methods on u8 directly will shadow the AsciiExt methods,
we cannot change the signature without breaking everything. It
would have been nice to take `u8` as argument instead of `&u8`, but
we cannot break stuff! So this commit reverts it to the original
`&u8` version.

6 years agoMake ascii methods on u8 insta-stable
Lukas Kalbertodt [Thu, 28 Sep 2017 14:37:37 +0000 (16:37 +0200)]
Make ascii methods on u8 insta-stable

Those methods will shadow the methods of `AsciiExt`, so if we don't
make them insta-stable, everyone will hitting stability errors. It
is fine adding those as stable, because they are just being moved
around [according to sfackler][1].

OPEN QUESTION: this commit also stabilizes the `AsciiExt` methods
that were previously feature gated by the `ascii_ctype` feature.
Maybe we don't want to stablilize those yet.

[1]: https://github.com/rust-lang/rust/pull/44042#issuecomment-329939279

6 years agoAdd all methods of AsciiExt to u8 directly
Lukas Kalbertodt [Tue, 22 Aug 2017 17:45:36 +0000 (19:45 +0200)]
Add all methods of AsciiExt to u8 directly

This is the first step in order to deprecate AsciiExt. Since
this is a WIP commit, there is still some code duplication (notably
the static arrays) that will be removed later.

6 years agoShorten paths to auxiliary files created by tests
Vadim Petrochenkov [Fri, 3 Nov 2017 19:41:15 +0000 (22:41 +0300)]
Shorten paths to auxiliary files created by tests

6 years agoAdded page to unstable book.
David Wood [Fri, 3 Nov 2017 19:18:11 +0000 (19:18 +0000)]
Added page to unstable book.

6 years agoImplemented RFC 2008 for enums (not including variants) and structs.
David Wood [Fri, 3 Nov 2017 19:17:54 +0000 (19:17 +0000)]
Implemented RFC 2008 for enums (not including variants) and structs.

6 years agoAdded tests for RFC 2008.
David Wood [Fri, 3 Nov 2017 19:15:15 +0000 (19:15 +0000)]
Added tests for RFC 2008.

6 years agoAdded feature gate for RFC 2008.
David Wood [Fri, 3 Nov 2017 19:14:39 +0000 (19:14 +0000)]
Added feature gate for RFC 2008.

6 years agoAuto merge of #45247 - leodasvacas:implement-auto-trait-syntax, r=nikomatsakis
bors [Fri, 3 Nov 2017 19:07:45 +0000 (19:07 +0000)]
Auto merge of #45247 - leodasvacas:implement-auto-trait-syntax, r=nikomatsakis

[Syntax] Implement auto trait syntax

Implements `auto trait Send {}` as a substitute for `trait Send {} impl Send for .. {}`.

See the [internals thread](https://internals.rust-lang.org/t/pre-rfc-renaming-oibits-and-changing-their-declaration-syntax/3086) for motivation. Part of #13231.

The first commit is just a rename moving from "default trait" to "auto trait". The rest is parser->AST->HIR work and making it the same as the current syntax for everything below HIR. It's under the `optin_builtin_traits` feature gate.

When can we remove the old syntax? Do we need to wait for a new `stage0`? We also need to formally decide for the new form (even if the keyword is not settled yet).

Observations:
- If you `auto trait Auto {}` and then `impl Auto for .. {}` that's accepted even if it's redundant.
- The new syntax is simpler internally which will allow for a net removal of code, for example well-formedness checks are effectively moved to the parser.
- Rustfmt and clippy are broken, need to fix those.
- Rustdoc just ignores it for now.

ping @petrochenkov @nikomatsakis

6 years agoFix unsafe auto trait pretty print.
leonardo.yvens [Fri, 3 Nov 2017 18:13:02 +0000 (16:13 -0200)]
Fix unsafe auto trait pretty print.

It was being printed wrong as auto unsafe trait

6 years agoUpdate pretty test for auto trait syntax.
leonardo.yvens [Thu, 2 Nov 2017 18:33:09 +0000 (16:33 -0200)]
Update pretty test for auto trait syntax.

6 years agorustfmt is broken which makes rls broken
leonardo.yvens [Thu, 2 Nov 2017 01:10:36 +0000 (23:10 -0200)]
rustfmt is broken which makes rls broken

6 years agofix rebase conflict
leonardo.yvens [Wed, 1 Nov 2017 11:47:18 +0000 (09:47 -0200)]
fix rebase conflict

6 years agoRename `trait_has_auto_impl` to `trait_is_auto`
leonardo.yvens [Mon, 16 Oct 2017 19:33:45 +0000 (17:33 -0200)]
Rename `trait_has_auto_impl` to `trait_is_auto`

6 years agoupdate unstable book and error example
leonardo.yvens [Sun, 15 Oct 2017 19:58:25 +0000 (17:58 -0200)]
update unstable book and error example

6 years agoParse auto traits the same as traits.
leonardo.yvens [Sun, 15 Oct 2017 18:03:03 +0000 (16:03 -0200)]
Parse auto traits the same as traits.

This moves the well formedness checks to the AST validation pass. Tests
were adjusted.

The auto keyword should be back-compat now.

6 years agoFix tests and rebase conflict
leonardo.yvens [Sat, 14 Oct 2017 22:14:31 +0000 (19:14 -0300)]
Fix tests and rebase conflict

6 years agoauto trait future compatibility lint
leonardo.yvens [Sat, 14 Oct 2017 21:23:50 +0000 (18:23 -0300)]
auto trait future compatibility lint

6 years agoFinish DefaultImpl -> AutoImpl rename.
leonardo.yvens [Fri, 13 Oct 2017 16:58:46 +0000 (13:58 -0300)]
Finish DefaultImpl -> AutoImpl rename.

Forgot this ones.

6 years agoAdd tests for `auto trait`, fix parsing bug
leonardo.yvens [Thu, 12 Oct 2017 22:00:30 +0000 (19:00 -0300)]
Add tests for `auto trait`, fix parsing bug

Now we can do the well formedness checks in the parser, yay!

6 years agoFeature gate `auto trait` and ignore it in rustdoc
leonardo.yvens [Thu, 12 Oct 2017 18:36:18 +0000 (15:36 -0300)]
Feature gate `auto trait` and ignore it in rustdoc

6 years agoTeach typeck about `auto trait`
leonardo.yvens [Thu, 12 Oct 2017 14:18:55 +0000 (11:18 -0300)]
Teach typeck about `auto trait`

6 years agoadd `auto` keyword, parse `auto trait`, lower to HIR
leonardo.yvens [Thu, 12 Oct 2017 12:51:31 +0000 (09:51 -0300)]
add `auto` keyword, parse `auto trait`, lower to HIR

Adds an `IsAuto` field to `ItemTrait` which flags if the trait was
declared as an `auto trait`.

Auto traits cannot have generics nor super traits.

6 years ago[Syntax Breaking] Rename DefaultImpl to AutoImpl
leonardo.yvens [Mon, 9 Oct 2017 16:59:20 +0000 (13:59 -0300)]
[Syntax Breaking] Rename DefaultImpl to AutoImpl

DefaultImpl is a highly confusing name for what we now call auto impls,
as in `impl Send for ..`. The name auto impl is not formally decided
but for sanity anything is better than `DefaultImpl` which refers
neither to `default impl` nor to `impl Default`.

6 years agoissue #45357 set clippy build condition to extended.
matt rice [Sun, 29 Oct 2017 16:10:07 +0000 (09:10 -0700)]
issue #45357 set clippy build condition to extended.

6 years agoAdd tests for methods listing in rust docs
Guillaume Gomez [Fri, 3 Nov 2017 17:39:00 +0000 (18:39 +0100)]
Add tests for methods listing in rust docs

6 years ago[jemalloc] set correct excess in alloc_excess
gnzlbg [Fri, 3 Nov 2017 16:44:58 +0000 (17:44 +0100)]
[jemalloc] set correct excess in alloc_excess

6 years agoAuto merge of #45569 - zackmdavis:unexported_pub_lint, r=petrochenkov
bors [Fri, 3 Nov 2017 16:28:24 +0000 (16:28 +0000)]
Auto merge of #45569 - zackmdavis:unexported_pub_lint, r=petrochenkov

`unreachable-pub` lint (as authorized by RFC 2126)

To whom it may concern:

RFC 2126 commissions the creation of a lint for `pub` items that are not visible from crate root (#45521). We understand (but seek confirmation from more knowledgable compiler elders) that this can be implemented by linting HIR items that are _not_ ~~`cx.access_levels.is_exported`~~ `cx.access_levels.is_reachable` but have a `vis` (-ibility) field of `hir::Visibility::Public`.

The lint, tentatively called ~~`unexported-pub`~~ `unreachable-pub` (with the understanding that much could be written on the merits of various names, as it is said of the colors of bicycle-sheds), suggests `crate` as a replacement for `pub` if the `crate_visibility_modifier` feature is enabled (see #45388), and `pub(crate)` otherwise. We also use help messaging to suggest the other potential fix of exporting the item; feedback is desired as to whether this may be confusing or could be worded better.

As a preview of what respecting the proposed lint would look like (and to generate confirmatory evidence that this implementation doesn't issue false positives), ~~we take its suggestions for `libcore`~~ (save one, which is deferred to another pull request because it brings up an unrelated technical matter). I remain your obedient servant.

![unexported_pub](https://user-images.githubusercontent.com/1076988/32089794-fbd02420-baa0-11e7-87e5-3ec01f18924a.png)

r? @petrochenkov

6 years agoUpdate config.rs
Oliver Schneider [Fri, 3 Nov 2017 15:32:03 +0000 (16:32 +0100)]
Update config.rs

6 years agoDon't add a new -Z flag, reuse -Zunstable-options
Oliver Schneider [Fri, 3 Nov 2017 15:22:19 +0000 (16:22 +0100)]
Don't add a new -Z flag, reuse -Zunstable-options

6 years agoFix std compile error for windows-gnu targets without `backtrace` feature
Rolf Karp [Fri, 3 Nov 2017 14:21:05 +0000 (15:21 +0100)]
Fix std compile error for windows-gnu targets without `backtrace` feature

6 years agoPretty print json in ui tests
Oliver Schneider [Fri, 3 Nov 2017 12:38:26 +0000 (13:38 +0100)]
Pretty print json in ui tests

6 years agoAuto merge of #45734 - kennytm:ci-fix-centos-broken-link, r=alexcrichton
bors [Fri, 3 Nov 2017 12:30:09 +0000 (12:30 +0000)]
Auto merge of #45734 - kennytm:ci-fix-centos-broken-link, r=alexcrichton

ci: Fix broken link in `build-powerpc64le-toolchain.sh`

r? @rust-lang/infra

This is just an emergency fix to keep bors running for another week. I think the numbers will be broken soon. Can we verify if this statement is still true later?

> First, download the CentOS7 glibc.ppc64le and relevant header files.
> (upstream ppc64le support wasn't added until 2.19, which el7 backported.)

6 years agoRemove outdated documentation
Oliver Schneider [Fri, 3 Nov 2017 11:37:11 +0000 (12:37 +0100)]
Remove outdated documentation