rust-analyzer/crates/hir_expand/src
bors[bot] 1a29934c37
Merge #7145
7145: Proper handling $crate Take 2 [DO NOT MERGE] r=edwin0cheng a=edwin0cheng

Similar to previous PR (#7133) , but improved the following things :

1. Instead of storing the whole `ExpansionInfo`, we store a similar but stripped version `HygieneInfo`.
2. Instread of storing the `SyntaxNode` (because every token we are interested are IDENT), we store the `TextRange` only.
3. Because of 2, we now can put it in Salsa.
4. And most important improvement: Instead of computing the whole frames every single time, we compute it recursively through salsa: (Such that in the best scenario, we only need to compute the first layer of frame)

```rust
        let def_site = db.hygiene_frame(info.def.file_id);
        let call_site = db.hygiene_frame(info.arg.file_id);

        HygieneFrame { expansion: Some(info), local_inner, krate, call_site, def_site }
```

The overall speed compared to previous PR is much faster (65s vs 45s) :
```
[WITH old PR]
Database loaded 644.86ms, 284mi
Crates in this dir: 36
Total modules found: 576
Total declarations: 11153
Total functions: 8715
Item Collection: 15.78s, 91562mi
Total expressions: 240721
Expressions of unknown type: 2635 (1%)
Expressions of partially unknown type: 2064 (0%)
Type mismatches: 865
Inference: 49.84s, 250747mi
Total: 65.62s, 342310mi
rust-analyzer -q analysis-stats .  66.72s user 0.57s system 99% cpu 1:07.40 total

[WITH this PR]
Database loaded 665.83ms, 284mi
Crates in this dir: 36
Total modules found: 577
Total declarations: 11188
Total functions: 8743
Item Collection: 15.28s, 84919mi
Total expressions: 241229
Expressions of unknown type: 2637 (1%)
Expressions of partially unknown type: 2064 (0%)
Type mismatches: 868
Inference: 30.15s, 135293mi
Total: 45.43s, 220213mi   
rust-analyzer -q analysis-stats .  46.26s user 0.74s system 99% cpu 47.294 total
```

*HOWEVER*,  it is still a perf regression (35s vs 45s):
```
[WITHOUT this PR]
Database loaded 657.42ms, 284mi
Crates in this dir: 36
Total modules found: 577
Total declarations: 11177
Total functions: 8735
Item Collection: 12.87s, 72407mi
Total expressions: 239380
Expressions of unknown type: 2643 (1%)
Expressions of partially unknown type: 2064 (0%)
Type mismatches: 868
Inference: 22.88s, 97889mi
Total: 35.74s, 170297mi
rust-analyzer -q analysis-stats .  36.71s user 0.63s system 99% cpu 37.498 total
```



Co-authored-by: Edwin Cheng <edwin0cheng@gmail.com>
2021-01-08 03:57:11 +00:00
..
ast_id_map.rs Rename ra_hir_expand -> hir_expand 2020-08-13 16:29:33 +02:00
builtin_derive.rs Change <|> to $0 - Rebase 2021-01-07 12:09:23 +00:00
builtin_macro.rs Fix == in in format causes mismatched-arg-count 2020-12-31 17:59:29 +08:00
db.rs Proper handling $crate Take 2 2021-01-07 13:08:32 +08:00
diagnostics.rs Explain how we get precise spans for diagnostics. 2020-11-28 18:14:08 +03:00
eager.rs Fixed nested eager macro bug 2021-01-03 17:56:59 +08:00
hygiene.rs Proper handling $crate Take 2 2021-01-07 13:08:32 +08:00
lib.rs Revert "Proper handling $crate and local_inner_macros" 2021-01-03 11:47:57 +01:00
name.rs Add fix to wrap return expression in Some 2021-01-07 19:01:33 +00:00
proc_macro.rs Refactor TokenBuffer for reduc cloning 2021-01-05 02:00:46 +08:00
quote.rs Rename ra_hir_expand -> hir_expand 2020-08-13 16:29:33 +02:00
test_db.rs Introduce anchored_path 2020-12-09 19:07:05 +03:00