Skip to content

Commit

Permalink
feat: LSP will now suggest private items if they are visible (#5923)
Browse files Browse the repository at this point in the history
# Description

## Problem

Resolves #5879

## Summary

Uses the existing visibility check instead of just considering private
items to never be visible.

## Additional Context

None.

## Documentation

Check one:
- [x] No documentation needed.
- [ ] Documentation included in this PR.
- [ ] **[For Experimental Features]** Documentation to be submitted in a
separate PR.

# PR Checklist

- [x] I have tested the changes locally.
- [x] I have formatted the changes with [Prettier](https://prettier.io/)
and/or `cargo fmt` on default settings.
  • Loading branch information
asterite authored Sep 4, 2024
1 parent 44cf9a2 commit d2caa5b
Show file tree
Hide file tree
Showing 8 changed files with 54 additions and 38 deletions.
5 changes: 1 addition & 4 deletions compiler/noirc_frontend/src/elaborator/comptime.rs
Original file line number Diff line number Diff line change
Expand Up @@ -269,10 +269,7 @@ impl<'context> Elaborator<'context> {
let module = self.module_id();
self.interner.push_function(id, &function.def, module, location);

if self.interner.is_in_lsp_mode()
&& !function.def.is_test()
&& !function.def.is_private()
{
if self.interner.is_in_lsp_mode() && !function.def.is_test() {
self.interner.register_function(id, &function.def);
}

Expand Down
5 changes: 1 addition & 4 deletions compiler/noirc_frontend/src/hir/def_collector/dc_mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -239,10 +239,7 @@ impl<'a> ModCollector<'a> {
let location = Location::new(function.span(), self.file_id);
context.def_interner.push_function(func_id, &function.def, module, location);

if context.def_interner.is_in_lsp_mode()
&& !function.def.is_test()
&& !function.def.is_private()
{
if context.def_interner.is_in_lsp_mode() && !function.def.is_test() {
context.def_interner.register_function(func_id, &function.def);
}

Expand Down
5 changes: 3 additions & 2 deletions tooling/lsp/src/modules.rs
Original file line number Diff line number Diff line change
Expand Up @@ -47,10 +47,11 @@ pub(crate) fn module_full_path(
current_module_id: ModuleId,
current_module_parent_id: Option<ModuleId>,
interner: &NodeInterner,
def_maps: &BTreeMap<CrateId, CrateDefMap>,
) -> Option<String> {
let full_path;
if let ModuleDefId::ModuleId(module_id) = module_def_id {
if !is_visible(visibility, current_module_id, module_id) {
if !is_visible(module_id, current_module_id, visibility, def_maps) {
return None;
}

Expand All @@ -61,7 +62,7 @@ pub(crate) fn module_full_path(
return None;
};

if !is_visible(visibility, current_module_id, parent_module) {
if !is_visible(parent_module, current_module_id, visibility, def_maps) {
return None;
}

Expand Down
1 change: 1 addition & 0 deletions tooling/lsp/src/requests/code_action/import_or_qualify.rs
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,7 @@ impl<'a> CodeActionFinder<'a> {
self.module_id,
current_module_parent_id,
self.interner,
self.def_maps,
) else {
continue;
};
Expand Down
22 changes: 2 additions & 20 deletions tooling/lsp/src/requests/completion.rs
Original file line number Diff line number Diff line change
Expand Up @@ -22,10 +22,7 @@ use noirc_frontend::{
UnresolvedGenerics, UnresolvedType, UseTree, UseTreeKind, Visitor,
},
graph::{CrateId, Dependency},
hir::{
def_map::{CrateDefMap, LocalModuleId, ModuleId},
resolution::import::can_reference_module_id,
},
hir::def_map::{CrateDefMap, LocalModuleId, ModuleId},
hir_def::traits::Trait,
macros_api::{ModuleDefId, NodeInterner},
node_interner::ReferenceId,
Expand All @@ -34,7 +31,7 @@ use noirc_frontend::{
};
use sort_text::underscore_sort_text;

use crate::{requests::to_lsp_location, utils, LspState};
use crate::{requests::to_lsp_location, utils, visibility::is_visible, LspState};

use super::process_request;

Expand Down Expand Up @@ -1263,21 +1260,6 @@ fn module_def_id_from_reference_id(reference_id: ReferenceId) -> Option<ModuleDe
}
}

fn is_visible(
target_module_id: ModuleId,
current_module_id: ModuleId,
visibility: ItemVisibility,
def_maps: &BTreeMap<CrateId, CrateDefMap>,
) -> bool {
can_reference_module_id(
def_maps,
current_module_id.krate,
current_module_id.local_id,
target_module_id,
visibility,
)
}

#[cfg(test)]
mod completion_name_matches_tests {
use crate::requests::completion::name_matches;
Expand Down
1 change: 1 addition & 0 deletions tooling/lsp/src/requests/completion/auto_import.rs
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@ impl<'a> NodeFinder<'a> {
self.module_id,
current_module_parent_id,
self.interner,
self.def_maps,
) else {
continue;
};
Expand Down
25 changes: 25 additions & 0 deletions tooling/lsp/src/requests/completion/tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1863,4 +1863,29 @@ mod completion_tests {
Some("(use bar::foobar)".to_string()),
);
}

#[test]
async fn test_auto_import_suggests_private_function_if_visibile() {
let src = r#"
mod foo {
fn qux() {
barba>|<
}
}
fn barbaz() {}
fn main() {}
"#;

let items = get_completions(src).await;
assert_eq!(items.len(), 1);

let item = &items[0];
assert_eq!(item.label, "barbaz()");
assert_eq!(
item.label_details.as_ref().unwrap().detail,
Some("(use super::barbaz)".to_string()),
);
}
}
28 changes: 20 additions & 8 deletions tooling/lsp/src/visibility.rs
Original file line number Diff line number Diff line change
@@ -1,13 +1,25 @@
use noirc_frontend::{ast::ItemVisibility, hir::def_map::ModuleId};
use std::collections::BTreeMap;

use noirc_frontend::{
ast::ItemVisibility,
graph::CrateId,
hir::{
def_map::{CrateDefMap, ModuleId},
resolution::import::can_reference_module_id,
},
};

pub(super) fn is_visible(
target_module_id: ModuleId,
current_module_id: ModuleId,
visibility: ItemVisibility,
current_module: ModuleId,
target_module: ModuleId,
def_maps: &BTreeMap<CrateId, CrateDefMap>,
) -> bool {
match visibility {
ItemVisibility::Public => true,
ItemVisibility::Private => false,
ItemVisibility::PublicCrate => current_module.krate == target_module.krate,
}
can_reference_module_id(
def_maps,
current_module_id.krate,
current_module_id.local_id,
target_module_id,
visibility,
)
}

0 comments on commit d2caa5b

Please sign in to comment.