mirror of
https://github.com/rust-lang/rust-analyzer.git
synced 2025-09-28 21:05:02 +00:00
Generalize query
This commit is contained in:
parent
0568e76406
commit
7fc91f41d8
5 changed files with 79 additions and 110 deletions
|
@ -21,7 +21,8 @@ use std::{
|
|||
use libsyntax2::ast;
|
||||
use libeditor::{LineIndex, FileSymbol};
|
||||
|
||||
use self::symbol_index::{FileSymbols, Query};
|
||||
use self::symbol_index::{FileSymbols};
|
||||
pub use self::symbol_index::Query;
|
||||
|
||||
pub type Result<T> = ::std::result::Result<T, ::failure::Error>;
|
||||
|
||||
|
@ -89,14 +90,13 @@ impl World {
|
|||
Ok(index.clone())
|
||||
}
|
||||
|
||||
pub fn world_symbols<'a>(&'a self, query: &str) -> impl Iterator<Item=(&'a Path, &'a FileSymbol)> + 'a
|
||||
pub fn world_symbols<'a>(&'a self, query: Query) -> impl Iterator<Item=(&'a Path, &'a FileSymbol)> + 'a
|
||||
{
|
||||
let q = Query::new(query);
|
||||
self.data.file_map.iter()
|
||||
.flat_map(move |(path, data)| {
|
||||
let path: &'a Path = path.as_path();
|
||||
let symbols = data.symbols(path);
|
||||
q.process(symbols).map(move |s| (path, s))
|
||||
query.process(symbols).map(move |s| (path, s))
|
||||
})
|
||||
}
|
||||
|
||||
|
|
|
@ -3,7 +3,7 @@ use libsyntax2::{
|
|||
ast,
|
||||
SyntaxKind::{self, *},
|
||||
};
|
||||
use fst::{self, IntoStreamer};
|
||||
use fst::{self, IntoStreamer, Streamer};
|
||||
|
||||
#[derive(Debug)]
|
||||
pub(crate) struct FileSymbols {
|
||||
|
@ -30,19 +30,30 @@ impl FileSymbols {
|
|||
}
|
||||
}
|
||||
|
||||
pub(crate) struct Query {
|
||||
pub struct Query {
|
||||
query: String,
|
||||
all_symbols: bool,
|
||||
lowercased: String,
|
||||
only_types: bool,
|
||||
exact: bool,
|
||||
}
|
||||
|
||||
impl Query {
|
||||
pub(crate) fn new(query: &str) -> Query {
|
||||
let all_symbols = query.contains("#");
|
||||
let query: String = query.chars()
|
||||
.filter(|&c| c != '#')
|
||||
.flat_map(char::to_lowercase)
|
||||
.collect();
|
||||
Query { query, all_symbols }
|
||||
pub fn new(query: String) -> Query {
|
||||
let lowercased = query.to_lowercase();
|
||||
Query {
|
||||
query,
|
||||
lowercased,
|
||||
only_types: false,
|
||||
exact: false,
|
||||
}
|
||||
}
|
||||
|
||||
pub fn only_types(&mut self) {
|
||||
self.only_types = true;
|
||||
}
|
||||
|
||||
pub fn exact(&mut self) {
|
||||
self.exact = true;
|
||||
}
|
||||
|
||||
pub(crate) fn process<'a>(
|
||||
|
@ -55,16 +66,21 @@ impl Query {
|
|||
_ => false,
|
||||
}
|
||||
}
|
||||
let automaton = fst::automaton::Subsequence::new(&self.query);
|
||||
let all_symbols = self.all_symbols;
|
||||
file.map.search(automaton).into_stream()
|
||||
.into_values()
|
||||
.into_iter()
|
||||
.map(move |idx| {
|
||||
let idx = idx as usize;
|
||||
&file.symbols[idx]
|
||||
})
|
||||
.filter(move |s| all_symbols || is_type(s.kind))
|
||||
let automaton = fst::automaton::Subsequence::new(&self.lowercased);
|
||||
let mut stream = file.map.search(automaton).into_stream();
|
||||
let mut res = Vec::new();
|
||||
while let Some((_, idx)) = stream.next() {
|
||||
let idx = idx as usize;
|
||||
let symbol = &file.symbols[idx];
|
||||
if self.only_types && !is_type(symbol.kind) {
|
||||
continue;
|
||||
}
|
||||
if self.exact && symbol.name != self.query {
|
||||
continue;
|
||||
}
|
||||
res.push(symbol)
|
||||
}
|
||||
res.into_iter()
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue