Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

⬆️ rust-analyzer #101497

Merged
merged 64 commits into from
Sep 7, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
64 commits
Select commit Hold shift + click to select a range
7025502
clippy: make generated code nice to read
kartva Aug 7, 2022
a3fc4db
more matches! sites
kartva Aug 7, 2022
bcab4be
regenerate files with new syntax
kartva Aug 7, 2022
581a01d
Migrate `syntax::make` to use format arg captures
DropDemBits Aug 18, 2022
6669ea8
Leave attrs on the variant, not the extracted struct
DropDemBits Aug 18, 2022
7d77775
Insert newline after extracted struct's attributes
DropDemBits Aug 18, 2022
dbaf2ce
turn `unwrap_or` into `unwrap_or_else` and vice versa
Austaras Aug 26, 2022
0dd9eef
add type check
Austaras Aug 26, 2022
f9c180f
update tests
Austaras Aug 26, 2022
42486b6
change as requested
Austaras Aug 27, 2022
f02cd0a
Auto merge of #13056 - DropDemBits:make-refactors, r=Veykril
bors Aug 29, 2022
66ec636
Highlight namerefs by syntax until proc-macros have been loaded
Veykril Aug 28, 2022
5f132e6
feat: Add a "Unmerge match arm" assist to split or-patterns inside ma…
ChayimFriedman2 Aug 30, 2022
7ecead2
fix: sort and deduplicate auto traits in trait object types
lowr Jul 18, 2022
989b09d
Auto merge of #13145 - ChayimFriedman2:unmerge-match-arm, r=jonas-sch…
bors Aug 30, 2022
45dac9a
Move comments to the extracted struct
DropDemBits Aug 30, 2022
662ab0c
fix: unescape all occurrences of module name in module resolution
lowr Aug 30, 2022
e5e9799
Use type information to deduce the correct type for "Replace turbofis…
ChayimFriedman2 Aug 31, 2022
bcdacfe
Support `?` and `.await` in "Replace turbofish with explicit type"
ChayimFriedman2 Aug 31, 2022
e0e18cc
Auto merge of #13151 - ChayimFriedman2:replace-turbofish-other-type, …
bors Aug 31, 2022
5c0e252
Drop the expander borrow in all control flow paths
Veykril Aug 31, 2022
ef27641
Auto merge of #13154 - Veykril:ty-mac-expander, r=Veykril
bors Aug 31, 2022
b613896
Auto merge of #13149 - lowr:fix/unescape-raw-ident-module-path, r=Vey…
bors Aug 31, 2022
56d8886
Auto merge of #12793 - lowr:fix/12739, r=Veykril
bors Aug 31, 2022
d9e2207
Auto merge of #12963 - DesmondWillowbrook:clippy-matches-sourcegen, r…
bors Aug 31, 2022
43e8d96
change title
Austaras Aug 31, 2022
4661a60
Add convert_two_arm_bool_match_to_matches_macro ide-assists
pocket7878 Aug 12, 2022
a5d2463
fix: Simplify logics to allow two-arm enum match.
pocket7878 Aug 12, 2022
5a1b45d
feature: Simplfy branch check logics
pocket7878 Aug 31, 2022
7464b6d
feature: Check if first_arm bool and second_arm bool is inverted or not.
pocket7878 Aug 31, 2022
cf05b7d
Auto merge of #13051 - DropDemBits:attrs-and-comments-on-enum-variant…
bors Aug 31, 2022
79a578a
Auto merge of #13005 - pocket7878:convert-two-arm-bool-match-to-match…
bors Aug 31, 2022
7f38581
Auto merge of #13120 - Austaras:master, r=jonas-schievink
bors Aug 31, 2022
192a79c
Remove hir::Expr::MacroStmts
Veykril Aug 31, 2022
1a580a3
Implement unstable RFC 1872 `exhaustive_patterns`
iDawer Aug 31, 2022
ee02a47
Remove unnecessary allocations
Veykril Aug 31, 2022
ab068f1
Auto merge of #13156 - Veykril:macro-stmts, r=Veykril
bors Aug 31, 2022
1fa9d5e
Correct visibility check
iDawer Aug 31, 2022
643c3a5
Auto merge of #13134 - Veykril:proc-highlight, r=Veykril
bors Aug 31, 2022
d786a40
Parse TypePathFn with preceding `::`
ChayimFriedman2 Aug 31, 2022
2eec4ed
Lower float literals with underscores
ChayimFriedman2 Sep 1, 2022
d6fc4a9
Simplify breakables handling
Veykril Sep 1, 2022
1e66a5a
Diagnose incorrect continue expressions
Veykril Sep 1, 2022
8110119
Properly handle break resolution inside non-breakable expressions
Veykril Sep 1, 2022
c6b7f45
Don't run `rust-2021-compatibility` lints, our crates are already on …
Veykril Sep 1, 2022
c4445e4
Auto merge of #13165 - Veykril:breakables, r=Veykril
bors Sep 1, 2022
f23114c
Auto merge of #13161 - ChayimFriedman2:pi-is-zero, r=jonas-schievink
bors Sep 1, 2022
93c52e4
Auto merge of #13160 - ChayimFriedman2:parse-parenthesized-type-path-…
bors Sep 1, 2022
61ad33d
internal: ignore failures when publishing to ovsx
matklad Sep 2, 2022
412d614
Auto merge of #13171 - matklad:open-failure, r=lnicola
bors Sep 2, 2022
8ae58b9
Record enabled unstable features into DefMap
iDawer Sep 2, 2022
ffd79c2
Add docs
iDawer Sep 2, 2022
4f8153e
Auto merge of #13167 - iDawer:exhaustive_patterns, r=Veykril
bors Sep 2, 2022
fe0a106
Don't store SyntheticSyntax in the reverse maps in BodySourceMap
Veykril Sep 2, 2022
2bb6635
Auto merge of #13173 - Veykril:synthetic, r=Veykril
bors Sep 2, 2022
8828049
Lift out the module scope into a field in the Resolver
Veykril Sep 2, 2022
f27f98d
Auto merge of #13174 - Veykril:resolver, r=Veykril
bors Sep 2, 2022
894aa0e
Clarify the state of (extern) preludes for block def maps
Veykril Sep 2, 2022
afa374e
Auto merge of #13175 - Veykril:resolver, r=Veykril
bors Sep 2, 2022
020f689
Fix nested break expressions, expecting unknown types
Veykril Sep 3, 2022
8ddb8b7
Auto merge of #13183 - Veykril:break-break, r=Veykril
bors Sep 3, 2022
d7ef3f5
fix: correct broken logic for return complition
matklad Sep 4, 2022
67920f7
Auto merge of #13187 - matklad:return, r=Veykril
bors Sep 4, 2022
d058800
:arrow_up: rust-analyzer
lnicola Sep 6, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
156 changes: 78 additions & 78 deletions src/tools/rust-analyzer/.github/workflows/ci.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -6,15 +6,15 @@ on:
pull_request:
push:
branches:
- auto
- try
- auto
- try

