aboutsummaryrefslogtreecommitdiff
path: root/crates
Commit message (Collapse)AuthorAgeFilesLines
...
| * | | Implement Syntax Highlight inside MacroEdwin Cheng2020-01-204-111/+208
| | | |
* | | | Merge #2887bors[bot]2020-01-279-18/+491
|\ \ \ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2887: Initial auto import action implementation r=matklad a=SomeoneToIgnore Closes https://github.com/rust-analyzer/rust-analyzer/issues/2180 Adds an auto import action implementation. This implementation is not ideal and has a few limitations: * The import search functionality should be moved into a separate crate accessible from ra_assists. This requires a lot of changes and a preliminary design. Currently the functionality is provided as a trait impl, more on that here: https://github.com/rust-analyzer/rust-analyzer/issues/2180#issuecomment-575690942 * Due to the design desicion from the previous item, no doctests are run for the new aciton (look for a new FIXME in the PR) * For the same reason, I have to create the mock trait implementaion to test the assist * Ideally, I think we should have this feature as a diagnostics (that detects an absense of an import) that has a corresponding quickfix action that gets evaluated on demand. Curretly we perform the import search every time we resolve the import which looks suboptimal. This requires `classify_name_ref` to be moved from ra_ide, so not done currently. A few improvements to the imports mechanism to be considered later: * Constants like `ra_syntax::SyntaxKind::NAME` are not imported, because they are not present in the database * Method usages are not imported, they are found in the database, but `find_use_path` does not return any import paths for them * Some import paths returned by the `find_use_path` method end up in `core::` or `alloc::` instead of `std:`, for example: `core::fmt::Debug` instead of `std::fmt::Debug`. This is not an error techically, but still looks weird. * No detection of cases where a trait should be imported in order to be able to call a method * Improve `auto_import_text_edit` functionality: refactor it and move away from the place it is now, add better logic for merging the new import with already existing imports Co-authored-by: Kirill Bulatov <[email protected]>
| * | | | Code review fixesKirill Bulatov2020-01-274-11/+11
| | | | |
| * | | | Enforce alphabetical import sortingKirill Bulatov2020-01-261-2/+3
| | | | |
| * | | | Adjust the testsKirill Bulatov2020-01-263-61/+150
| | | | |
| * | | | Have a better trait interfaceKirill Bulatov2020-01-264-64/+45
| | | | |
| * | | | Raise the import search query capKirill Bulatov2020-01-261-2/+3
| | | | |
| * | | | Remove unnecessary lifetime parameterKirill Bulatov2020-01-263-9/+9
| | | | |
| * | | | Initial auto import action implementationKirill Bulatov2020-01-269-19/+420
| | | | |
* | | | | Move snaps to new naming schemeJeremy Kolb2020-01-267-0/+0
| | | | |
* | | | | Update cratesJeremy Kolb2020-01-264-4/+4
|/ / / /
* | | | Merge #2906bors[bot]2020-01-262-5/+25
|\ \ \ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2906: Fix thread priority problems on windows r=matklad a=matklad Co-authored-by: Aleksey Kladov <[email protected]>
| * | | | Bump main thread priority on windowsAleksey Kladov2020-01-262-0/+22
| | | | |
| * | | | Use default threadpool sizeAleksey Kladov2020-01-251-5/+3
| | | | |
* | | | | fixed inline_local_variable bugTomáš2020-01-251-0/+15
|/ / / /
* | | | Merge #2899bors[bot]2020-01-251-1/+15
|\ \ \ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2899: Provide more runners for potential tests r=matklad a=SomeoneToIgnore Based on the https://rust-lang.zulipchat.com/#narrow/stream/185405-t-compiler.2Fwg-rls-2.2E0/topic/Runners.20for.20custom.20test.20annotations discussion. Adds a test runner for every method that has an annotation that contains `test` word in it, allowing to run tests annotated with custom testing annotations such as `#[tokio::test]`, `#[test_case(...)]` and others at costs of potentially emitting some false-positives. Co-authored-by: Kirill Bulatov <[email protected]>
| * | | | Provide more runners for potential testsKirill Bulatov2020-01-231-1/+15
| | |_|/ | |/| |
* | | | Add print_time helperAleksey Kladov2020-01-251-0/+15
| | | |
* | | | Disable env_logger humantime featureAleksey Kladov2020-01-252-2/+2
| | | | | | | | | | | | | | | | | | | | We rarely care about timings of events, and, when we care, we need millisecond precision
* | | | Cancel requests during shutdownAleksey Kladov2020-01-243-5/+10
| | | |
* | | | Remove RWLock from check watcher.Emil Lauridsen2020-01-235-18/+16
|/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | @matklad mentioned this might be a good idea. So the general idea is that we don't really need the lock, as we can just clone the check watcher state when creating a snapshot. We can then use `Arc::get_mut` to get mutable access to the state from `WorldState` when needed. Running with this it seems to improve responsiveness a bit while cargo is running, but I have no hard numbers to prove it. In any case, a serialization point less is always better when we're trying to be responsive.
* | / Update crateskjeremy2020-01-222-2/+2
| |/ |/|
* | Omit default parameters for reference typesKirill Bulatov2020-01-223-3/+20
| |
* | Fixed a typoVeetaha2020-01-221-1/+1
| |
* | Fixed a typoVeetaha2020-01-221-1/+1
| |
* | Preserved a comment on the bug previously present in ast::Literal::kind()Veetaha2020-01-221-0/+5
| |
* | ra_syntax: remove code duplication and token reevaluation from ↵Veetaha2020-01-222-32/+22
| | | | | | | | ast::Literal::kind()
* | Merge #2877bors[bot]2020-01-204-27/+55
|\ \ | |/ |/| | | | | | | | | | | 2877: "Insert explicit type " assist fix #2869, fix typo r=matklad a=TomasKralCZ So this was quite straightforward. I basically looked at how the other assists work and tried doing something simillar. I also fixed a typo in the other assist. Co-authored-by: TomasKralCZ <[email protected]>
| * changed 'descendants()' to 'children()'TomasKralCZ2020-01-201-4/+1
| |
| * added eq_token() method to LetStmtTomasKralCZ2020-01-192-2/+8
| |
| * Merge branch 'master' of https://github.com/rust-analyzer/rust-analyzerTomasKralCZ2020-01-1911-67/+154
| |\
| * | fix 'add_explicit_type' assist rangeTomasKralCZ2020-01-191-1/+26
| | |
| * | fix typo in 'inline_local_variable'TomasKralCZ2020-01-192-26/+26
| | |
* | | Fix a corner case when printing unaccounted timeMichal Terepeta2020-01-191-4/+52
| |/ |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Previously `ra_prof` wouldn't actually print the unaccounted time in some cases. We would print, for instance, this: ``` 5ms - foo 2ms - bar ``` instead of: ``` 5ms - foo 2ms - bar 3ms - ??? ``` The fix is to properly handle the case when an entry has 0 children instead of using the `last` variable. Signed-off-by: Michal Terepeta <[email protected]>
* | Improve parameter hints a bit & add emacs supportFlorian Diebold2020-01-182-17/+25
| | | | | | | | | | - just include the name, not e.g. `mut` - don't return empty hints (or `_`)
* | Fix inference for shift operatorsFlorian Diebold2020-01-173-5/+35
| | | | | | | | Fixes #2602.
* | Nest attrs into exprs in function argsAleksey Kladov2020-01-173-32/+23
| |
* | Extract expr_with_attrsAleksey Kladov2020-01-173-23/+36
| |
* | Merge pull request #2813 from jyn514/arg_attributesAleksey Kladov2020-01-173-0/+45
|\ \ | | | | | | Allow attributes before function arguments
| * | move inline function closer to relevant codeJoshua Nelson2020-01-175-119/+44
| | | | | | | | | | | | also updates generated inline tests
| * | shrink inline tesJoshua Nelson2020-01-161-9/+3
| | |
| * | Allow attributes before function argumentsJoshua Nelson2020-01-123-0/+126
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This adds support for function calls of the form: ```rust ( #[attr(...)] 1.2, #[attr_one(...)] #[attr_two(...)] 1.5, ... etc ... ) ``` Closes https://github.com/rust-analyzer/rust-analyzer/issues/2801
* | | Merge #2865bors[bot]2020-01-171-1/+1
|\ \ \ | |_|/ |/| | | | | | | | | | | | | | | | | 2865: fix(mixed): fixed a couple of typos and added a todo r=kjeremy a=Veetaha Fixed a couple of typos and added a todo while studying the codebase. Co-authored-by: Veetaha <[email protected]>
| * | fix(ra_parser.typo): amend 'format language' to 'formal language'Veetaha2020-01-151-1/+1
| | |
* | | Minimize testAleksey Kladov2020-01-167-129/+51
| | |
* | | Simplify array parsingAleksey Kladov2020-01-163-68/+44
| | |
* | | Merge #2862bors[bot]2020-01-1616-430/+306
|\ \ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2862: Move from `from_source` to `SourceBinder` r=matklad a=matklad bors r+ Co-authored-by: Aleksey Kladov <[email protected]>
| * | | Fix commentAleksey Kladov2020-01-161-3/+1
| | | |
| * | | Remove dead codeAleksey Kladov2020-01-161-34/+2
| | | |
| * | | Correctly discover module containersAleksey Kladov2020-01-161-11/+15
| | | |