about summary refs log tree commit diff
AgeCommit message (Collapse)AuthorLines
2020-06-08Rollup merge of #72761 - poliorcetics:use-keyword-doc, r=Dylan-DPCRalf Jung-2/+54
Added the documentation for the 'use' keyword This is a partial fix of #34601. I heavily inspired myself from the Reference on the `use` keyword. I checked the links when compiling the documentation, they should be ok. I also added an example for the wildcard `*` in the case of types, because it's behaviour is not *import everything* like one might think at first.
2020-06-08Rollup merge of #72615 - jschwe:fix-Zprofile-documentation, r=steveklabnikRalf Jung-1/+7
Fix documentation example for gcov profiling closes #72546 Improves the documentation for the unstable Rustflag `-Zprofile` by: - stating that Incremental compilation must be turned off. - Adding the other `RUSTFLAGS` that should/need to be turned on (taken from [grcov documentation](https://github.com/mozilla/grcov#example-how-to-generate-gcda-files-for-a-rust-project)) - Mentioning `RUSTC_WRAPPER` to prevent everything getting instrumented. r? @steveklabnik
2020-06-08Rollup merge of #72583 - CAD97:vec-iter-asref-slice, r=dtolnayRalf Jung-0/+7
impl AsRef<[T]> for vec::IntoIter<T> Adds `impl<T> AsRef<[T]> for vec::IntoIter<T>`. This mirrors the same trait impl for [`slice::Iter`](https://doc.rust-lang.org/nightly/std/slice/struct.Iter.html). Both types already offer `fn as_slice(&self) -> &[T]`, this just adds the trait impl for `vec::IntoIter`. If/when `fn as_slice(&self) -> &[T]` stabilizes for `vec::Drain` and `slice::IterMut`, they should get `AsRef<[T]>` impls as well. As thus, tangentially related to #58957. My ultimate goal here: being able to use `for<T, I: Iterator<Item=T> + AsRef<[T]>> I` to refer to `vec::IntoIter`, `vec::Drain`, and eventually `array::IntoIter`, as an approximation of the set of by-value iterators that can be "previewed" as by-ref iterators. (Actually expressing that as a trait requires GAT.)
2020-06-08Rollup merge of #72026 - botika:master, r=estebankRalf Jung-128/+210
Update annotate-snippets-rs to 0.8.0 #59346 I made major changes to this library. In the previous version we worked with owned while in the current one with borrowed. I have adapted it without changing the behavior. I have modified the coverage since the previous one did not return correctly the index of the character in the line.
2020-06-08Auto merge of #73046 - marmeladema:save-analysis-fix-path, r=Xanewokbors-6/+39
save_analysis: fix some ICEs Fixes #73020 Fixes #73022 Fixes #73041
2020-06-07Auto merge of #72904 - shepmaster:reduce-abi-symbol-hash-churn, ↵bors-16/+24
r=jonas-schievink,RalfJung Order the Rust and C ABIs first to reduce test churn
2020-06-07Auto merge of #73099 - Dylan-DPC:rollup-7u8f3m4, r=Dylan-DPCbors-41/+140
Rollup of 2 pull requests Successful merges: - #72952 (run-make regression test for issue #70924.) - #72977 (Fix codegen tests for RISC-V) Failed merges: r? @ghost
2020-06-07Rollup merge of #72977 - tblah:riscv-codegen-llvm10, r=nikomatsakisDylan DPC-41/+93
Fix codegen tests for RISC-V Some codegen tests didn't seem relevant (e.g. unsupported annotations). The RISC-V abi tests were broken by LLVM 10, c872dcf fixes that (cc: @msizanoen1) I'm not sure about skipping catch-unwind.rs and included that change here mostly as a request for comment - I can't tell if that's a bug.
2020-06-07Rollup merge of #72952 - pnkfelix:regression-test-for-issue-70924, ↵Dylan DPC-0/+47
r=nikomatsakis run-make regression test for issue #70924. Sometime after my PR #72767 (to fix issue #70924) landed, I realized that I *could* make a local regression test, thanks to `rustc --print sysroot`: I can make a fresh "copy" (really mostly symlinks) of the sysroot, and then modify it to recreate the terms of this bug.
2020-06-07Auto merge of #73093 - Dylan-DPC:rollup-9gh5tyu, r=Dylan-DPCbors-116/+234
Rollup of 5 pull requests Successful merges: - #72764 (Be more careful around ty::Error in generators) - #72908 (rename FalseEdges -> FalseEdge) - #72970 (Properly handle feature-gated lints) - #72998 (Mention that some atomic operations may not be available on some platforms) - #73063 (Elide type on liballoc vec) Failed merges: r? @ghost
2020-06-07Rollup merge of #73063 - pickfire:liballoc-elide, r=kennytmDylan DPC-1/+1
Elide type on liballoc vec
2020-06-07Rollup merge of #72998 - poliorcetics:atomic-availability-doc, r=AmanieuDylan DPC-0/+87
Mention that some atomic operations may not be available on some platforms fixes #54250 This simply adds a line saying the type/function/method may not be available on some platforms, depending on said platform capabilities. I *think* I got them all.
2020-06-07Rollup merge of #72970 - OddCoincidence:feature-gated-lints, r=petrochenkovDylan DPC-21/+29
Properly handle feature-gated lints Closes #72694
2020-06-07Rollup merge of #72908 - RalfJung:false-edge, r=matthewjasperDylan DPC-66/+66
rename FalseEdges -> FalseEdge There's just a single false edge in this terminator, not multiple of them. r? @matthewjasper @jonas-schievink
2020-06-07Rollup merge of #72764 - jonas-schievink:mind-the-tyerr, r=estebankDylan DPC-28/+51
Be more careful around ty::Error in generators cc https://github.com/rust-lang/rust/issues/72685 (doesn't close it because it's missing a reproduction to use as a test case) r? @estebank
2020-06-07rename FalseEdges -> FalseEdgeRalf Jung-66/+66
2020-06-07Auto merge of #73072 - arcnmx:lld-noload, r=nikicbors-0/+0
Update LLVM submodule to include lld NOLOAD fix > Rust nightly 2020-05-22 and later ships lld with a regression related to linker scripts: NOLOAD sections incorrectly generate sections filled with 0s. This causes gdb and other elf loaders to write to reserved or otherwise invalid addresses (gdb also seems confused by the resulting ELF files and spits out a warning about the sections). This is particularly a problem for embedded rust projects that use lld by default and have affected linker scripts (cortex-m-rt based projects for instance). https://github.com/rust-lang/llvm-project/pull/64 Note that this also pulls in llvm changes from #72937
2020-06-06Order the Rust and C ABIs first to reduce test churnJake Goulding-16/+24
2020-06-07Auto merge of #73081 - Dylan-DPC:rollup-1aqk215, r=Dylan-DPCbors-1677/+1900
Rollup of 5 pull requests Successful merges: - #72810 (validate basic sanity for TerminatorKind) - #72989 (Revert pr 71840) - #72993 (Count the beta prerelease number just from master) - #73057 (Clean up E0644 explanation) - #73059 (remove outdated comment) Failed merges: r? @ghost
2020-06-07Rollup merge of #73059 - lcnr:outdated-comment, r=matthewjasperDylan DPC-4/+0
remove outdated comment r? @matthewjasper
2020-06-07Rollup merge of #73057 - GuillaumeGomez:cleanup-e0644, r=Dylan-DPCDylan DPC-1/+1
Clean up E0644 explanation r? @Dylan-DPC
2020-06-07Rollup merge of #72993 - cuviper:beta-number, r=Mark-SimulacrumDylan DPC-18/+4
Count the beta prerelease number just from master We were computing a merge-base between the remote beta and master branches, but this was giving incorrect answers for the first beta if the remote hadn't been pushed yet. For instance, `1.45.0-beta.3359` corresponds to the number of merges since the 1.44 beta, but we really want just `.1` for the sole 1.45 beta promotion merge. We don't really need to query the remote beta at all -- `master..HEAD` suffices if we assume that we're on the intended beta branch already.
2020-06-07Rollup merge of #72989 - pnkfelix:revert-pr-71840, r=matthewjasperDylan DPC-1638/+1768
Revert pr 71840 Revert7 PR #71840 to fix issue #72470 This will need a backport to beta if we do not want #72470 to hit stable.
2020-06-07Rollup merge of #72810 - RalfJung:mir-terminate-sanity, r=jonas-schievinkDylan DPC-16/+127
validate basic sanity for TerminatorKind r? @jonas-schievink This mainly checks that all `BasicBlock` actually exist. On top of that, it checks that `Call` actually calls something of `FnPtr`/`FnDef` type, and `Assert` has to work on a `bool`. Also `SwitchInt` cannot have an empty target list.
2020-06-06save_analysis: fix panic in `write_sub_paths_truncated`marmeladema-3/+19
2020-06-06Only mention `u8` and not booleansPoliorcetics-1/+1
Co-authored-by: Amanieu d'Antras <amanieu@gmail.com>
2020-06-06Auto merge of #73073 - RalfJung:rollup-i24dh28, r=RalfJungbors-34/+107
Rollup of 3 pull requests Successful merges: - #71796 (de-promote Duration::from_secs) - #72508 (Make `PolyTraitRef::self_ty` return `Binder<Ty>`) - #72708 (linker: Add a linker rerun hack for gcc versions not supporting -static-pie) Failed merges: r? @ghost
2020-06-06Rollup merge of #72708 - petrochenkov:linkhack, r=cuviperRalf Jung-8/+62
linker: Add a linker rerun hack for gcc versions not supporting -static-pie Which mirrors the existing `-no-pie` linker rerun hack, but the logic is a bit more elaborated in this case. If the linker (gcc or clang) errors on `-static-pie` we rerun in with `-static` instead. We must also replace CRT objects corresponding to `-static-pie` with ones corresponding to `-static` in this case. (One sanity check for CRT objects in target specs is also added as a drive-by fix.) To do in the future: refactor all linker rerun hacks into separate functions and share more code with `add_(pre,post)_link_objects`. This PR accompanies https://github.com/rust-lang/rust/pull/71804 and unblocks https://github.com/rust-lang/rust/pull/70740.
2020-06-06Rollup merge of #72508 - ecstatic-morse:poly-self-ty, r=nikomatsakisRalf Jung-25/+45
Make `PolyTraitRef::self_ty` return `Binder<Ty>` This came up during review of #71618. The current implementation is the same as a call to `skip_binder` but harder to audit. Make it preserve binding levels and add a call to `skip_binder` at all use sites so they can be audited as part of #72507.
2020-06-06Rollup merge of #71796 - RalfJung:from-secs, r=nikomatsakisRalf Jung-1/+0
de-promote Duration::from_secs In https://github.com/rust-lang/rust/pull/67531, we removed the `rustc_promotable` attribute from a bunch of `Duration` methods, but not from `Duration::from_secs`. This makes the current list of promotable functions the following (courtesy of @ecstatic-morse): * `INT::min_value`, `INT::max_value` * `std::mem::size_of`, `std::mem::align_of` * `RangeInclusive::new` (backing `x..=y`) * `std::ptr::null`, `std::ptr::null_mut` * `RawWaker::new`, `RawWakerVTable::new` ??? * `Duration::from_secs` I feel like the last one stands out a bit here -- the rest are all very core language primitives, and `RawWaker` has a strong motivation for getting a `'static` vtable. But a `&'static Duration`? That seems unlikely. So I propose we no longer promote calls to `Duration::from_secs`, which is what this PR does. https://github.com/rust-lang/rust/pull/67531 saw zero regressions and I am not aware of anyone complaining that this broke their (non-cratered) code, so I consider it likely the same will be true here, but of course we'd do a crater run. See [this document](https://github.com/rust-lang/const-eval/blob/master/promotion.md) for some more background on promotion and https://github.com/rust-lang/const-eval/issues/19 for some of the concerns around promoting function calls.
2020-06-06Elide type on liballoc vecIvan Tham-1/+1
2020-06-06remove outdated commentBastian Kauschke-4/+0
2020-06-06Clean up E0644 explanationGuillaume Gomez-1/+1
2020-06-06Auto merge of #72927 - petrochenkov:rustc, r=Mark-Simulacrumbors-185/+178
Rename all remaining compiler crates to use the `rustc_foo` pattern libarena -> librustc_arena libfmt_macros -> librustc_parse_format libgraphviz -> librustc_graphviz libserialize -> librustc_serialize Closes https://github.com/rust-lang/rust/issues/71177 in particular.
2020-06-06save_analysis: fix ice in `get_expr_data`marmeladema-3/+20
2020-06-05properly handle feature gated lintsJoey Hain-21/+29
- lint: add `feature_gate` field, allow specifying it in `declare_lint!` - generalize the lint feature gate check - librustdoc: generalize whitelisting of feature-gated lints
2020-06-05Auto merge of #72982 - tblah:riscv-ui-tests, r=estebankbors-66/+85
resolve: Sort E0408 errors by Symbol str This is a request for comments implementing my suggested solution to https://github.com/rust-lang/rust/issues/72913 Previously errors were sorted by Symbol index instead of the string. The indexes are not the same between architectures because Symbols for architecture extensions (e.g. x86 AVX or RISC-V d) are interned before the source file is parsed. RISC-V's naming of extensions after single letters led to it having errors sorted differently for test cases using single letter variable names. Instead sort the errors by the Symbol string so that it is stable across architectures. While I was at it, there's also 8edb05c2 skipping some ui tests which I think are irrelevant for risc-v.
2020-06-05Update LLVM submodule to include lld NOLOAD fixarcnmx-0/+0
https://github.com/rust-lang/llvm-project/pull/64
2020-06-05Improve the new documentation to be more precise about the necessary ↵Alexis Bourget-67/+97
platform's capabilities
2020-06-05Ignore windows in the test.Felix S. Klock II-0/+5
2020-06-05Auto merge of #73025 - Dylan-DPC:rollup-a1uzj5u, r=Dylan-DPCbors-81/+111
Rollup of 5 pull requests Successful merges: - #72260 (Spell out `Self` in async function return) - #72996 (Remove unsused `NodeId` related APIs in hir map) - #73010 (Update RELEASES.md) - #73017 (Use assert_eq for liballoc test) - #73019 (add test for #72960) Failed merges: r? @ghost
2020-06-05Auto merge of #72957 - Mark-Simulacrum:bootstrap-bump, r=sfacklerbors-105/+25
Bump bootstrap compiler to 1.45 Pretty standard update.
2020-06-05Rollup merge of #73019 - matthiaskrgr:test_72960, r=XanewokDylan DPC-1/+3
add test for #72960 Fixes #72960 r? @Xanewok
2020-06-05Rollup merge of #73017 - pickfire:liballoc-assert, r=XanewokDylan DPC-1/+1
Use assert_eq for liballoc test
2020-06-05Rollup merge of #73010 - tshepang:patch-2, r=Mark-SimulacrumDylan DPC-2/+2
Update RELEASES.md try fix the f64 as u32 line
2020-06-05Rollup merge of #72996 - marmeladema:remove-hir-map-nodeid-apis, ↵Dylan DPC-35/+8
r=ecstatic-morse Remove unsused `NodeId` related APIs in hir map cc #50928 r? @ecstatic-morse
2020-06-05Rollup merge of #72260 - csmoe:issue-69276, r=estebankDylan DPC-42/+97
Spell out `Self` in async function return Closes #69276 r? @tmandry
2020-06-05add test for #72960Matthias Krüger-1/+3
Fixes #72960
2020-06-05Use assert_eq for liballoc testIvan Tham-1/+1
2020-06-05Update RELEASES.mdTshepang Lekhonkhobe-2/+2
try fix the f64 as u32 line