env:
CARGO_INCREMENTAL: 0
CARGO_NET_RETRY: 10
CI: 1
RUST_BACKTRACE: short
RUSTFLAGS: "-D warnings -W unreachable-pub -W rust-2021-compatibility"
RUSTFLAGS: "-D warnings -W unreachable-pub -W bare-trait-objects"
RUSTUP_MAX_RETRIES: 10

jobs:
Expand All @@ -31,25 +31,25 @@ jobs:
os: [ubuntu-latest, windows-latest, macos-latest]

steps:
- name: Checkout repository
uses: actions/checkout@v3
with:
ref: ${{ github.event.pull_request.head.sha }}
fetch-depth: 20
- name: Checkout repository
uses: actions/checkout@v3
with:
ref: ${{ github.event.pull_request.head.sha }}
fetch-depth: 20

- name: Install Rust toolchain
run: |
rustup update --no-self-update stable
rustup component add rustfmt rust-src
- name: Install Rust toolchain
run: |
rustup update --no-self-update stable
rustup component add rustfmt rust-src

- name: Cache Dependencies
uses: Swatinem/rust-cache@ce325b60658c1b38465c06cc965b79baf32c1e72
- name: Cache Dependencies
uses: Swatinem/rust-cache@ce325b60658c1b38465c06cc965b79baf32c1e72

- name: Compile
run: cargo test --no-run --locked
- name: Compile
run: cargo test --no-run --locked

- name: Test
run: cargo test -- --nocapture --quiet
- name: Test
run: cargo test -- --nocapture --quiet

