Commit message (Collapse) | Author | Age | Files | Lines | ||
---|---|---|---|---|---|---|
... | ||||||
* | Merge #7907 | bors[bot] | 2021-03-24 | 2 | -12/+34 | |
|\ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 7907: Autoderef with visibility r=cynecx a=cynecx Fixes https://github.com/rust-analyzer/rust-analyzer/issues/7841. I am not sure about the general approach here. Right now this simply tries to check whether the autoderef candidate is reachable from the current module. ~~However this doesn't exactly work with traits (see the `tests::macros::infer_derive_clone_in_core` test, which fails right now).~~ see comment below Refs: - `rustc_typeck` checking fields: https://github.com/rust-lang/rust/blob/66ec64ccf31883cd2c28d045912a76179c0c6ed2/compiler/rustc_typeck/src/check/expr.rs#L1610 r? @flodiebold Co-authored-by: cynecx <[email protected]> | |||||
| * | hir_ty: don't call write_field_resolution when field candidate isn't visible | cynecx | 2021-03-24 | 1 | -6/+4 | |
| | | ||||||
| * | hir_ty: introduce visible_from_module param into method resolution | cynecx | 2021-03-20 | 2 | -0/+2 | |
| | | ||||||
| * | hir_ty: check field visibility while iterating through autoderef candidates | cynecx | 2021-03-20 | 1 | -14/+36 | |
| | | ||||||
* | | Merge #8139 | bors[bot] | 2021-03-22 | 3 | -30/+43 | |
|\ \ | | | | | | | | | | | | | | | | | | | | | | 8139: Align `Canonical` and `InEnvironment` with the Chalk versions r=flodiebold a=flodiebold Co-authored-by: Florian Diebold <[email protected]> | |||||
| * | | Align InEnvironment with Chalk | Florian Diebold | 2021-03-21 | 3 | -16/+13 | |
| | | | | | | | | | | | | | | | | | | This in particular means storing a chalk_ir::Environment, not our TraitEnvironment. This makes InEnvironment not usable for Type, where we need to keep the full TraitEnvironment. | |||||
| * | | Align Canonical more with Chalk's version | Florian Diebold | 2021-03-21 | 1 | -14/+30 | |
| | | | | | | | | | | | | In particular, use chalk_ir::CanonicalVarKinds. | |||||
* | | | Merge #8136 #8146 | bors[bot] | 2021-03-22 | 2 | -4/+16 | |
|\| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 8136: Introduce QuantifiedWhereClause and DynTy analogous to Chalk r=flodiebold a=flodiebold This introduces a bunch of new binders in lots of places, which we have to be careful about, but we had to add them at some point. There's a lot of skipping of the binders; once we're done with the Chalk move, we should review the remaining ones. 8146: Document patch policy r=matklad a=matklad bors r+ 🤖 Co-authored-by: Florian Diebold <[email protected]> Co-authored-by: Aleksey Kladov <[email protected]> | |||||
| * | | Use QuantifiedWhereClause in generic_predicates as well | Florian Diebold | 2021-03-21 | 1 | -1/+4 | |
| | | | | | | | | | | | | | | | Still far too much binder skipping going on; I find it hard to imagine this is all correct, but the tests pass. | |||||
| * | | Introduce QuantifiedWhereClause and DynTy analogous to Chalk | Florian Diebold | 2021-03-21 | 1 | -3/+12 | |
| | | | | | | | | | | | | | | | This introduces a bunch of new binders in lots of places, which we have to be careful about, but we had to add them at some point. | |||||
* | | | Fix box pattern inference panic | Lukas Wirth | 2021-03-21 | 2 | -9/+29 | |
|/ / | ||||||
* / | clippy::complexity simplifications related to Iterators | Matthias Krüger | 2021-03-21 | 1 | -1/+1 | |
|/ | ||||||
* | Turn Obligation into something similar to chalk_ir::DomainGoal | Florian Diebold | 2021-03-20 | 4 | -30/+27 | |
| | | | | This includes starting to make use of Chalk's `Cast` trait. | |||||
* | Rename GenericPredicate -> WhereClause | Florian Diebold | 2021-03-20 | 1 | -11/+6 | |
| | ||||||
* | Replace Projection variant in GenericPredicate with AliasEq | Lukas Wirth | 2021-03-19 | 1 | -12/+23 | |
| | ||||||
* | Chalkify TraitRef | Florian Diebold | 2021-03-18 | 4 | -13/+22 | |
| | ||||||
* | Rename Substs -> Substitution | Florian Diebold | 2021-03-16 | 5 | -43/+48 | |
| | ||||||
* | Fix unification logic | Florian Diebold | 2021-03-15 | 1 | -1/+1 | |
| | ||||||
* | Merge #8018 | bors[bot] | 2021-03-15 | 4 | -39/+44 | |
|\ | | | | | | | | | | | | | | | | | | | 8018: Make Ty wrap TyKind in an Arc r=flodiebold a=flodiebold ... to further move towards Chalk. This is a bit of a slowdown (218ginstr vs 213ginstr for inference on RA), even though it allows us to unwrap the Substs in `TyKind::Ref` etc.. Co-authored-by: Florian Diebold <[email protected]> | |||||
| * | Don't use Substs for Ref/Raw/Array/Slice | Florian Diebold | 2021-03-14 | 4 | -29/+34 | |
| | | ||||||
| * | Make Ty wrap TyKind in an Arc | Florian Diebold | 2021-03-14 | 4 | -10/+10 | |
| | | | | | | | | | | | | | | | | ... like it will be in Chalk. We still keep `interned_mut` and `into_inner` methods that will probably not exist with Chalk. This worsens performance slightly (5ginstr inference on RA), but doesn't include other simplifications we can do yet. | |||||
* | | Simplify source maps for fields | Aleksey Kladov | 2021-03-15 | 1 | -3/+2 | |
|/ | ||||||
* | Use chalk_ir::FnSig | Florian Diebold | 2021-03-14 | 1 | -1/+1 | |
| | ||||||
* | Rename some fields to their Chalk names | Florian Diebold | 2021-03-14 | 2 | -5/+5 | |
| | ||||||
* | Move type lowering methods to TyLoweringContext | Florian Diebold | 2021-03-13 | 1 | -5/+5 | |
| | ||||||
* | Use chalk_ir::OpaqueTyId | Florian Diebold | 2021-03-13 | 1 | -3/+4 | |
| | ||||||
* | Use chalk_ir::PlaceholderIndex | Florian Diebold | 2021-03-13 | 1 | -1/+1 | |
| | ||||||
* | Use chalk_ir::ClosureId | Florian Diebold | 2021-03-13 | 1 | -1/+2 | |
| | ||||||
* | Use chalk_ir::FnDefId | Florian Diebold | 2021-03-13 | 1 | -3/+4 | |
| | ||||||
* | Use chalk_ir::AssocTypeId | Florian Diebold | 2021-03-13 | 1 | -2/+5 | |
| | ||||||
* | Separate `Ty` and `TyKind` like in Chalk | Florian Diebold | 2021-03-13 | 5 | -186/+239 | |
| | | | | | Currently `Ty` just wraps `TyKind`, but this allows us to change most places to already use `intern` / `interned`. | |||||
* | Stop using `ContainerId` in `AssocContainerId` | Jonas Schievink | 2021-03-09 | 1 | -1/+1 | |
| | ||||||
* | Use upstream cov-mark | Laurențiu Nicola | 2021-03-08 | 4 | -12/+7 | |
| | ||||||
* | Use chalk_ir::AdtId | Lukas Wirth | 2021-03-04 | 2 | -13/+13 | |
| | ||||||
* | Use chalk_ir::Mutability | Lukas Wirth | 2021-03-01 | 3 | -21/+25 | |
| | ||||||
* | Introduce Ty::Alias | Lukas Wirth | 2021-03-01 | 3 | -9/+9 | |
| | ||||||
* | Assert index relationship between type_variable_table and var_unification_table | Lukas Wirth | 2021-03-01 | 1 | -20/+11 | |
| | ||||||
* | Being Ty::InferenceVar closes to chalk equivalent | Lukas Wirth | 2021-03-01 | 3 | -84/+130 | |
| | ||||||
* | Merge #7816 | bors[bot] | 2021-02-28 | 2 | -10/+9 | |
|\ | | | | | | | | | | | | | | | 7816: Lift Ty::Fn into a struct r=Veykril a=Veykril bors r+ Co-authored-by: Lukas Wirth <[email protected]> | |||||
| * | Lift FnPointer into a struct | Lukas Wirth | 2021-02-28 | 2 | -10/+9 | |
| | | ||||||
* | | hir_ty: use default type generic for box expressions | cynecx | 2021-02-28 | 1 | -0/+6 | |
|/ | ||||||
* | Turn Ty::Tuple variant into a tuple-variant | Lukas Wirth | 2021-02-28 | 2 | -5/+5 | |
| | ||||||
* | Inline TypeCtor into Ty | Lukas Wirth | 2021-02-28 | 4 | -225/+157 | |
| | ||||||
* | Use chalk_ir::Scalar directly | Lukas Wirth | 2021-02-28 | 1 | -6/+10 | |
| | ||||||
* | Introduce TypeCtor::Scalar | Lukas Wirth | 2021-02-28 | 2 | -23/+66 | |
| | ||||||
* | Put the old resolver back | Jonas Schievink | 2021-02-10 | 1 | -3/+8 | |
| | ||||||
* | infer: update resolver when descending into block | Jonas Schievink | 2021-02-10 | 1 | -16/+20 | |
| | ||||||
* | Use block_def_map in body lowering | Jonas Schievink | 2021-02-03 | 1 | -1/+1 | |
| | ||||||
* | Revert "Use block_def_map in body lowering" | Jonas Schievink | 2021-02-02 | 1 | -1/+1 | |
| | ||||||
* | Use block_def_map in body lowering | Jonas Schievink | 2021-02-01 | 1 | -1/+1 | |
| |