mirror of
https://github.com/rust-lang/rust.git
synced 2025-02-23 12:23:22 +00:00
![]() Postfix adjustment hints # Basic Description This PR implements "postfix" adjustment hints: data:image/s3,"s3://crabby-images/a0e6e/a0e6ef546cde556e8d21af2b54544b02bbb3a64b" alt="2022-12-21_19-27" They are identical to normal adjustment hints, but are rendered _after_ the expression. E.g. `expr.*` instead of `*expr`. ~~This mirrors "postfix deref" feature that I'm planning to eventually propose to the compiler.~~ # Motivation The advantage of being postfix is that you need to add parentheses less often: data:image/s3,"s3://crabby-images/822a9/822a9cd141bb4d6ffe10f5a078ef76a2de5b1237" alt="2022-12-21_19-38" data:image/s3,"s3://crabby-images/ee231/ee2312f08b71c4a800f40905ea93388757240120" alt="2022-12-21_19-37" This is because a lot of "reborrow" hints are caused by field access or method calls, both of which are postfix and have higher "precedence" than prefix `&` and `*`. Also IMHO it just looks nicer and it's more clear what is happening (order of operations). # Modes However, there are some cases where postfix hints need parentheses but prefix don't (for example `&x` being turned into `(&x).*.*.&` or `&**&x`). This PR allows users to choose which look they like more. There are 4 options (`rust-analyzer.inlayHints.expressionAdjustmentHints.mode` setting): - `prefix` — always use prefix hints (default, what was used before that PR) - `postfix` — always use postfix hints - `prefer_prefix` — try to minimize number of parentheses, breaking ties in favor of prefix - `prefer_postfix` — try to minimize number of parentheses, breaking ties in favor of postfix Comparison of all modes: data:image/s3,"s3://crabby-images/0e87f/0e87fc8bac8b9e00803348da6aaa1af45d4bbd72" alt="2022-12-21_19-53" data:image/s3,"s3://crabby-images/63424/6342480710e3ad0390da6a59c13e1025a7c04786" alt="2022-12-21_19-49" data:image/s3,"s3://crabby-images/1091b/1091b9ba886c7440076402d3f63ca5b19fc88256" alt="2022-12-21_19-48" data:image/s3,"s3://crabby-images/8f4e7/8f4e7e8c48c2622217b17a4ffc7350bdd1896db8" alt="2022-12-21_19-47" # Edge cases Where are some rare cases where chain hints weirdly interact with adjustment hints, for example (note `SourceAnalyzer.&`): data:image/s3,"s3://crabby-images/e8ae0/e8ae09909d62f314359bde16579eefa0bf8ed149" alt="image" This is pre-existing, you can get the same effect with prefix hints (`SourceAnalyzer)`). ---- Another weird thing is this: data:image/s3,"s3://crabby-images/0301f/0301f0fecb7ef8ed4888ad13ce8c8389a929cb6f" alt="2022-12-21_20-00" Here `.&` is a hint and `?` is written in the source code. It looks like `?` is part of the hint because `?.` is ligature in my font. IMO this is a bug in vscode, but still worth mentioning (I'm also too lazy to report it there...). # Fixed bugs I've used the "needs parens" API and this accidentally fixed a bug with parens around `as`, see the test diff: ```diff,rust let _: *const u32 = &mut 0u32 as *mut u32; //^^^^^^^^^^^^^^^^^^^^^<mut-ptr-to-const-ptr> + //^^^^^^^^^^^^^^^^^^^^^( + //^^^^^^^^^^^^^^^^^^^^^) ... let _: *const u32 = &mut 0u32 as *mut u32; //^^^^^^^^^^^^^^^^^^^^^<mut-ptr-to-const-ptr> + //^^^^^^^^^^^^^^^^^^^^^( + //^^^^^^^^^^^^^^^^^^^^^) ``` # Changelog changelog feature Add an option to make adjustment hints (aka reborrow hints) postfix changelog fix Fix placement of parentheses around `as` casts for adjustment hints |
||
---|---|---|
.. | ||
base-db | ||
cfg | ||
flycheck | ||
hir | ||
hir-def | ||
hir-expand | ||
hir-ty | ||
ide | ||
ide-assists | ||
ide-completion | ||
ide-db | ||
ide-diagnostics | ||
ide-ssr | ||
limit | ||
mbe | ||
parser | ||
paths | ||
proc-macro-api | ||
proc-macro-srv | ||
proc-macro-srv-cli | ||
proc-macro-test | ||
profile | ||
project-model | ||
rust-analyzer | ||
sourcegen | ||
stdx | ||
syntax | ||
test-utils | ||
text-edit | ||
toolchain | ||
tt | ||
vfs | ||
vfs-notify |