# Weird targets to catch non-portable code
rust-cross:
Expand All @@ -64,25 +64,25 @@ jobs:
targets_ide: "wasm32-unknown-unknown"

steps:
- name: Checkout repository
uses: actions/checkout@v3

- name: Install Rust toolchain
run: |
rustup update --no-self-update stable
rustup target add ${{ env.targets }} ${{ env.targets_ide }}

- name: Cache Dependencies
uses: Swatinem/rust-cache@ce325b60658c1b38465c06cc965b79baf32c1e72

- name: Check
run: |
for target in ${{ env.targets }}; do
cargo check --target=$target --all-targets
done
for target in ${{ env.targets_ide }}; do
cargo check -p ide --target=$target --all-targets
done
- name: Checkout repository
uses: actions/checkout@v3

- name: Install Rust toolchain
run: |
rustup update --no-self-update stable
rustup target add ${{ env.targets }} ${{ env.targets_ide }}

- name: Cache Dependencies
uses: Swatinem/rust-cache@ce325b60658c1b38465c06cc965b79baf32c1e72

- name: Check
run: |
for target in ${{ env.targets }}; do
cargo check --target=$target --all-targets
done
for target in ${{ env.targets_ide }}; do
cargo check -p ide --target=$target --all-targets
done

typescript:
if: github.repository == 'rust-lang/rust-analyzer'
Expand All @@ -95,47 +95,47 @@ jobs:
runs-on: ${{ matrix.os }}

steps:
- name: Checkout repository
uses: actions/checkout@v3

- name: Install Nodejs
uses: actions/setup-node@v1
with:
node-version: 16.x

- name: Install xvfb
if: matrix.os == 'ubuntu-latest'
run: sudo apt-get install -y xvfb

- run: npm ci
working-directory: ./editors/code

# - run: npm audit || { sleep 10 && npm audit; } || { sleep 30 && npm audit; }
# if: runner.os == 'Linux'
# working-directory: ./editors/code

- run: npm run lint
working-directory: ./editors/code

- name: Run VS Code tests (Linux)
if: matrix.os == 'ubuntu-latest'
env:
VSCODE_CLI: 1
run: xvfb-run npm test
working-directory: ./editors/code

- name: Run VS Code tests (Windows)
if: matrix.os == 'windows-latest'
env:
VSCODE_CLI: 1
run: npm test
working-directory: ./editors/code

- run: npm run pretest
working-directory: ./editors/code

- run: npm run package --scripts-prepend-node-path
working-directory: ./editors/code
- name: Checkout repository
uses: actions/checkout@v3

- name: Install Nodejs
uses: actions/setup-node@v1
with:
node-version: 16.x

- name: Install xvfb
if: matrix.os == 'ubuntu-latest'
run: sudo apt-get install -y xvfb

- run: npm ci
working-directory: ./editors/code

# - run: npm audit || { sleep 10 && npm audit; } || { sleep 30 && npm audit; }
# if: runner.os == 'Linux'
# working-directory: ./editors/code

- run: npm run lint
working-directory: ./editors/code

- name: Run VS Code tests (Linux)
if: matrix.os == 'ubuntu-latest'
env:
VSCODE_CLI: 1
run: xvfb-run npm test
working-directory: ./editors/code

- name: Run VS Code tests (Windows)
if: matrix.os == 'windows-latest'
env:
VSCODE_CLI: 1
run: npm test
working-directory: ./editors/code

- run: npm run pretest
working-directory: ./editors/code

- run: npm run package --scripts-prepend-node-path
working-directory: ./editors/code

end-success:
name: bors build finished
Expand Down
4 changes: 2 additions & 2 deletions src/tools/rust-analyzer/.github/workflows/release.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -248,7 +248,7 @@ jobs:
if: github.ref == 'refs/heads/release' && (github.repository == 'rust-analyzer/rust-analyzer' || github.repository == 'rust-lang/rust-analyzer')
working-directory: ./editors/code
# token from https://dev.azure.com/rust-analyzer/
run: npx ovsx publish --pat ${{ secrets.OPENVSX_TOKEN }} --packagePath ../../dist/rust-analyzer-*.vsix
run: npx ovsx publish --pat ${{ secrets.OPENVSX_TOKEN }} --packagePath ../../dist/rust-analyzer-*.vsix || true

