Camille GILLOT
9d86e6abaf
Use the interned stable hash as plain hash.
2022-11-11 13:02:37 +00:00
Camille GILLOT
d47424b833
Hash spans when interning.
2022-11-11 13:02:37 +00:00
Camille GILLOT
c42a4245cc
Do not rename bound variables when verbose-printing binders.
2022-11-11 13:02:37 +00:00
León Orell Valerian Liehr
c2b906ba9a
Recover from fn ptr tys with generic param list
2022-11-11 13:42:40 +01:00
Albert Larsan
a1909b7b07
Try another way
2022-11-11 12:17:32 +01:00
Camille GILLOT
6c95805a34
Clean-up formatting.
2022-11-11 10:32:49 +00:00
Camille GILLOT
60892e8b1d
Visit opaque types during type collection too.
2022-11-11 10:29:27 +00:00
Albert Larsan
fb98796892
Apply suggestions
2022-11-11 11:14:09 +01:00
Camille GILLOT
3075f03513
Resolve lifetimes using the regular logic for RPIT.
2022-11-11 10:12:28 +00:00
Camille GILLOT
44c10e4cb0
Resolve lifetimes independently for each item-like.
2022-11-11 10:11:50 +00:00
Camille GILLOT
0ff1d1e122
Tweak signatures in rustc_middle::hir::map.
2022-11-11 10:10:16 +00:00
Florian Bartels
ae71df987b
Add nto
as known target_os
2022-11-11 10:44:48 +01:00
Florian Bartels
84e1fbcadf
Add no_std AArch64 support for the QNX Neutrino (nto) 7.1 RTOS
...
This change allows to compile no_std applications for the QNX Neutrino
realtime operating system for ARM 64 bit CPUs.
Tested with QNX Neutrino 7.1.
2022-11-11 10:44:48 +01:00
Michael Benfield
51918dcc51
rustc_codegen_ssa: Better code generation for niche discriminants.
...
In some cases we can avoid arithmetic before checking whether a niche
represents an untagged variant.
This is relevant to #101872
2022-11-11 05:54:30 +00:00
bors
b7b7f2716e
Auto merge of #103898 - Nilstrieb:match-macro, r=nnethercote
...
Retry failed macro matching for diagnostics
When a declarative macro fails to match, retry the matching to collect diagnostic info instead of collecting it on the fly in the hot path. Split out of #103439 .
You made a bunch of changes to declarative macro matching, so
r? `@nnethercote`
This change should produce a few small perf wins: https://github.com/rust-lang/rust/pull/103439#issuecomment-1294249602
2022-11-11 04:54:59 +00:00
Ben Reeves
94f67e667b
Oops, bless this test.
2022-11-10 22:14:08 -06:00
Esteban Küber
f57713b010
Fix tests after rebase
2022-11-10 19:01:33 -08:00
bors
5b82ea74b7
Auto merge of #99918 - WaffleLapkin:fnFnfun, r=estebank
...
Recover wrong-cased keywords that start items
(_this pr was inspired by [this tweet](https://twitter.com/Azumanga/status/1552982326409367561 )_)
r? `@estebank`
We've talked a bit about this recovery, but I just wanted to make sure that this is the right approach :)
For now I've only added the case insensitive recovery to `use`s, since most other items like `impl` blocks, modules, functions can start with multiple keywords which complicates the matter.
2022-11-11 02:07:52 +00:00
Esteban Küber
8bd8484972
review comments
2022-11-10 18:06:59 -08:00
Esteban Küber
243496e129
Consider #[must_use]
annotation on async fn
as also affecting the Future::Output
...
No longer lint against `#[must_use] async fn foo()`.
When encountering a statement that awaits on a `Future`, check if the
`Future`'s parent item is annotated with `#[must_use]` and emit a lint
if so. This effectively makes `must_use` an annotation on the
`Future::Output` instead of only the `Future` itself.
Fix #78149 .
2022-11-10 18:01:03 -08:00
Esteban Küber
50bb7a40e1
Tweak span for #[must_use]
...
Do not point at whole statement, only at the expression (skip pointing at `;`)
2022-11-10 18:01:02 -08:00
Takayuki Maeda
6018f115aa
emit errors when using RangeFrom
and RangeTo
2022-11-11 10:51:02 +09:00
Takayuki Maeda
004986b79b
avoid unnecessary format!
2022-11-11 10:51:02 +09:00
Takayuki Maeda
c467006fd0
suggest removing unnecessary . to use a floating point literal
2022-11-11 10:51:00 +09:00
kubycsolutions
b8edf0213e
Avoid runtime dependency on static libstdc++
...
Usually, we do want to use the static C++ library when building rustc_llvm, but do not want to have that dependency at compiler runtime. Change the defaults to Make It So.
2022-11-10 19:37:09 -05:00
Michael Howell
0f3ae6218e
rustdoc: use checkbox instead of switch for settings toggles
...
The switch is designed to give the application a "physical" feel, but
nothing else in here really followed through. They didn't support the
"flick" gesture that real iOS switches support, and the radio
buttons that were also used in Rustdoc Settings were a more "classic"
form element anyway.
Also, while "switches" are the exclusive toggle design on iOS (since
[Apple HIG] reserves checkboxes for Mac only), the [Google Material]
guidelines say that lists of switches are bad, and you should just use
check boxes.
[Apple HIG]: https://developer.apple.com/design/human-interface-guidelines/components/selection-and-input/toggles
[Google Material]: https://m3.material.io/components/checkbox/guidelines#6902f23d-ceba-4b19-ae3b-b78b9b01d185
2022-11-10 17:22:37 -07:00
Michael Goulet
07aa592504
Regression test for coercion of mut-ref to dyn-star
2022-11-10 23:54:34 +00:00
Albert Larsan
d85b61460a
Add a reference to ilog2 in leading_zeros integer docs
...
Asked in #104248
2022-11-11 00:47:52 +01:00
Michael Goulet
fea8d0eb99
More nits
2022-11-10 21:29:20 +00:00
Michael Goulet
43ad19b250
bless tests
2022-11-10 21:18:06 +00:00
lcnr
8ec6c84bb3
add some more tests
2022-11-10 21:18:06 +00:00
lcnr
0f2e45b18f
make Sized
coinductive
2022-11-10 21:18:06 +00:00
Michael Goulet
55f1f993ff
More accurately report error when formal and expected signature types differ
2022-11-10 20:21:31 +00:00
Michael Goulet
312d6b8e9a
Don't emit coerce suggestions for a type into itself
2022-11-10 20:21:13 +00:00
bors
c1a859b25a
Auto merge of #104164 - cjgillot:u64-cache, r=compiler-errors
...
Use 64 bits for incremental cache in-file positions
We currently use a 32-bit integer to encode byte positions into the incremental cache.
This is not enough when the query chache file is >4GB.
As the overflow check was a `debug_assert`, it was removed in released compilers, making compilation succeed silently.
At the next compilation, cache decoding would try to read unrelated data because of garbled file position, triggering an ICE.
Fixes https://github.com/rust-lang/rust/issues/79786
(I'm closing that bug since it the original report and the subsequent questions are probably different instances. A new bug should be opened for new instances of that ICE.)
2022-11-10 20:13:42 +00:00
Ben Reeves
fe53cacff9
Apply PR feedback.
2022-11-10 12:56:33 -06:00
Ben Reeves
c0ae62ee95
Require ~const
qualifier on trait bounds in specializing impls if present in base impl.
2022-11-10 12:37:07 -06:00
Ben Reeves
d492b9b000
Add #[const_trait] where needed in tests.
2022-11-10 12:37:07 -06:00
Ben Reeves
ce03d259da
Disallow specializing on const impls with non-const impls.
2022-11-10 12:37:06 -06:00
Ben Reeves
5c25d30f6f
Allow specialized const trait impls.
...
Fixes #95186 .
Fixes #95187 .
2022-11-10 12:37:06 -06:00
Guillaume Gomez
149ab45ead
Add GUI test for :target
2022-11-10 18:53:31 +01:00
Guillaume Gomez
384059a07a
Migrate :target rules to use CSS variables
2022-11-10 18:53:30 +01:00
Charles Lew
3074678cd1
Mark trait_upcasting
feature no longer incomplete.
2022-11-11 00:35:08 +08:00
joboet
f30614a088
update debuginfo check
2022-11-10 17:31:23 +01:00
bors
a3c0a02361
Auto merge of #104246 - Manishearth:rollup-9o3txc7, r=Manishearth
...
Rollup of 9 pull requests
Successful merges:
- #101939 (Add loongarch64 abi support)
- #103863 (Use `TraitEngine` in more places, restrict visibility of `FulfillmentCtxt` constructor)
- #104036 (Suggest `is_some` when we've found `Option` but expected `bool`)
- #104060 (Make `Hash`, `Hasher` and `BuildHasher` `#[const_trait]` and make `Sip` const `Hasher`)
- #104077 (Use aapcs for efiapi calling convention on arm)
- #104186 (Tighten the 'introduce new binding' suggestion)
- #104194 (`EarlyBinder` docs)
- #104233 (Don't ICE when encountering `ConstKind::Error` in `RequiredConstsVisitor`)
- #104235 (Use `const_error_with_guaranteed` more)
Failed merges:
- #104078 (Print "Checking/Building ..." message even when --dry-run is passed)
- #104169 (Migrate `:target` rules to use CSS variables)
r? `@ghost`
`@rustbot` modify labels: rollup
2022-11-10 16:22:59 +00:00
Manish Goregaokar
ea56e80726
Rollup merge of #104235 - compiler-errors:more-ct-guar, r=oli-obk
...
Use `const_error_with_guaranteed` more
Better to pass down an ErrorGuaranteed rather than making a new one out of thin air, for some usages. Also for the ones where we *do* need to delay a bug, that delayed bug will have a more descriptive message.
2022-11-10 10:47:42 -05:00
Manish Goregaokar
77fde5d49a
Rollup merge of #104233 - compiler-errors:issue-104209, r=lcnr
...
Don't ICE when encountering `ConstKind::Error` in `RequiredConstsVisitor`
Fixes #104209
2022-11-10 10:47:41 -05:00
Manish Goregaokar
c6595ea22a
Rollup merge of #104194 - BoxyUwU:early_binder_docs, r=compiler-errors
...
`EarlyBinder` docs
2022-11-10 10:47:41 -05:00
Manish Goregaokar
819c9315c3
Rollup merge of #104186 - chenyukang:yukang/fix-104086-let-binding-issue, r=oli-obk
...
Tighten the 'introduce new binding' suggestion
Fixes #104086
2022-11-10 10:47:40 -05:00
Manish Goregaokar
8f2c1f8469
Rollup merge of #104077 - nicholasbishop:bishop-uefi-aapcs, r=nagisa
...
Use aapcs for efiapi calling convention on arm
On arm, [llvm treats the C calling convention as `aapcs` on soft-float targets and `aapcs-vfp` on hard-float targets](https://github.com/rust-lang/compiler-builtins/issues/116#issuecomment-261057422 ). UEFI specifies in the arm calling convention that [floating point extensions aren't used](https://uefi.org/specs/UEFI/2.10/02_Overview.html#detailed-calling-convention ), so always translate `efiapi` to `aapcs` on arm.
https://github.com/rust-lang/rust/issues/65815
2022-11-10 10:47:39 -05:00