Commit message (Collapse) | Author | Age | Files | Lines | ||
---|---|---|---|---|---|---|
... | ||||||
* | Remove some unused methods, move some to types.rs | Florian Diebold | 2021-04-05 | 2 | -29/+15 | |
| | ||||||
* | Binders::wrap_empty -> wrap_empty_binders | Florian Diebold | 2021-04-05 | 3 | -16/+12 | |
| | ||||||
* | Substitution::single -> from1 | Florian Diebold | 2021-04-05 | 4 | -14/+17 | |
| | ||||||
* | Move ProjectionTy methods to extension trait | Florian Diebold | 2021-04-05 | 7 | -32/+43 | |
| | ||||||
* | Merge #8353 | bors[bot] | 2021-04-05 | 4 | -18/+50 | |
|\ | | | | | | | | | | | | | | | 8353: Replace hir_ty::Lifetime with chalk equivalent r=flodiebold a=Veykril Our `Lifetime` isn't really used yet so this is a rather simple change Co-authored-by: Lukas Wirth <[email protected]> | |||||
| * | Replace unused hir_ty::Lifetime with chalk equivalents | Lukas Wirth | 2021-04-05 | 4 | -18/+50 | |
| | | ||||||
* | | Use more assoc. type aliases in the chalk interner | Jonas Schievink | 2021-04-05 | 1 | -22/+21 | |
|/ | | | | Makes it sligthly easier to swap out these types | |||||
* | Rename shift_bound_vars{_out} to align with Chalk | Florian Diebold | 2021-04-05 | 5 | -25/+32 | |
| | ||||||
* | Get rid of subst_bound_vars uses | Florian Diebold | 2021-04-05 | 3 | -5/+9 | |
| | ||||||
* | Get rid of some walk_mut uses | Florian Diebold | 2021-04-05 | 2 | -10/+15 | |
| | ||||||
* | Add Interner parameter to Binders::substitute | Florian Diebold | 2021-04-05 | 11 | -37/+44 | |
| | ||||||
* | Binders::subst -> substitute | Florian Diebold | 2021-04-05 | 11 | -34/+34 | |
| | ||||||
* | Use VariableKinds in Binders | Florian Diebold | 2021-04-05 | 7 | -84/+107 | |
| | ||||||
* | Hide Binders internals more | Florian Diebold | 2021-04-05 | 9 | -84/+104 | |
| | ||||||
* | Use arrayvec 0.7 to avoid perf regression in 0.6.1 | kjeremy | 2021-04-05 | 1 | -1/+1 | |
| | | | | See: https://github.com/bluss/arrayvec/issues/182 | |||||
* | Pass interner to TraitRef::self_type_parameter | Laurențiu Nicola | 2021-04-05 | 4 | -20/+24 | |
| | ||||||
* | Pass interner to ProjectionTy::self_type_parameter | Laurențiu Nicola | 2021-04-05 | 4 | -7/+7 | |
| | ||||||
* | Rename TyKind::ForeignType to Foreign | Laurențiu Nicola | 2021-04-05 | 6 | -9/+9 | |
| | ||||||
* | Rename TyKind::Unknown to Error | Laurențiu Nicola | 2021-04-05 | 13 | -47/+47 | |
| | ||||||
* | Intern `GenericParams` | Jonas Schievink | 2021-04-05 | 1 | -1/+2 | |
| | | | | | Also share the same instance between `ItemTree` and `generic_params` query. | |||||
* | Intern more `TypeRef`s in generics | Jonas Schievink | 2021-04-05 | 1 | -5/+4 | |
| | | | | Saves ~3 MB | |||||
* | Move things from `traits` module to `types` as well | Florian Diebold | 2021-04-04 | 11 | -107/+103 | |
| | ||||||
* | Move things in hir_ty into submodules | Florian Diebold | 2021-04-04 | 10 | -706/+750 | |
| | | | | | - all the types that will be replaced by Chalk go to `types` - `TypeWalk` impls go to `walk` | |||||
* | Add comment | Florian Diebold | 2021-04-04 | 1 | -0/+3 | |
| | ||||||
* | Replace Substitution::type_params | Florian Diebold | 2021-04-04 | 4 | -12/+11 | |
| | ||||||
* | Replace Substitution::bound_vars and ::type_params_for_generics | Florian Diebold | 2021-04-04 | 7 | -54/+42 | |
| | ||||||
* | Move TyBuilder to its own module | Florian Diebold | 2021-04-04 | 2 | -204/+221 | |
| | ||||||
* | Replace last uses of SubstsBuilder by TyBuilder | Florian Diebold | 2021-04-04 | 4 | -64/+23 | |
| | ||||||
* | Remove CallableSig::from_substs | Florian Diebold | 2021-04-04 | 1 | -11/+1 | |
| | ||||||
* | Use TyBuilder in another place | Florian Diebold | 2021-04-04 | 1 | -4/+3 | |
| | ||||||
* | Some more TyBuilder use | Florian Diebold | 2021-04-04 | 2 | -33/+25 | |
| | ||||||
* | Replace remaining uses of Substitution::build_for_def | Florian Diebold | 2021-04-04 | 5 | -18/+44 | |
| | ||||||
* | More TyBuilder use | Florian Diebold | 2021-04-04 | 1 | -12/+9 | |
| | ||||||
* | More TyBuilder use | Florian Diebold | 2021-04-04 | 1 | -23/+15 | |
| | ||||||
* | Add and start using TraitRef and ProjectionTy builders | Florian Diebold | 2021-04-04 | 4 | -22/+39 | |
| | ||||||
* | Move Ty::builtin to TyBuilder | Florian Diebold | 2021-04-04 | 2 | -18/+18 | |
| | ||||||
* | Add TyBuilder::adt | Florian Diebold | 2021-04-04 | 4 | -45/+104 | |
| | ||||||
* | Move Ty::fn_ptr to TyBuilder | Florian Diebold | 2021-04-04 | 2 | -11/+12 | |
| | ||||||
* | Add TyBuilder::unit() and TyExt::is_unit() | Florian Diebold | 2021-04-04 | 7 | -25/+39 | |
| | ||||||
* | Add TyBuilder | Florian Diebold | 2021-04-04 | 1 | -0/+6 | |
| | ||||||
* | Access a body's block def maps via a method | Jonas Schievink | 2021-04-04 | 2 | -3/+2 | |
| | ||||||
* | Use bitflags to compress function properties | Jonas Schievink | 2021-04-03 | 4 | -6/+6 | |
| | | | | Very minor savings, only 1 MB or so | |||||
* | Rename Ty::interned to Ty::kind | Florian Diebold | 2021-04-03 | 16 | -62/+60 | |
| | | | | ... since that's the actual method on Chalk side that matches the signature. | |||||
* | Introduce `GenericArg` like in Chalk | Florian Diebold | 2021-04-03 | 16 | -152/+301 | |
| | | | | | | | Plus some more adaptations to Substitution. Lots of `assert_ty_ref` that we should revisit when introducing lifetime/const parameters. | |||||
* | Merge #8284 | bors[bot] | 2021-04-02 | 1 | -1/+1 | |
|\ | | | | | | | | | | | | | | | 8284: Reduce memory usage by using global `Arc`-based interning r=jonas-schievink a=jonas-schievink This saves around 50 mb when running `analysis-stats` on r-a itself. Not a lot, but this infra can be easily reused to intern more stuff. Co-authored-by: Jonas Schievink <[email protected]> | |||||
| * | Global TypeRef/TraitRef interning | Jonas Schievink | 2021-04-01 | 1 | -1/+1 | |
| | | ||||||
* | | Merge #8287 | bors[bot] | 2021-04-02 | 1 | -36/+33 | |
|\ \ | | | | | | | | | | | | | | | | | | | | | | 8287: Don't allocate in `associated_type_shorthand_candidates` r=Veykril a=Veykril Co-authored-by: Lukas Wirth <[email protected]> | |||||
| * | | Don't allocate in `associated_type_shorthand_candidates` | Lukas Wirth | 2021-04-02 | 1 | -36/+33 | |
| | | | ||||||
* | | | minor: add profile call for resolve_obligations | Aleksey Kladov | 2021-04-02 | 1 | -0/+2 | |
| | | | ||||||
* | | | Merge #8285 | bors[bot] | 2021-04-02 | 4 | -8/+26 | |
|\ \ \ | |/ / |/| | | | | | | | | | | | | | | | | | | | | | | | 8285: Don't recheck obligations if we have learned nothing new r=matklad a=flodiebold This is just the most trivial check: If no inference variables have been updated, and there are no new obligations, we can just skip trying to solve them again. We could be smarter about it, but this already helps quite a bit, and I don't want to touch this too much before we replace the inference table by Chalk's. Fixes #8263 (well, improves it quite a bit). Co-authored-by: Florian Diebold <[email protected]> |