about summary refs log tree commit diff
path: root/crates/syntax
AgeCommit message (Collapse)AuthorLines
2021-02-24Add tests for apply_demorganLukas Wirth-2/+5
2021-02-21Bump depsLaurențiu Nicola-1/+1
2021-02-20Fix incorrect missing field diagnostic with box patternsLaurențiu Nicola-4/+13
2021-02-17Revert "Replace usage of ast::NameOrNameRef with ast::NameLike"Lukas Wirth-18/+23
This reverts commit e1dbf43cf85f84c3a7e40f9731fc1f7ac96f8979.
2021-02-17Replace usage of ast::NameOrNameRef with ast::NameLikeLukas Wirth-23/+18
2021-02-16Implement ast::AstNode for NameLike and move it to node_extLukas Wirth-1/+47
2021-02-16Merge #7687bors[bot]-0/+88
7687: Specialization for async traits r=matklad a=arnaudgolfouse Fixes #7669. Adapting the parser seemed to be all that was needed, but I am not very experienced with the codebase. Is this enough ? Co-authored-by: Arnaud <arnaud.golfouse@laposte.net>
2021-02-16Merge #7620bors[bot]-9/+50
7620: Support control flow in `extract_function` assist r=matklad a=cpud36 Support `return`ing from outer function, `break`ing and `continue`ing outer loops when extracting function. # Example Transforms ```rust fn foo() -> i32 { let items = [1,2,3]; let mut sum = 0; for &item in items { <|>if item == 42 { break; }<|> sum += item; } sum } ``` Into ```rust fn foo() -> i32 { let items = [1,2,3]; let mut sum = 0; for &item in items { if fun_name(item) { break; } sum += item; } sum } fn fun_name(item: i32) -> bool { if item == 42 { return true; } false } ``` ![add_explicit_type_infer_type](https://user-images.githubusercontent.com/4218373/107544222-0fadf280-6bdb-11eb-9625-ed6194ba92c0.gif) # Features Supported variants - break and function does not return => uses `bool` and plain if - break and function does return => uses `Option<T>` and matches on it - break with value and function does not return => uses `Option<T>` and if let - break with value and function does return => uses `Result<T, U>` and matches on t - same for `return` and `continue`(but we can't continue with value) Assist does handle nested loops and nested items(like functions, modules, impls) Try `expr?` operator is allowed together with `return Err(_)` and `return None`. `return expr` is not allowed. # Not supported ## Mixing `return` with `break` or `continue` If we have e.g. a `return` and a `break` in the selected code, it is unclear what the produced code should look like. We can try `Result<T, Option<U>>` or something like that, but it isn't idiomatic, nor it is established. Otherwise, implementation is relatively simple. ## `break` with label Not sure how to handle different labels for multiple `break`s. [edit] implemented try `expr?` Co-authored-by: Vladyslav Katasonov <cpud47@gmail.com>
2021-02-15Specialization for async traitsArnaud-0/+88
2021-02-13Don't rename field record patterns directlyLukas Wirth-3/+2
2021-02-13allow try expr? when extacting functionVladyslav Katasonov-0/+3
2021-02-13handle return, break and continue when extracting functionVladyslav Katasonov-9/+47
2021-02-12Refactor reference searching to work with the astLukas Wirth-4/+26
2021-02-09Add parsing benchmarkAleksey Kladov-3/+25
2021-02-09Infra for "unit" benchmarkingAleksey Kladov-3980/+0
2021-02-08Update crateskjeremy-1/+1
Pulls in https://github.com/rust-lang/chalk/pull/682
2021-02-07AdtDef -> AdtAleksey Kladov-19/+19
2021-02-05Merge #7535bors[bot]-1/+1
7535: Extract function assist r=cpud36 a=cpud36 This PR adds `extract function/method` assist. closes #5409. # Supported features Assist should support extracting from expressions(`1`, `2 + 2`, `loop { }`) and from a series of statements, e.g.: ```rust foo(); $0bar(); baz();$0 quix(); ``` Assist also supports extracting parameters, like: ```rust fn foo() -> i32 { let n = 1; $0n + 1$0 } // - fn foo() -> i32 { let n = 1; fun_name(n) } fn fun_name(n: i32) -> i32 { n + 1 } ``` Extracting methods also generally works. Assist allows referencing outer variables, both mutably and immutably, and handles handles access to variables local to extracted function: ```rust fn foo() { let mut n = 1; let mut m = 2; let mut moved_v = Vec::new(); let mut ref_mut_v = Vec::new(); $0 n += 1; let k = 1; moved_v.push(n); let r = &mut m; ref_mut_v.push(*r); let h = 3; $0 n = ref_mut_v.len() + k; n -= h + m; } // - fn foo() { let mut n = 1; let mut m = 2; let mut moved_v = Vec::new(); let mut ref_mut_v = Vec::new(); let (k, h) = fun_name(&mut n, moved_v, &mut m, &mut ref_mut_v); n = ref_mut_v.len() + k; n -= h + m; } fn fun_name(n: &mut i32, mut moved_v: Vec<i32>, m: &mut i32, ref_mut_v: &mut Vec<i32>) -> (i32, i32) { *n += 1; let k = 1; moved_v.push(*n); let r = m; ref_mut_v.push(*r); let h = 3; (k, h) } ``` So we handle both input and output paramters # Showcase ![extract_cursor_in_range_3](https://user-images.githubusercontent.com/4218373/106980190-c9870800-6770-11eb-83d9-3d36b2550ff6.gif) ![fill_match_arms_discard_wildcard](https://user-images.githubusercontent.com/4218373/106980197-cbe96200-6770-11eb-96b0-14c27894fac0.gif) ![ide_db_helpers_handle_kind](https://user-images.githubusercontent.com/4218373/106980201-cdb32580-6770-11eb-9e6e-6ac8155d65ac.gif) ![ide_db_imports_location_local_query](https://user-images.githubusercontent.com/4218373/106980205-cf7ce900-6770-11eb-8516-653c8fcca807.gif) # Working with non-`Copy` types Consider the following example: ```rust fn foo() { let v = Vec::new(); $0 let n = v.len(); $0 let is_empty = v.is_empty(); } ``` `v` must be a parameter to extracted function. The question is, what type should it have. It could be `v: Vec<i32>`, or `v: &Vec<i32>`. The former is incorrect for `Vec<i32>`, but the later is silly for `i32`. To resolve this we need to know if the type implements `Copy` trait. I didn't find any api available from assists to query this. `hir_ty::method_resolution::implements` seems relevant, but is isn't publicly re-exported from `hir`. # Star(`*`) token and pointer dereference If I understand correctly, in order to create expression like `*p`, one should use `ast::make::expr_prefix(T![*], ...)`, which in turn calls `token(T![*])`. `token` does not have star in `tokens::SOURCE_FILE`, so this panics. I had to add `*` to `SOURCE_FILE` to make it work. Correct me if this is not intended way to do this. # Lowering access `value -> mut ref -> shared ref` Consider the following example: ```rust fn foo() { let v = Vec::new(); $0 let n = v.len(); $0 } ``` `v` is not used after extracted function body, so both `v: &Vec<i32>` and `v: Vec<i32>` would work. Currently the later would be chosen. We can however check the body of extracted function and conclude that `v: &Vec<i32>` is sufficient. Using `v: &Vec<i32>`(that is a minimal required access level) might be a better default. I am unsure. # Cleanup The assist seems to be reasonably handling most of common cases. If there are no concerns with code it produces(i.e. with test cases), I will start cleaning up [edit] added showcase Co-authored-by: Vladyslav Katasonov <cpud47@gmail.com>
2021-02-03allow modifications of vars from outer scope inside extracted functionVladyslav Katasonov-1/+1
It currently allows only directly setting variable. No `&mut` references or methods.
2021-02-03Add cargo file tidy testEdwin Cheng-2/+2
2021-02-02Bump rustc_lexerLaurențiu Nicola-1/+1
2021-01-30Fix ast::String::value not properly escaping in some casesLukas Wirth-2/+19
2021-01-27Bump depsLaurențiu Nicola-1/+1
2021-01-25:arrow_up: rowanAleksey Kladov-1/+1
2021-01-24Add validation for mutable const itemsLukas Wirth-24/+39
2021-01-21Up lexerkjeremy-1/+1
2021-01-20:arrow_up: rowanAleksey Kladov-12/+8
It now stores text inline with tokens
2021-01-20.Aleksey Kladov-18/+18
2021-01-19:arrow_up: rowanAleksey Kladov-5/+6
2021-01-18Parse `impl const Trait`Lukas Wirth-0/+25
2021-01-18Add `MacroType` syntaxJonas Schievink-2/+31
2021-01-18Merge #7291bors[bot]-67/+147
7291: Wrap remaining self/super/crate in Name{Ref} r=matklad a=Veykril That should be the remaining special casing for `self` 🎉 Co-authored-by: Lukas Wirth <lukastw97@gmail.com>
2021-01-16When building an item-tree, keep fewer nodes in memoryAleksey Kladov-1/+1
2021-01-15Wrap remaining self/super/crate in Name{Ref}Lukas Wirth-67/+147
2021-01-15Add Unmerge Use assistunexge-2/+6
2021-01-15Merge #7288bors[bot]-41/+87
7288: Handle self/super/crate in PathSegment as NameRef r=matklad a=Veykril Wrapping self/super/crate in NameRef as per https://github.com/rust-analyzer/rust-analyzer/pull/7261#issuecomment-760023172 Co-authored-by: Lukas Wirth <lukastw97@gmail.com>
2021-01-15Handle self/super/crate in PathSegment as NameRefLukas Wirth-41/+87
2021-01-15Merge #7287bors[bot]-1/+1
7287: Make SyntaxPtr lookup logarithmic r=matklad a=matklad bors r+ 🤖 Co-authored-by: Aleksey Kladov <aleksey.kladov@gmail.com>
2021-01-15Make SyntaxPtr lookup logarithmicAleksey Kladov-1/+1
closes #3934 cc https://github.com/rust-analyzer/rowan/pull/81
2021-01-15Merge #7286bors[bot]-8/+3
7286: Remove useless wrapper r=matklad a=matklad bors r+ 🤖 Co-authored-by: Aleksey Kladov <aleksey.kladov@gmail.com>
2021-01-15Remove useless wrapperAleksey Kladov-8/+3
2021-01-15Add test for yield_exprDaiki Ihara-0/+32
2021-01-15Add support for yiled keywordDaiki Ihara-1/+33
2021-01-14Introduce more appropriate assertion mechanismAleksey Kladov-1/+1
rust-analyzer is a long-running program, so we *should* handle assertion failures. See also https://www.sqlite.org/assert.html.
2021-01-10Merge #7218bors[bot]-58/+58
7218: Fix typos r=Veykril a=regexident Apart from the very last commit on this PR (which fixes a public type's name) all changes are non-breaking. Co-authored-by: Vincent Esche <regexident@gmail.com>
2021-01-10Updated tests via `cargo xtask codegen`Vincent Esche-50/+50
2021-01-10Merge #7239bors[bot]-1/+1
7239: Replace SyntaxKind usage with T! macro where applicable r=lnicola a=Veykril https://github.com/rust-analyzer/rust-analyzer/blob/master/docs/dev/style.md#token-names Co-authored-by: Lukas Wirth <lukastw97@gmail.com>
2021-01-10Replace SyntaxKind usage with T! macro where applicableLukas Wirth-1/+1
2021-01-10Fix typo, parentheses is pluralLaurențiu Nicola-2/+2
2021-01-10Allow `true` and `false` keywords in const genericsCallym-10/+20