- name: Publish Extension (Code Marketplace, nightly)
if: github.ref != 'refs/heads/release' && (github.repository == 'rust-analyzer/rust-analyzer' || github.repository == 'rust-lang/rust-analyzer')
Expand All @@ -258,4 +258,4 @@ jobs:
- name: Publish Extension (OpenVSX, nightly)
if: github.ref != 'refs/heads/release' && (github.repository == 'rust-analyzer/rust-analyzer' || github.repository == 'rust-lang/rust-analyzer')
working-directory: ./editors/code
run: npx ovsx publish --pat ${{ secrets.OPENVSX_TOKEN }} --packagePath ../../dist/rust-analyzer-*.vsix
run: npx ovsx publish --pat ${{ secrets.OPENVSX_TOKEN }} --packagePath ../../dist/rust-analyzer-*.vsix || true
19 changes: 12 additions & 7 deletions src/tools/rust-analyzer/crates/hir-def/src/body.rs
Original file line number Diff line number Diff line change
Expand Up @@ -250,6 +250,10 @@ pub type PatSource = InFile<PatPtr>;

pub type LabelPtr = AstPtr<ast::Label>;
pub type LabelSource = InFile<LabelPtr>;

pub type FieldPtr = AstPtr<ast::RecordExprField>;
pub type FieldSource = InFile<FieldPtr>;

/// An item body together with the mapping from syntax nodes to HIR expression
/// IDs. This is needed to go from e.g. a position in a file to the HIR
/// expression containing it; but for type inference etc., we want to operate on
Expand All @@ -264,18 +268,18 @@ pub type LabelSource = InFile<LabelPtr>;
#[derive(Default, Debug, Eq, PartialEq)]
pub struct BodySourceMap {
expr_map: FxHashMap<ExprSource, ExprId>,
expr_map_back: ArenaMap<ExprId, Result<ExprSource, SyntheticSyntax>>,
expr_map_back: ArenaMap<ExprId, ExprSource>,

pat_map: FxHashMap<PatSource, PatId>,
pat_map_back: ArenaMap<PatId, Result<PatSource, SyntheticSyntax>>,
pat_map_back: ArenaMap<PatId, PatSource>,

label_map: FxHashMap<LabelSource, LabelId>,
label_map_back: ArenaMap<LabelId, LabelSource>,

/// We don't create explicit nodes for record fields (`S { record_field: 92 }`).
/// Instead, we use id of expression (`92`) to identify the field.
field_map: FxHashMap<InFile<AstPtr<ast::RecordExprField>>, ExprId>,
field_map_back: FxHashMap<ExprId, InFile<AstPtr<ast::RecordExprField>>>,
field_map: FxHashMap<FieldSource, ExprId>,
field_map_back: FxHashMap<ExprId, FieldSource>,

expansions: FxHashMap<InFile<AstPtr<ast::MacroCall>>, HirFileId>,

Expand Down Expand Up @@ -420,7 +424,7 @@ impl Index<LabelId> for Body {
// Perhaps `expr_syntax` and `expr_id`?
impl BodySourceMap {
pub fn expr_syntax(&self, expr: ExprId) -> Result<ExprSource, SyntheticSyntax> {
self.expr_map_back[expr].clone()
self.expr_map_back.get(expr).cloned().ok_or(SyntheticSyntax)
}

pub fn node_expr(&self, node: InFile<&ast::Expr>) -> Option<ExprId> {
Expand All @@ -434,7 +438,7 @@ impl BodySourceMap {
}

pub fn pat_syntax(&self, pat: PatId) -> Result<PatSource, SyntheticSyntax> {
self.pat_map_back[pat].clone()
self.pat_map_back.get(pat).cloned().ok_or(SyntheticSyntax)
}

pub fn node_pat(&self, node: InFile<&ast::Pat>) -> Option<PatId> {
Expand All @@ -456,9 +460,10 @@ impl BodySourceMap {
self.label_map.get(&src).cloned()
}

pub fn field_syntax(&self, expr: ExprId) -> InFile<AstPtr<ast::RecordExprField>> {
pub fn field_syntax(&self, expr: ExprId) -> FieldSource {
self.field_map_back[&expr].clone()
}

pub fn node_field(&self, node: InFile<&ast::RecordExprField>) -> Option<ExprId> {
let src = node.map(AstPtr::new);
self.field_map.get(&src).cloned()
Expand Down
Loading