Go to file
bors[bot] 0a715cfbd2
Merge #6472
6472: Add `static` modifier for associated functions r=matklad a=p3achyjr

Adds static semantic token modifier to associated functions, resolves #6194 

## Info

- Associated functions are more-or-less equivalent to static methods in other languages. This PR checks, for each function, whether that function has a self_param, and whether it's enclosed in a trait/impl.

## Changes

- Added method ```is_associated``` to code_model::Function. This basically gets the source from the ast, and checks whether the enclosing scope is an impl or trait.
- Added `static` to HighlightModifiers
- Added unit test

## Tests

- Ran ```cargo test```

Co-authored-by: Anatol Liu <axlui@anatols-mbp.lan>
2020-11-09 21:13:51 +00:00
.cargo Use lld on winsows 2020-08-19 20:17:49 +02:00
.github Add common issues to the bug report template 2020-11-04 20:20:35 +02:00
.vscode
assets Add SVG logos to assets directory 2020-08-28 21:41:45 +10:00
crates Merge #6472 2020-11-09 21:13:51 +00:00
docs don\t indent tests 2020-11-06 20:29:41 +01:00
editors/code Merge #6465 2020-11-09 11:54:42 +00:00
xtask More consistent naming 2020-11-09 13:07:18 +01:00
.gitattributes
.gitignore Create xtask module to generate diagnostics docs 2020-10-19 20:55:16 +03:00
bors.toml Reduce bors timeout 2020-10-14 13:37:20 +02:00
Cargo.lock cargo update 2020-11-04 22:01:19 -05:00
Cargo.toml Upgrade Chalk to 0.36 2020-10-30 18:57:55 +01:00
LICENSE-APACHE
LICENSE-MIT
PRIVACY.md Add notes concerning privacy and network access 2020-10-04 20:16:53 +03:00
README.md Replace logo in readme with SVG version 2020-08-28 21:42:12 +10:00
rustfmt.toml

rust-analyzer logo

rust-analyzer is an experimental modular compiler frontend for the Rust language. It is a part of a larger rls-2.0 effort to create excellent IDE support for Rust.

Work on rust-analyzer is sponsored by

Ferrous Systems

Quick Start

https://rust-analyzer.github.io/manual.html#installation

Documentation

If you want to contribute to rust-analyzer or are just curious about how things work under the hood, check the ./docs/dev folder.

If you want to use rust-analyzer's language server with your editor of choice, check the manual folder. It also contains some tips & tricks to help you be more productive when using rust-analyzer.

Communication

For usage and troubleshooting requests, please use "IDEs and Editors" category of the Rust forum:

https://users.rust-lang.org/c/ide/14

For questions about development and implementation, join rls-2.0 working group on Zulip:

https://rust-lang.zulipchat.com/#narrow/stream/185405-t-compiler.2Frls-2.2E0

License

Rust analyzer is primarily distributed under the terms of both the MIT license and the Apache License (Version 2.0).

See LICENSE-APACHE and LICENSE-MIT for details.