]> git.lizzy.rs Git - rust.git/log
rust.git
2 years agoStop using walk_crate.
Camille GILLOT [Thu, 26 Aug 2021 16:42:08 +0000 (18:42 +0200)]
Stop using walk_crate.

2 years agoReport cycle error using 'deepest' obligation in the cycle
Aaron Hill [Fri, 27 Aug 2021 22:34:48 +0000 (17:34 -0500)]
Report cycle error using 'deepest' obligation in the cycle

2 years agoAuto merge of #87580 - ChrisDenton:win-arg-parse-2008, r=m-ou-se
bors [Thu, 2 Sep 2021 16:16:13 +0000 (16:16 +0000)]
Auto merge of #87580 - ChrisDenton:win-arg-parse-2008, r=m-ou-se

Update Windows Argument Parsing

Fixes #44650

The Windows command line is passed to applications [as a single string](https://docs.microsoft.com/en-us/archive/blogs/larryosterman/the-windows-command-line-is-just-a-string) which the application then parses to get a list of arguments. The standard rules (as used by C/C++) for parsing the command line have slightly changed over the years, most recently in 2008 which added new escaping rules.

This PR implements the new rules as [described on MSDN](https://docs.microsoft.com/en-us/cpp/cpp/main-function-command-line-args?view=msvc-160#parsing-c-command-line-arguments) and [further detailed here](https://daviddeley.com/autohotkey/parameters/parameters.htm#WIN). It has been tested against the behaviour of C++ by calling a C++ program that outputs its raw command line and the contents of `argv`. See [my repo](https://github.com/ChrisDenton/winarg/tree/std) if anyone wants to reproduce my work.

For an overview of how this PR changes argument parsing behavior and why we feel it is warranted see https://github.com/rust-lang/rust/pull/87580#issuecomment-893833893.

For some examples see: https://github.com/rust-lang/rust/pull/87580#issuecomment-894299249

2 years agoPreserve most sub-obligations in the projection cache
Aaron Hill [Mon, 31 May 2021 18:22:40 +0000 (13:22 -0500)]
Preserve most sub-obligations in the projection cache

2 years agoAuto merge of #7604 - flip1995:rustup, r=Manishearth
bors [Thu, 2 Sep 2021 15:30:12 +0000 (15:30 +0000)]
Auto merge of #7604 - flip1995:rustup, r=Manishearth

Rustup

I'll write some TODOs later. This time I'll need a review for this Rustup

r? `@ghost`  (for now)

changelog: none

2 years agoConsistent placement of doc alias for primitives below the `doc(primitive…)`
Frank Steffahn [Thu, 2 Sep 2021 15:21:05 +0000 (17:21 +0200)]
Consistent placement of doc alias for primitives below the `doc(primitive…)`

2 years agoAdd "!" doc alias for `std::ops::Not`
Frank Steffahn [Thu, 2 Sep 2021 15:19:43 +0000 (17:19 +0200)]
Add "!" doc alias for `std::ops::Not`

2 years agoadd test
b-naber [Thu, 2 Sep 2021 14:29:04 +0000 (16:29 +0200)]
add test

2 years agodo not resolve instances for trait fn ids
b-naber [Thu, 2 Sep 2021 10:22:23 +0000 (12:22 +0200)]
do not resolve instances for trait fn ids

2 years agoAuto merge of #88530 - bjorn3:shrink_session, r=cjgillot
bors [Thu, 2 Sep 2021 13:12:59 +0000 (13:12 +0000)]
Auto merge of #88530 - bjorn3:shrink_session, r=cjgillot

Shrink Session a bit

Remove a couple of unnecessary fields from `Session` and remove a `Lock<T>` for a field that is never mutated anyway.

2 years agoCorrect doc comments inside `use_expr_visitor.rs`
xFrednet [Thu, 2 Sep 2021 12:59:14 +0000 (14:59 +0200)]
Correct doc comments inside `use_expr_visitor.rs`

2 years agoFix fallout from re-applying patches
flip1995 [Thu, 2 Sep 2021 11:58:25 +0000 (12:58 +0100)]
Fix fallout from re-applying patches

2 years agoBump nightly version -> 2021-09-02
flip1995 [Thu, 2 Sep 2021 11:45:45 +0000 (12:45 +0100)]
Bump nightly version -> 2021-09-02

2 years agoFix matadata collection configuration formatting
xFrednet [Sat, 28 Aug 2021 13:04:28 +0000 (15:04 +0200)]
Fix matadata collection configuration formatting

2 years agoAdd higher docs and remove some unneeded fields
Cameron Steffen [Fri, 27 Aug 2021 13:38:07 +0000 (08:38 -0500)]
Add higher docs and remove some unneeded fields

2 years agoFix remaining dogfood errors
flip1995 [Thu, 26 Aug 2021 15:53:07 +0000 (16:53 +0100)]
Fix remaining dogfood errors

Except for the missing docs ones

2 years agoFix dogfood
Cameron Steffen [Thu, 26 Aug 2021 15:25:14 +0000 (10:25 -0500)]
Fix dogfood

2 years agoFix manual_match with let-expressions
Cameron Steffen [Thu, 26 Aug 2021 15:05:33 +0000 (10:05 -0500)]
Fix manual_match with let-expressions

2 years agoMerge remote-tracking branch 'upstream/master' into rustup2
flip1995 [Thu, 2 Sep 2021 11:38:17 +0000 (12:38 +0100)]
Merge remote-tracking branch 'upstream/master' into rustup2

2 years agoexpand: Treat more macro calls as statement macro calls
Vadim Petrochenkov [Thu, 26 Aug 2021 14:18:03 +0000 (17:18 +0300)]
expand: Treat more macro calls as statement macro calls

2 years agoAdd explanation for ctfe_backtrace lock
bjorn3 [Tue, 31 Aug 2021 13:06:59 +0000 (15:06 +0200)]
Add explanation for ctfe_backtrace lock

2 years agoUse in_incr_comp_dir_sess in cg_clif
bjorn3 [Mon, 30 Aug 2021 13:06:56 +0000 (15:06 +0200)]
Use in_incr_comp_dir_sess in cg_clif

2 years agoRemove print_fuel_crate field of Session
bjorn3 [Mon, 30 Aug 2021 12:41:09 +0000 (14:41 +0200)]
Remove print_fuel_crate field of Session

2 years agoRemove optimization_fuel_crate from Session
bjorn3 [Mon, 30 Aug 2021 12:36:24 +0000 (14:36 +0200)]
Remove optimization_fuel_crate from Session

2 years agoAuto merge of #88516 - matthiaskrgr:clippy_perf_end_august, r=jyn514,GuillaumeGomez
bors [Thu, 2 Sep 2021 10:27:44 +0000 (10:27 +0000)]
Auto merge of #88516 - matthiaskrgr:clippy_perf_end_august, r=jyn514,GuillaumeGomez

some low hanging clippy::perf fixes

2 years agoRemove unused argument from resolve_crate
bjorn3 [Tue, 31 Aug 2021 15:18:06 +0000 (17:18 +0200)]
Remove unused argument from resolve_crate

2 years agoIntroduce CrateRejections struct
bjorn3 [Tue, 31 Aug 2021 15:02:36 +0000 (17:02 +0200)]
Introduce CrateRejections struct

2 years agoRemove root field from CrateLocator
bjorn3 [Tue, 31 Aug 2021 14:50:00 +0000 (16:50 +0200)]
Remove root field from CrateLocator

2 years agoRemove host_hash from CrateLocator
bjorn3 [Tue, 31 Aug 2021 13:22:21 +0000 (15:22 +0200)]
Remove host_hash from CrateLocator

2 years agoRefactor CrateLocator.is_proc_macro
bjorn3 [Mon, 30 Aug 2021 16:11:09 +0000 (18:11 +0200)]
Refactor CrateLocator.is_proc_macro

This also fixes a (theoretical) bug where a proc-macro may be loaded as
plugin if it exports a symbol with the right name.

2 years agoDon't store Session in CrateLocator
bjorn3 [Mon, 30 Aug 2021 16:05:15 +0000 (18:05 +0200)]
Don't store Session in CrateLocator

2 years agoBless 32bit MIR opt tests
Matthew Jasper [Thu, 2 Sep 2021 09:18:08 +0000 (10:18 +0100)]
Bless 32bit MIR opt tests

2 years agoRemove TODO
Matthew Jasper [Thu, 2 Sep 2021 08:21:16 +0000 (09:21 +0100)]
Remove TODO

2 years agoAuto merge of #7619 - UnrealApex:patch-1, r=flip1995
bors [Thu, 2 Sep 2021 08:11:57 +0000 (08:11 +0000)]
Auto merge of #7619 - UnrealApex:patch-1, r=flip1995

Update README.md

Capitalized proper noun.
changelog:none

2 years agoAuto merge of #87114 - cjgillot:abilint, r=estebank
bors [Thu, 2 Sep 2021 06:06:24 +0000 (06:06 +0000)]
Auto merge of #87114 - cjgillot:abilint, r=estebank

Lint missing Abi in ast validation instead of lowering.

2 years agoImplement #88581
Jacob Pratt [Thu, 2 Sep 2021 05:28:47 +0000 (01:28 -0400)]
Implement #88581

2 years agoremove redundant / misplaced sentence from docs
ast-ral [Thu, 2 Sep 2021 03:52:30 +0000 (20:52 -0700)]
remove redundant / misplaced sentence from docs

2 years agoAuto merge of #83342 - Count-Count:win-console-incomplete-utf8, r=m-ou-se
bors [Thu, 2 Sep 2021 03:31:17 +0000 (03:31 +0000)]
Auto merge of #83342 - Count-Count:win-console-incomplete-utf8, r=m-ou-se

Allow writing of incomplete UTF-8 sequences to the Windows console via stdout/stderr

# Problem
Writes of just an incomplete UTF-8 byte sequence (e.g. `b"\xC3"` or `b"\xF0\x9F"`)  to stdout/stderr with a Windows console attached error with `io::ErrorKind::InvalidData, "Windows stdio in console mode does not support writing non-UTF-8 byte sequences"` even though further writes could complete the codepoint. This is currently a rare occurence since the [linewritershim](https://github.com/rust-lang/rust/blob/2c56ea38b045624dc8b42ec948fc169eaff1206a/library/std/src/io/buffered/linewritershim.rs) implementation flushes complete lines immediately and buffers up to 1024 bytes for incomplete lines. It can still happen as described in #83258.

The problem will become more pronounced once the developer can switch stdout/stderr from line-buffered to block-buffered or immediate when the changes in the "Switchable buffering for Stdout" pull request (#78515) get merged.

# Patch description
If there is at least one valid UTF-8 codepoint all valid UTF-8 is passed through to the extracted `write_valid_utf8_to_console()` fn. The new code only comes into play if `write()` is being passed a short byte slice comprising an incomplete UTF-8 codepoint. In this case up to three bytes are buffered in the `IncompleteUtf8` struct associated with `Stdout` / `Stderr`. The bytes are accepted one at a time. As soon as an error can be detected `io::ErrorKind::InvalidData, "Windows stdio in console mode does not support writing non-UTF-8 byte sequences"` is returned. Once a complete UTF-8 codepoint is received it is passed to the `write_valid_utf8_to_console()` and the buffer length is set to zero.

Calling `flush()` will neither error nor write anything if an incomplete codepoint is present in the buffer.

# Tests
Currently there are no Windows-specific tests for console writing code at all. Writing (regression) tests for this problem is a bit challenging since unit tests and UI tests don't run in a console and suddenly popping up another console window might be surprising to developers running the testsuite and it might not work at all in CI builds. To just test the new functionality in unit tests the code would need to be refactored. Some guidance on how to proceed would be appreciated.

# Public API changes
* `std::str::verifications::utf8_char_width()` would be exposed as `std::str::utf8_char_width()` behind the "str_internals" feature gate.

# Related issues
* Fixes #83258.
* PR #78515 will exacerbate the problem.

# Open questions
* Add tests?
* Squash into one commit with better commit message?

2 years agoEnsure suggestion is in its own diagnostic window
Noah Lev [Thu, 2 Sep 2021 03:20:46 +0000 (20:20 -0700)]
Ensure suggestion is in its own diagnostic window

For two reasons:

1. Now that the suggestion span has been corrected, the output is a bit
   cluttered and hard to read. Putting the suggestion its own window
   creates more space.

2. It's easier to see what's being suggested, since now the version
   after the suggestion is applied is shown.

2 years agoFix span used for structured tuple struct suggestion
Noah Lev [Thu, 2 Sep 2021 03:11:05 +0000 (20:11 -0700)]
Fix span used for structured tuple struct suggestion

(And same for tuple variants.)

Previously, the span was just for the constructor name, which meant it
would result in syntactically-invalid code when applied. Now, the span
is for the entire expression.

2 years agoAuto merge of #7617 - xFrednet:0000-link-diag-item-docs, r=giraffate
bors [Thu, 2 Sep 2021 01:04:40 +0000 (01:04 +0000)]
Auto merge of #7617 - xFrednet:0000-link-diag-item-docs, r=giraffate

Reference new diagnostic item docs in our docs :)

The title says it all. The rustc dev guide now has some information about diagnostic items that are worthwhile linking to :upside_down_face:

---

changelog: none

2 years agoAuto merge of #88522 - camelid:box-paren-output, r=jyn514
bors [Thu, 2 Sep 2021 00:12:21 +0000 (00:12 +0000)]
Auto merge of #88522 - camelid:box-paren-output, r=jyn514

rustdoc: Box `GenericArgs::Parenthesized.output`

Split out from #88379.

This reduces the size of `GenericArgs` from 104 bytes to 56 bytes,
essentially reducing it by half.

`GenericArgs` is one of the fields of `PathSegment`, so this should
reduce the amount of memory allocated for `PathSegment`s in the cases
where the generics are not for a `Fn`, `FnMut`, or `FnOnce` trait.

r? `@jyn514`

2 years agoFix drop handling for `if let` expressions
Matthew Jasper [Wed, 1 Sep 2021 21:52:17 +0000 (22:52 +0100)]
Fix drop handling for `if let` expressions

MIR lowering for `if let` expressions is now more complicated now that
`if let` exists in HIR. This PR adds a scope for the variables bound in
an `if let` expression and then uses an approach similar to how we
handle loops to ensure that we reliably drop the correct variables.

2 years agorustc_target: move `LayoutOf` to `ty::layout`.
Eduard-Mihai Burtescu [Mon, 30 Aug 2021 14:38:27 +0000 (17:38 +0300)]
rustc_target: move `LayoutOf` to `ty::layout`.

2 years agoty::layout: split `LayoutOf` into required and (blanket) provided halves.
Eduard-Mihai Burtescu [Mon, 30 Aug 2021 17:37:36 +0000 (20:37 +0300)]
ty::layout: split `LayoutOf` into required and (blanket) provided halves.

2 years agoty::layout: implement `layout_of` automatically as a default method.
Eduard-Mihai Burtescu [Mon, 30 Aug 2021 15:01:58 +0000 (18:01 +0300)]
ty::layout: implement `layout_of` automatically as a default method.

2 years agorustc_target: move `LayoutOf` to `ty::layout`.
Eduard-Mihai Burtescu [Mon, 30 Aug 2021 14:38:27 +0000 (17:38 +0300)]
rustc_target: move `LayoutOf` to `ty::layout`.

2 years agorustdoc: Don't panic on ambiguous inherent associated types
Noah Lev [Wed, 1 Sep 2021 21:59:07 +0000 (14:59 -0700)]
rustdoc: Don't panic on ambiguous inherent associated types

Instead, return `Type::Infer` since compilation should fail anyway.
That's how rustdoc handles `hir::TyKind::Err`s, so this just extends
that behavior to `ty::Err`s when analyzing associated types.

For some reason, the error is printed twice with rustdoc (though only
once with rustc). I'm not sure why that is, but it's better than
panicking.

This commit also makes rustdoc fail early in the non-projection,
non-error case, instead of returning a `Res::Err` that would likely
cause rustdoc to panic later on. This change is originally from #88379.

2 years agoAuto merge of #88490 - GuillaumeGomez:associated-types-implementors-display, r=cameli...
bors [Wed, 1 Sep 2021 21:31:16 +0000 (21:31 +0000)]
Auto merge of #88490 - GuillaumeGomez:associated-types-implementors-display, r=camelid,Manishearth

Display associated types of implementors

Fixes #86631.

Contrary to before, it doesn't display methods. I also had to "resurrect" the `auto-hide-trait-implementations` setting. :3

Only question at this point: should I move the `render_impl` boolean arguments into one struct? We're starting to have quite a lot of them...

cc `@cynecx`
r? `@camelid`

2 years agoUpdate README.md
Aaron [Wed, 1 Sep 2021 21:04:24 +0000 (14:04 -0700)]
Update README.md

2 years agoReference new diagnostic item docs in our docs :)
xFrednet [Wed, 1 Sep 2021 19:55:08 +0000 (21:55 +0200)]
Reference new diagnostic item docs in our docs :)

2 years agoRemove implementors setting
Guillaume Gomez [Wed, 1 Sep 2021 18:34:51 +0000 (20:34 +0200)]
Remove implementors setting

2 years agoCompute proc_macros in resolutions.
Camille GILLOT [Fri, 16 Jul 2021 20:22:08 +0000 (22:22 +0200)]
Compute proc_macros in resolutions.

2 years agoCompute all_traits_impls during resolution.
Camille GILLOT [Fri, 16 Jul 2021 19:55:10 +0000 (21:55 +0200)]
Compute all_traits_impls during resolution.

2 years agoCompute item_generics_num_lifetimes during resolution.
Camille GILLOT [Wed, 14 Jul 2021 16:04:56 +0000 (18:04 +0200)]
Compute item_generics_num_lifetimes during resolution.

2 years agoStop sorting bodies by span.
Camille GILLOT [Fri, 16 Jul 2021 14:54:47 +0000 (16:54 +0200)]
Stop sorting bodies by span.

The definition order is already close to the span order, and only differs
in corner cases.

2 years agoRemove redundant `Span` in `QueryJobInfo`
Noah Lev [Wed, 1 Sep 2021 18:07:33 +0000 (11:07 -0700)]
Remove redundant `Span` in `QueryJobInfo`

Previously, `QueryJobInfo` was composed of two parts: a `QueryInfo` and
a `QueryJob`. However, both `QueryInfo` and `QueryJob` have a `span`
field, which seem to be the same. So, the `span` was recorded twice.

Now, `QueryJobInfo` is composed of a `QueryStackFrame` (the other field
of `QueryInfo`) and a `QueryJob`. So, now, the `span` is only recorded
once.

2 years agoAuto merge of #88563 - ehuss:update-cargo-books, r=ehuss
bors [Wed, 1 Sep 2021 17:26:49 +0000 (17:26 +0000)]
Auto merge of #88563 - ehuss:update-cargo-books, r=ehuss

Update cargo, books

## nomicon

2 commits in 0c7e5bd1428e7838252bb57b7f0fbfda4ec82f02..fe6227eb3c8533200c52dffa42ef1b6f2f02c40e
2021-08-04 10:18:22 -0700 to 2021-08-31 05:42:38 +0900
- update lifetime-elision to show what elided code under `rust_2018_idi… (rust-lang/nomicon#306)
- Change code for `into_iter` on the `RawVec` section for consistency/soundness (rust-lang/nomicon#302)

## cargo

8 commits in f559c109cc79fe413a8535fb620a5a58b3823d94..18751dd3f238d94d384a7fe967abfac06cbfe0b9
2021-08-26 22:54:55 +0000 to 2021-09-01 14:26:00 +0000
- print the full destination path when no track duplicates (rust-lang/cargo#9850)
- Stabilize 2021 edition (rust-lang/cargo#9800)
- Stabilize patch-in-config (and prefer config over manifest) (rust-lang/cargo#9839)
- Adding the cargo doc --examples subcommand (rust-lang/cargo#9808)
- Make library created with `cargo new` clippy happy (rust-lang/cargo#9796)
- Swap out some outdated repo urls in documentation (rust-lang/cargo#9862)
- Change `cargo fix --edition` to only fix edition lints. (rust-lang/cargo#9846)
- Show desc of well known subcommands (fmt, clippy) in cargo --list (rust-lang/cargo#9848)

## reference

1 commits in da6ea9b03f74cae0a292f40315723d7a3a973637..0e5ed7a4bec065f0cc18c35d1c904639e095314d
2021-08-19 21:28:10 -0700 to 2021-08-29 17:33:21 +0900
- expressions.md: Attempt fixing broken grammar in Mutability paragraph (rust-lang/reference#1084)

## book

1 commits in 687e21bde2ea10c261f79fa14797c5137425098d..fcb5e0ea68112d85a1d29a7a7335978ef2a02181
2021-08-18 20:48:38 -0400 to 2021-08-31 21:26:19 -0400
- Improve the reading of the code (rust-lang/book#2845)

## rustc-dev-guide

7 commits in cf0e151b7925a40f13fbc6573c6f97d5f94c7c17..95f1acf9a39d6f402f654e917e2c1dfdb779c5fc
2021-08-22 11:47:02 -0300 to 2021-08-31 12:38:30 -0500
- Add link to `Span`
- Add rustc-source to suggested rust-analyzer config (rust-lang/rustc-dev-guide#1189)
- Fix typo, clarify backtick wording, and use inline code
- Trailing date comments in a line inside of a paragraph caused beginning of a new paragraph. (rust-lang/rustc-dev-guide#1196)
- Fix warning "Renderer command uses a path relative to the renderer output directory ..." (rust-lang/rustc-dev-guide#1194)
- Fix a code block containing ```rust
- date-check: Recognize capitalized 'Date' as well

## edition-guide

1 commits in 3710b0cae783d0bcd2b42452a63b081473f5970a..2d9b1b9da706de24650fdc5c3b0182f55c82115d
2021-07-26 11:34:46 -0700 to 2021-08-31 10:44:09 +0200
- Update for 2021 stabilization (rust-lang/edition-guide#266)

## embedded-book

1 commits in 4f9fcaa30d11ba52b641e6fd5206536d65838af9..c3a51e23859554369e6bbb5128dcef0e4f159fb5
2021-08-06 17:43:12 +0000 to 2021-08-26 07:04:58 +0000
- Make glossary more linkable and add more detail  (rust-embedded/book#299)

2 years agoadd regression test for issue 83190
Rémy Rakic [Wed, 1 Sep 2021 16:33:34 +0000 (18:33 +0200)]
add regression test for issue 83190

2 years agoUpdate cargo, books
Eric Huss [Wed, 1 Sep 2021 16:27:57 +0000 (09:27 -0700)]
Update cargo, books

2 years agoUndo debug statements
Theodore Luo Wang [Wed, 1 Sep 2021 16:02:11 +0000 (12:02 -0400)]
Undo debug statements

2 years agoUpdate formatting
Theodore Luo Wang [Wed, 1 Sep 2021 15:55:36 +0000 (11:55 -0400)]
Update formatting

2 years agoAdd checks for a block before a unary plus. Fix failing tests
Theodore Luo Wang [Wed, 1 Sep 2021 15:54:06 +0000 (11:54 -0400)]
Add checks for a block before a unary plus. Fix failing tests

2 years agouse the correct feature gate
lcnr [Wed, 1 Sep 2021 15:43:07 +0000 (17:43 +0200)]
use the correct feature gate

Co-authored-by: Boxy <supbscripter@gmail.com>
2 years agoAuto merge of #88269 - prconrad:doctest-persist-binaries, r=jyn514
bors [Wed, 1 Sep 2021 14:33:37 +0000 (14:33 +0000)]
Auto merge of #88269 - prconrad:doctest-persist-binaries, r=jyn514

Doctest persist full binaries when persisting

Tested by adding an extra debug to echo the whole compiler line. Trimmed significantly:

Persisted but not running -> full compile so we get binaries (new behavior).
```
$ rustdoc -Zunstable-options --test --persist-doctests doctests --no-run --extern t=libt.rlib t.rs

DEBUG rustdoc::doctest run_test compiler "rustc" "--crate-type" "bin" "--edition" "2015" "-o" "doctests/t_rs_8_0/rust_out" "--extern" "t=libt.rlib" "-Ccodegen-units=1" "-Z" "unstable-options" "--target" "x86_64-unknown-linux-gnu" "--color" "always"
DEBUG rustdoc::doctest run_test compiler "rustc" "--crate-type" "bin" "--edition" "2015" "-o" "doctests/t_rs_2_0/rust_out" "--extern" "t=libt.rlib" "-Ccodegen-units=1" "-Z" "unstable-options" "--target" "x86_64-unknown-linux-gnu" "--color" "always"
test t.rs - foople (line 2) - compile ... ok
test t.rs - florp (line 8) - compile ... ok
```

Persisted and running -> full compile.
```
$ rustdoc -Zunstable-options --test --persist-doctests doctests --extern t=libt.rlib t.rs

DEBUG rustdoc::doctest run_test compiler "rustc" "--crate-type" "bin" "--edition" "2015" "-o" "doctests/t_rs_8_0/rust_out" "--extern" "t=libt.rlib" "-Ccodegen-units=1" "-Z" "unstable-options" "--target" "x86_64-unknown-linux-gnu" "--color" "always"
DEBUG rustdoc::doctest run_test compiler "rustc" "--crate-type" "bin" "--edition" "2015" "-o" "doctests/t_rs_2_0/rust_out" "--extern" "t=libt.rlib" "-Ccodegen-units=1" "-Z" "unstable-options" "--target" "x86_64-unknown-linux-gnu" "--color" "always"

```

Running but not persisted -> full compile only
```
$ rustdoc --test --extern t=libt.rlib t.rs

DEBUG rustdoc::doctest run_test compiler "rustc" "--crate-type" "bin" "--edition" "2015" "-o" "/tmp/rustdoctestixWAUI/rust_out" "--extern" "t=libt.rlib" "-Ccodegen-units=1" "--target" "x86_64-unknown-linux-gnu" "--color" "always"
DEBUG rustdoc::doctest run_test compiler "rustc" "--crate-type" "bin" "--edition" "2015" "-o" "/tmp/rustdoctestKEaJQu/rust_out" "--extern" "t=libt.rlib" "-Ccodegen-units=1" "--target" "x86_64-unknown-linux-gnu" "--color" "always"

```

Not running and not persisting -> save time and only run metadata.
```
RUSTDOC_LOG=rustdoc=debug,std::test=debug rustdoc -Zunstable-options --no-run --test --extern t=libt.rlib t.rs

DEBUG rustdoc::doctest run_test compiler "rustc" "--crate-type" "bin" "--edition" "2015" "-o" "/tmp/rustdoctest8twt2c/rust_out" "--extern" "t=libt.rlib" "-Ccodegen-units=1" "-Z" "unstable-options" "--emit=metadata" "--target" "x86_64-unknown-linux-gnu" "--color" "always"
DEBUG rustdoc::doctest run_test compiler "rustc" "--crate-type" "bin" "--edition" "2015" "-o" "/tmp/rustdoctest3miSqv/rust_out" "--extern" "t=libt.rlib" "-Ccodegen-units=1" "-Z" "unstable-options" "--emit=metadata" "--target" "x86_64-unknown-linux-gnu" "--color" "always"
```

I can't see any infrastructure for automating this sort of test. Am I missing it?

2 years agofix clippy lints
klensy [Wed, 1 Sep 2021 12:52:29 +0000 (15:52 +0300)]
fix clippy lints

2 years agoMove add_rlib and add_native_library to cg_ssa
bjorn3 [Wed, 1 Sep 2021 12:38:37 +0000 (14:38 +0200)]
Move add_rlib and add_native_library to cg_ssa

This deduplicates logic between codegen backends

2 years ago`fmt::Formatter::pad`: don't call chars().count() more than one time
klensy [Wed, 1 Sep 2021 12:35:58 +0000 (15:35 +0300)]
`fmt::Formatter::pad`: don't call chars().count() more than one time

2 years agoAuto merge of #88395 - ricky26:llvm-submodule, r=nikic
bors [Wed, 1 Sep 2021 11:47:18 +0000 (11:47 +0000)]
Auto merge of #88395 - ricky26:llvm-submodule, r=nikic

Update LLVM submodule

This will capture the two M68k bugfixes to help with #88321.

2 years agoupdate FIXME
lcnr [Wed, 1 Sep 2021 09:42:52 +0000 (11:42 +0200)]
update FIXME

2 years agocleanup const generics FIXME
lcnr [Wed, 1 Sep 2021 09:41:06 +0000 (11:41 +0200)]
cleanup const generics FIXME

2 years agoAuto merge of #88556 - m-ou-se:rollup-q636wyd, r=m-ou-se
bors [Wed, 1 Sep 2021 09:06:24 +0000 (09:06 +0000)]
Auto merge of #88556 - m-ou-se:rollup-q636wyd, r=m-ou-se

Rollup of 9 pull requests

Successful merges:

 - #86376 (Emit specific warning to clarify that `#[no_mangle]` should not be applied on foreign statics or functions)
 - #88040 (BTree: remove Ord bound from new)
 - #88053 (Fix the flock fallback implementation)
 - #88350 (add support for clobbering xer, cr, and cr[0-7] for asm! on OpenPower/PowerPC)
 - #88410 (Remove bolding on associated constants)
 - #88525 (fix(rustc_typeck): produce better errors for dyn auto trait)
 - #88542 (Use the return value of readdir_r() instead of errno)
 - #88548 (Stabilize `Iterator::intersperse()`)
 - #88551 (Stabilize `UnsafeCell::raw_get()`)

Failed merges:

r? `@ghost`
`@rustbot` modify labels: rollup

2 years agoClean render_impl arguments
Guillaume Gomez [Tue, 31 Aug 2021 10:20:02 +0000 (12:20 +0200)]
Clean render_impl arguments

2 years agoAdd tests for implementors associated types display
Guillaume Gomez [Mon, 30 Aug 2021 14:47:17 +0000 (16:47 +0200)]
Add tests for implementors associated types display

2 years agoRollup merge of #88551 - inquisitivecrystal:unsafe_cell_raw_get, r=m-ou-se
Mara Bos [Wed, 1 Sep 2021 07:23:31 +0000 (09:23 +0200)]
Rollup merge of #88551 - inquisitivecrystal:unsafe_cell_raw_get, r=m-ou-se

Stabilize `UnsafeCell::raw_get()`

This PR stabilizes the associated function `UnsafeCell::raw_get()`. The FCP has [already completed](https://github.com/rust-lang/rust/issues/66358#issuecomment-899095068). While there was some discussion about the naming after the close of the FCP, it looks like people have agreed on this name. Still, it would probably be best if a `libs-api` member had a look at this and stated whether more discussion is needed.

While I was at it, I added some tests for `UnsafeCell`, because there were barely any.

Closes #66358.

2 years agoRollup merge of #88548 - inquisitivecrystal:intersperse, r=m-ou-se
Mara Bos [Wed, 1 Sep 2021 07:23:30 +0000 (09:23 +0200)]
Rollup merge of #88548 - inquisitivecrystal:intersperse, r=m-ou-se

Stabilize `Iterator::intersperse()`

This PR stabilizes the methods `Iterator::intersperse()` and `Iterator::intersperse_with()`. The FCP has [already completed](https://github.com/rust-lang/rust/issues/79524#issuecomment-909663616).

Closes #79524.

2 years agoRollup merge of #88542 - tavianator:readdir_r-errno, r=jyn514
Mara Bos [Wed, 1 Sep 2021 07:23:29 +0000 (09:23 +0200)]
Rollup merge of #88542 - tavianator:readdir_r-errno, r=jyn514

Use the return value of readdir_r() instead of errno

POSIX says:

> If successful, the readdir_r() function shall return zero; otherwise,
> an error number shall be returned to indicate the error.

But we were previously using errno instead of the return value.  This
led to issue #86649.

2 years agoRollup merge of #88525 - notriddle:notriddle/coherence-dyn-auto-trait, r=petrochenkov
Mara Bos [Wed, 1 Sep 2021 07:23:28 +0000 (09:23 +0200)]
Rollup merge of #88525 - notriddle:notriddle/coherence-dyn-auto-trait, r=petrochenkov

fix(rustc_typeck): produce better errors for dyn auto trait

Fixes #85026

2 years agoRollup merge of #88410 - camelid:fix-assoc-bold, r=GuillaumeGomez
Mara Bos [Wed, 1 Sep 2021 07:23:27 +0000 (09:23 +0200)]
Rollup merge of #88410 - camelid:fix-assoc-bold, r=GuillaumeGomez

Remove bolding on associated constants

Associated types don't get bolded, so it looks off to have one kind
bolded and one not.

2 years agoRollup merge of #88350 - programmerjake:add-ppc-cr-xer-clobbers, r=Amanieu
Mara Bos [Wed, 1 Sep 2021 07:23:26 +0000 (09:23 +0200)]
Rollup merge of #88350 - programmerjake:add-ppc-cr-xer-clobbers, r=Amanieu

add support for clobbering xer, cr, and cr[0-7] for asm! on OpenPower/PowerPC

Fixes #88315

2 years agoRollup merge of #88053 - bjorn3:fix_flock_fallback_impl, r=cjgillot
Mara Bos [Wed, 1 Sep 2021 07:23:25 +0000 (09:23 +0200)]
Rollup merge of #88053 - bjorn3:fix_flock_fallback_impl, r=cjgillot

Fix the flock fallback implementation

2 years agoRollup merge of #88040 - nbdd0121:btreemap, r=m-ou-se
Mara Bos [Wed, 1 Sep 2021 07:23:23 +0000 (09:23 +0200)]
Rollup merge of #88040 - nbdd0121:btreemap, r=m-ou-se

BTree: remove Ord bound from new

`K: Ord` bound is unnecessary on `BTree{Map,Set}::new` and their `Default` impl. No elements exist so there are nothing to compare anyway, so I don't think "future proof" would be a blocker here. This is analogous to `HashMap::new` not having a `K: Eq + Hash` bound.

#79245 originally does this and for some reason drops the change to `new` and `Default`. I can see why changes to other methods like `entry` or `symmetric_difference` need to be careful but I couldn't find out any reason not to do it on `new`.

Removing the bound also makes the stabilisation of `const fn new` not depending on const trait bounds.

cc `@steffahn` who suggests me to make this PR.

r? `@dtolnay`

2 years agoRollup merge of #86376 - asquared31415:extern-no-mangle-84204, r=Mark-Simulacrum
Mara Bos [Wed, 1 Sep 2021 07:23:22 +0000 (09:23 +0200)]
Rollup merge of #86376 - asquared31415:extern-no-mangle-84204, r=Mark-Simulacrum

Emit specific warning to clarify that `#[no_mangle]` should not be applied on foreign statics or functions

Foreign statics and foreign functions should not have `#[no_mangle]` applied, as it does nothing to the name and has some extra hidden behavior that is normally unwanted.  There was an existing warning for this, but it says the attribute is only allowed on "statics or functions", which to the user can be confusing.

This PR adds a specific version of the unused `#[no_mangle]` warning that explains that the target is a *foreign* static or function and that they do not need the attribute.

Fixes #78989

2 years agoAuto merge of #88272 - willcrichton:mutable-sparse-matrix, r=ecstatic-morse
bors [Wed, 1 Sep 2021 06:13:15 +0000 (06:13 +0000)]
Auto merge of #88272 - willcrichton:mutable-sparse-matrix, r=ecstatic-morse

Add bit removal methods to SparseBitMatrix and factor *BitSet relational methods into more extensible trait

I need the ability to clear the bits out of a row from `SparseBitMatrix`. Currently, all the mutating methods only allow insertion of bits, and there is no way to get access to the underlying data.

One approach is simply to make `ensure_row` public, since it grants `&mut` access to the underlying `HybridBitSet`. This PR adds the `pub` modifier. However, presumably this method was private for a reason, so I'm open to other designs. I would prefer general mutable access to the rows, because that way I can add many mutating operations (`clear`, `intersect`, etc.) without filing a PR each time :-)

r? `@ecstatic-morse`

2 years agofix(rustc_lint): better detect when parens are necessary
Michael Howell [Tue, 31 Aug 2021 21:45:57 +0000 (14:45 -0700)]
fix(rustc_lint): better detect when parens are necessary

Fixes #88519

2 years agoAuto merge of #88121 - camelid:better-recursive-alias-error, r=estebank
bors [Wed, 1 Sep 2021 03:43:37 +0000 (03:43 +0000)]
Auto merge of #88121 - camelid:better-recursive-alias-error, r=estebank

Improve errors for recursive type aliases

Fixes #17539.

2 years agoRemove unhelpful `expect()` message
Noah Lev [Wed, 1 Sep 2021 01:10:57 +0000 (18:10 -0700)]
Remove unhelpful `expect()` message

2 years agoBox `GenericArgs::Parenthesized.output`
Noah Lev [Mon, 23 Aug 2021 04:35:01 +0000 (21:35 -0700)]
Box `GenericArgs::Parenthesized.output`

This reduces the size of `GenericArgs` from 104 bytes to 56 bytes,
essentially reducing it by half.

`GenericArgs` is one of the fields of `PathSegment`, so this should
reduce the amount of memory allocated for `PathSegment`s in the cases
where the generics are not for a `Fn`, `FnMut`, or `FnOnce` trait.

I also added `static_assert_size!`s to `GenericArgs` and `PathSegment`
to ensure they don't increase in size unexpectedly.

2 years agoApply formatting
Theodore Luo Wang [Wed, 1 Sep 2021 03:09:43 +0000 (23:09 -0400)]
Apply formatting

2 years agoImprove error checking on unary plus
Theodore Luo Wang [Wed, 1 Sep 2021 03:07:58 +0000 (23:07 -0400)]
Improve error checking on unary plus

2 years agoAuto merge of #87688 - camsteffen:let-else, r=cjgillot
bors [Wed, 1 Sep 2021 01:02:42 +0000 (01:02 +0000)]
Auto merge of #87688 - camsteffen:let-else, r=cjgillot

Introduce `let...else`

Tracking issue: #87335

The trickiest part for me was enforcing the diverging else block with clear diagnostics. Perhaps the obvious solution is to expand to `let _: ! = ..`, but I decided against this because, when a "mismatched type" error is found in typeck, there is no way to trace where in the HIR the expected type originated, AFAICT. In order to pass down this information, I believe we should introduce `Expectation::LetElseNever(HirId)` or maybe add `HirId` to `Expectation::HasType`, but I left that as a future enhancement. For now, I simply assert that the block is `!` with a custom `ObligationCauseCode`, and I think this is clear enough, at least to start. The downside here is that the error points at the entire block rather than the specific expression with the wrong type. I left a todo to this effect.

Overall, I believe this PR is feature-complete with regard to the RFC.

2 years agoAdd a few tests for `UnsafeCell`
inquisitivecrystal [Tue, 31 Aug 2021 23:32:01 +0000 (16:32 -0700)]
Add a few tests for `UnsafeCell`

2 years agoInclude debug info for the allocator shim
Daniel Paoliello [Tue, 31 Aug 2021 18:16:10 +0000 (11:16 -0700)]
Include debug info for the allocator shim
Issue Details:
In some cases it is necessary to generate an "allocator shim" to forward various Rust allocation functions (e.g., `__rust_alloc`) to an underlying function (e.g., `malloc`). However, since this allocator shim is a manually created LLVM module it is not processed via the normal module processing code and so no debug info is generated for it (if debugging info is enabled).

Fix Details:
* Modify the `debuginfo` code to allow creating debug info for a module without a `CodegenCx` (since it is difficult, and expensive, to create one just to emit some debug info).
* After creating the allocator shim add in basic debug info.

2 years agoAuto merge of #88533 - oli-obk:tait_🧊, r=spastorino
bors [Tue, 31 Aug 2021 22:15:26 +0000 (22:15 +0000)]
Auto merge of #88533 - oli-obk:tait_🧊, r=spastorino

Concrete regions can show up in mir borrowck if the originated from there

We used to not encounter them here, because we took regions from typeck's opaque type resolution by renumbering them. We don't do that anymore. Instead mir borrock does all the logic, and it can handle concrete regions just fine, as long as it created them itself.

fixes #83190 which was introduced by #87287

r? `@spastorino`

2 years agoMove test to run-make-fulldeps to avoid compiler flag bug
Patrick Conrad [Tue, 31 Aug 2021 22:06:18 +0000 (18:06 -0400)]
Move test to run-make-fulldeps to avoid compiler flag bug

2 years agoStabilize `Iterator::intersperse()`
inquisitivecrystal [Tue, 31 Aug 2021 21:35:12 +0000 (14:35 -0700)]
Stabilize `Iterator::intersperse()`

2 years agoStabilize `UnsafeCell::raw_get()`
inquisitivecrystal [Tue, 31 Aug 2021 21:44:13 +0000 (14:44 -0700)]
Stabilize `UnsafeCell::raw_get()`

2 years agox.py clippy: don't run with --all-targets by default
Matthias Krüger [Mon, 30 Aug 2021 21:32:57 +0000 (23:32 +0200)]
x.py clippy: don't run with --all-targets by default

this caused a lot of noise because benchmarks and tests were also checked

2 years agoAdd test for closure migration where body is a block fragment.
Mara Bos [Tue, 31 Aug 2021 20:18:10 +0000 (22:18 +0200)]
Add test for closure migration where body is a block fragment.

2 years agoImprove closure dummy capture suggestion in macros.
Mara Bos [Tue, 31 Aug 2021 20:17:51 +0000 (22:17 +0200)]
Improve closure dummy capture suggestion in macros.