Skip to content
Closed
Show file tree
Hide file tree
Changes from 3 commits
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
41ff6a8
Update LLVM submodule
Feb 10, 2023
313f04f
Add regression test for #105626
Feb 22, 2023
a914f37
Add lint against `Iterator::map` receiving a callable that returns `()`
obeis Feb 16, 2023
ddd7d10
Add ui test for `map_unit_fn` lint
obeis Feb 16, 2023
a87443a
Emit `map_unit_fn` lint in closure case
obeis Feb 16, 2023
b93d545
Add ui test for `map_unit_fn` lint in closure case
obeis Feb 16, 2023
99344a8
Add ui test for `E0271` error
obeis Feb 20, 2023
37d4302
Add regression test for #107918
GuillaumeGomez Feb 24, 2023
dca52ac
make "proc macro panicked" translatable
tshepang Feb 24, 2023
60ac309
add `known-bug` test for unsoundness issue #108425
gburgessiv Feb 25, 2023
9f876cc
docs/test: add UI test and docs for `E0476`
Ezrashaw Feb 25, 2023
7d83d69
add `known-bug` test for unsoundness issue #107975
gburgessiv Feb 25, 2023
6adc76d
add `known-bug` test for unsoundness issue #105787
gburgessiv Feb 25, 2023
3b51e9f
fix: fix issue in macro
Ezrashaw Feb 25, 2023
ed34354
Do not lint unresolved trait for ineffective unstable trait impl
fee1-dead Feb 25, 2023
c934ee8
Don't run issue-107918.rs test on windows
GuillaumeGomez Feb 25, 2023
885f9e7
Complete migrating `ast_passes` to derive diagnostics
clubby789 Feb 25, 2023
3560e65
Treat `str` as containing `[u8]` for auto trait purposes
compiler-errors Feb 11, 2023
53fb433
Special note for str in auto traits
compiler-errors Feb 14, 2023
c961431
Rollup merge of #107879 - icedrocket:update-llvm, r=cuviper
compiler-errors Feb 25, 2023
ec961db
Rollup merge of #107890 - obeis:mapping-to-unit, r=cjgillot
compiler-errors Feb 25, 2023
dfcaa20
Rollup merge of #107941 - compiler-errors:str-has-u8-slice-for-auto, …
compiler-errors Feb 25, 2023
cf5c521
Rollup merge of #108431 - GuillaumeGomez:regression-test-for-107918, …
compiler-errors Feb 25, 2023
8fa308d
Rollup merge of #108436 - tshepang:translatable-proc-macro-panicked, …
compiler-errors Feb 25, 2023
cb58440
Rollup merge of #108444 - Ezrashaw:add-test+docs-for-e0476, r=Guillau…
compiler-errors Feb 25, 2023
4b8a3a6
Rollup merge of #108445 - gburgessiv:add-known-bug, r=compiler-errors
compiler-errors Feb 25, 2023
fea67c2
Rollup merge of #108449 - fee1-dead-contrib:do_not_lint_unresolved, r…
compiler-errors Feb 25, 2023
e05492a
Rollup merge of #108456 - clubby789:ast-passes-diag-migrate, r=compil…
compiler-errors Feb 25, 2023
File filter

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -20,12 +20,14 @@ pub(super) fn instantiate_constituent_tys_for_auto_trait<'tcx>(
| ty::Float(_)
| ty::FnDef(..)
| ty::FnPtr(_)
| ty::Str
| ty::Error(_)
| ty::Infer(ty::IntVar(_) | ty::FloatVar(_))
| ty::Never
| ty::Char => Ok(vec![]),

// Treat this like `struct str([u8]);`
ty::Str => Ok(vec![tcx.mk_slice(tcx.types.u8)]),

ty::Dynamic(..)
| ty::Param(..)
| ty::Foreign(..)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3107,6 +3107,7 @@ impl<'tcx> TypeErrCtxtExt<'tcx> for TypeErrCtxt<'_, 'tcx> {
self.tcx.def_span(def_id),
"required because it's used within this closure",
),
ty::Str => err.note("`str` is considered to contain a `[u8]` slice for auto trait purposes"),
_ => err.note(&msg),
};
}
Expand Down
4 changes: 3 additions & 1 deletion compiler/rustc_trait_selection/src/traits/select/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2300,12 +2300,14 @@ impl<'cx, 'tcx> SelectionContext<'cx, 'tcx> {
| ty::Float(_)
| ty::FnDef(..)
| ty::FnPtr(_)
| ty::Str
| ty::Error(_)
| ty::Infer(ty::IntVar(_) | ty::FloatVar(_))
| ty::Never
| ty::Char => ty::Binder::dummy(Vec::new()),

// Treat this like `struct str([u8]);`
ty::Str => ty::Binder::dummy(vec![self.tcx().mk_slice(self.tcx().types.u8)]),

ty::Placeholder(..)
| ty::Dynamic(..)
| ty::Param(..)
Expand Down
13 changes: 13 additions & 0 deletions tests/ui/auto-traits/str-contains-slice-conceptually.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
#![feature(negative_impls)]
#![feature(auto_traits)]

auto trait AutoTrait {}

impl<T> !AutoTrait for [T] {}

fn needs_auto_trait<T: AutoTrait + ?Sized>() {}

fn main() {
needs_auto_trait::<str>();
//~^ ERROR the trait bound `[u8]: AutoTrait` is not satisfied in `str`
}
16 changes: 16 additions & 0 deletions tests/ui/auto-traits/str-contains-slice-conceptually.stderr
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
error[E0277]: the trait bound `[u8]: AutoTrait` is not satisfied in `str`
--> $DIR/str-contains-slice-conceptually.rs:11:22
|
LL | needs_auto_trait::<str>();
| ^^^ within `str`, the trait `AutoTrait` is not implemented for `[u8]`
|
= note: `str` is considered to contain a `[u8]` slice for auto trait purposes
note: required by a bound in `needs_auto_trait`
--> $DIR/str-contains-slice-conceptually.rs:8:24
|
LL | fn needs_auto_trait<T: AutoTrait + ?Sized>() {}
| ^^^^^^^^^ required by this bound in `needs_auto_trait`

error: aborting due to previous error

For more information about this error, try `rustc --explain E0277`.