aboutsummaryrefslogtreecommitdiff
path: root/crates
Commit message (Collapse)AuthorAgeFilesLines
...
| * | | use `&T` for non copy params of extracted functionVladyslav Katasonov2021-02-041-2/+55
| | | | | | | | | | | | | | | | Use shared ref if param is not `T: Copy` and is used after body
| * | | split extract_function into pieces and order themVladyslav Katasonov2021-02-041-380/+510
| | | |
| * | | remove ignored test for downgrading mut to sharedVladyslav Katasonov2021-02-031-30/+0
| | | |
| * | | allow calling `&mut` methods on outer vars when extracing functionVladyslav Katasonov2021-02-031-0/+116
| | | |
| * | | allow `&mut param` when extracting functionVladyslav Katasonov2021-02-031-3/+107
| | | | | | | | | | | | | | | | | | | | | | | | Recognise &mut as variable modification. This allows extracting functions with `&mut var` with `var` being in outer scope
| * | | allow modifications of vars from outer scope inside extracted functionVladyslav Katasonov2021-02-032-46/+337
| | | | | | | | | | | | | | | | | | | | It currently allows only directly setting variable. No `&mut` references or methods.
| * | | allow local variables to be used after extracted bodyVladyslav Katasonov2021-02-031-41/+183
| | | | | | | | | | | | | | | | | | | | when variable is defined inside extracted body export this variable to original scope via return value(s)
| * | | change TODO to FIXMEVladyslav Katasonov2021-02-031-2/+2
| | | |
| * | | disable test for downgrading mutability on extractVladyslav Katasonov2021-02-031-0/+3
| | | |
| * | | convert IdentPat to Pat via IntoVladyslav Katasonov2021-02-031-5/+5
| | | | | | | | | | | | | | | | before child getter was used
| * | | support extracting methods; no mut loweringVladyslav Katasonov2021-02-031-37/+191
| | | | | | | | | | | | | | | | | | | | currently mut refernce will *not* be downgraded to shared if it is sufficient(see relevant test for example)
| * | | initial version of extract function assistVladyslav Katasonov2021-02-033-0/+848
| |/ / | | | | | | | | | | | | | | | | | | | | | there are a few currently limitations: * no modifications of function body * does not handle mutability and references * no method support * may produce incorrect results
* | | Avoid using ModPath's fields directlyJonas Schievink2021-02-043-8/+9
| | |
* | | Make `ModPath`'s representation privateJonas Schievink2021-02-0418-51/+70
| | |
* | | Intern `TypeRef`s in the containing `ItemTree`Jonas Schievink2021-02-044-21/+67
| | |
* | | Expander: store a LocalModuleId, not ModuleIdJonas Schievink2021-02-042-14/+11
| | | | | | | | | | | | | | | It already stores the DefMap containing the module, so having a full ModuleId is unnecessary and makes it easier to mix things up
* | | Don't keep the parent DefMap alive via ArcJonas Schievink2021-02-045-36/+67
| | | | | | | | | | | | | | | This seems like it could easily leak a lot of memory since we don't currently run GC
* | | Split out ItemScope::dump from DefMap::dumpJonas Schievink2021-02-032-21/+26
| | |
* | | Merge #7546bors[bot]2021-02-032-0/+11
|\ \ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | 7546: Add newline between block and crate maps r=jonas-schievink a=jonas-schievink bors r+ Co-authored-by: Jonas Schievink <[email protected]>
| * | | Add newline between block and crate mapsJonas Schievink2021-02-032-0/+11
| | | |
* | | | Add a FIXME to ItemTreeJonas Schievink2021-02-031-0/+1
|/ / /
* | | Update `DefMap` and `block_def_map` docsJonas Schievink2021-02-032-1/+25
| | |
* | | Merge #7541bors[bot]2021-02-0312-100/+211
|\ \ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 7541: Use block_def_map in body lowering (third time's the charm) r=jonas-schievink a=jonas-schievink After https://github.com/rust-analyzer/rust-analyzer/pull/7380 and https://github.com/rust-analyzer/rust-analyzer/pull/7506 both had to be reverted, this should have finally resolved all remaining bugs. Most importantly, the optimization to skip `block_def_map` computation when the block contains no inner items was fixed (which fortunately was simpler than expected). I've ran `analysis-stats` on libstd locally, which works fine, and also ran this PR locally for a short while without issues. Note that this *still* has no (or almost no) user-facing impact, because the rest of r-a still relies on some local item support hacks. bors r+ Co-authored-by: Jonas Schievink <[email protected]>
| * | | Test for name resolution with DefMap shortcutJonas Schievink2021-02-031-0/+33
| | | |
| * | | Shortcut `block_def_map` if there's no inner itemsJonas Schievink2021-02-035-11/+26
| | | | | | | | | | | | | | | | | | | | This previously didn't work, but apparently only because of the wonky test setup
| * | | Use body lowering for block_def_map testsJonas Schievink2021-02-033-68/+117
| | | | | | | | | | | | | | | | Removes the hacky and buggy custom lowering code
| * | | Use block_def_map in body loweringJonas Schievink2021-02-036-26/+40
| | | |
* | | | Add cargo file tidy testEdwin Cheng2021-02-031-2/+2
|/ / /
* / / Make sure normal dependencies always have versionPavan Kumar Sunkara2021-02-031-1/+1
|/ /
* | Fix resolution of `crate` paths from within blocksJonas Schievink2021-02-022-2/+7
| | | | | | | | | | They resolve to the crate root, not the DefMap's root module (which can be a block)
* | Bump rustc_lexerLaurențiu Nicola2021-02-021-1/+1
| |
* | Bump chalkLaurențiu Nicola2021-02-022-5/+5
| |
* | Use non-deprecated memmap2 cratekjeremy2021-02-022-2/+2
| | | | | | | | | | | | | | `cargo audit` complains that `memmap` is unmaintained so switch to RazrFalcon's maintained version. Removes yet another edge on winapi
* | Show alias underlying typelumenian2021-02-021-1/+5
| |
* | Use the right `DefMap` when looking up modulesJonas Schievink2021-02-023-2/+20
| |
* | Revert "Use block_def_map in body lowering"Jonas Schievink2021-02-0210-161/+96
| |
* | Only allow one proc-macro processEdwin Cheng2021-02-011-14/+16
| |
* | Reap proc macro server instancesLaurențiu Nicola2021-02-012-8/+4
| |
* | Update Test DataChristopher Serr2021-02-011-1/+46
| |
* | Don't filter code suggestions on ApplicabilityChristopher Serr2021-02-011-4/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | I've noticed that there are various suggestions that rust-analyzer seems to filter out, even if they make sense. Here's an example of where it seems like there should be a suggestion, but there isn't: ![https://i.imgur.com/wsjM6iz.png](https://i.imgur.com/wsjM6iz.png) It turns out that this specific suggestion is not considered `MachineApplicable`, which are the only suggestions that rust-analyzer accepts. However if you read the documentation for `MachineApplicable`, https://github.com/rust-lang/rust/blob/b3897e3d1302391ed02efbac1dce8073646b8173/compiler/rustc_lint_defs/src/lib.rs#L27-L29 then you realize that these are specifically only those suggestions that rust-analyzer could even automatically apply (in some distant future, behind some setting or so). Other suggestions that may have some semantic impact do not use `MachineApplicable`. So all other suggestions are still intended to be suggested to the user, just not automatically applied without the user being consulted. https://github.com/rust-lang/rust/blob/b3897e3d1302391ed02efbac1dce8073646b8173/compiler/rustc_lint_defs/src/lib.rs#L22-L24 So with that in mind, rust-analyzer should almost definitely not filter out `MaybeIncorrect` (which honestly is named horribly, it just means that it's a semantic change, not just a syntactical one). Then there's `HasPlaceholders` which basically is just another semantic one, but with placeholders. The user will have to make some adjustments, but the suggestion still is perfectly valid. rust-analyzer could probably detect those placeholders and put proper "tab through" markers there for the IDE, but that's not necessary for now. Then the last one is `Unspecified` which is so unknown that I don't even know how to judge it, meaning that the suggestion should probably also just be suggested to the user and then they can decide. So with all that in mind, I'm proposing to get rid of the check for Applicability entirely.
* | Shortcut `block_def_map` if there's no inner itemsJonas Schievink2021-02-011-2/+4
| | | | | | | | | | This previously didn't work, but apparently only because of the wonky test setup
* | Use body lowering for block_def_map testsJonas Schievink2021-02-013-68/+117
| | | | | | | | Removes the hacky and buggy custom lowering code
* | Use block_def_map in body loweringJonas Schievink2021-02-016-26/+40
| |
* | Merge #7503bors[bot]2021-01-312-1/+25
|\ \ | | | | | | | | | | | | | | | | | | | | | 7503: Return inner attributes of outline mod declarations in `attrs_query` r=jonas-schievink a=Veykril Co-authored-by: Lukas Wirth <[email protected]>
| * | Return inner attributes of outline mod declarations in `attrs_query`Lukas Wirth2021-01-312-1/+25
| | |
* | | Honor #![macro_use] in mod source filesLukas Wirth2021-01-312-8/+23
|/ /
* | Merge #7500bors[bot]2021-01-301-2/+19
|\ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | 7500: Fix ast::String::value not properly escaping in some cases r=Veykril a=Veykril Fixes #7496 bors r+ Co-authored-by: Lukas Wirth <[email protected]>
| * | Fix ast::String::value not properly escaping in some casesLukas Wirth2021-01-301-2/+19
| | |
* | | Merge #7483bors[bot]2021-01-305-27/+59
|\ \ \ | |/ / |/| | | | | | | | | | | | | | | | | 7483: Classify function calls as functions when shadowed by types r=matklad a=Veykril Fixes #7479 Co-authored-by: Lukas Wirth <[email protected]>
| * | Prefer ValueNS when resolving hir path for PathExpressionsLukas Wirth2021-01-291-14/+31
| | |