mirror of
https://github.com/erg-lang/erg.git
synced 2025-09-28 20:14:45 +00:00
Split cache between Python and Erg modules
This commit is contained in:
parent
5916096cc4
commit
5aae4a69a5
22 changed files with 521 additions and 258 deletions
|
@ -4,7 +4,9 @@ use std::hash::Hash;
|
|||
use std::rc::Rc;
|
||||
|
||||
use erg_common::dict::Dict;
|
||||
use erg_common::levenshtein::get_similar_name;
|
||||
use erg_common::shared::Shared;
|
||||
use erg_common::Str;
|
||||
|
||||
use erg_parser::ast::VarName;
|
||||
|
||||
|
@ -26,7 +28,7 @@ impl ModId {
|
|||
}
|
||||
}
|
||||
|
||||
#[derive(Debug)]
|
||||
#[derive(Debug, Clone)]
|
||||
pub struct ModuleEntry {
|
||||
id: ModId, // builtin == 0, __main__ == 1
|
||||
pub hir: Option<HIR>,
|
||||
|
@ -88,6 +90,12 @@ impl ModuleCache {
|
|||
self.cache.get(name)
|
||||
}
|
||||
|
||||
pub fn get_by_name(&self, __name__: &str) -> Option<(&VarName, &ModuleEntry)> {
|
||||
self.cache
|
||||
.iter()
|
||||
.find(|(_, ent)| &ent.ctx.name[..] == __name__)
|
||||
}
|
||||
|
||||
pub fn get_mut<Q: Eq + Hash + ?Sized>(&mut self, name: &Q) -> Option<&mut ModuleEntry>
|
||||
where
|
||||
VarName: Borrow<Q>,
|
||||
|
@ -102,6 +110,10 @@ impl ModuleCache {
|
|||
self.cache.insert(name, entry);
|
||||
}
|
||||
|
||||
pub fn register_alias(&mut self, name: VarName, entry: &ModuleEntry) {
|
||||
self.cache.insert(name, entry.clone());
|
||||
}
|
||||
|
||||
pub fn remove<Q: Eq + Hash + ?Sized>(&mut self, name: &Q) -> Option<ModuleEntry>
|
||||
where
|
||||
VarName: Borrow<Q>,
|
||||
|
@ -122,6 +134,10 @@ impl ModuleCache {
|
|||
None
|
||||
}
|
||||
}
|
||||
|
||||
pub fn get_similar_name(&self, name: &str) -> Option<Str> {
|
||||
get_similar_name(self.cache.iter().map(|(v, _)| &v.inspect()[..]), name).map(Str::rc)
|
||||
}
|
||||
}
|
||||
|
||||
#[derive(Debug, Clone, Default)]
|
||||
|
@ -148,6 +164,11 @@ impl SharedModuleCache {
|
|||
ref_.get(name)
|
||||
}
|
||||
|
||||
pub fn get_by_name(&self, __name__: &str) -> Option<(&VarName, &ModuleEntry)> {
|
||||
let ref_ = unsafe { self.0.as_ptr().as_ref().unwrap() };
|
||||
ref_.get_by_name(__name__)
|
||||
}
|
||||
|
||||
pub fn get_mut<Q: Eq + Hash + ?Sized>(&self, name: &Q) -> Option<&mut ModuleEntry>
|
||||
where
|
||||
VarName: Borrow<Q>,
|
||||
|
@ -175,6 +196,10 @@ impl SharedModuleCache {
|
|||
self.0.borrow_mut().register(name, hir, ctx);
|
||||
}
|
||||
|
||||
pub fn register_alias(&self, name: VarName, entry: &ModuleEntry) {
|
||||
self.0.borrow_mut().register_alias(name, entry);
|
||||
}
|
||||
|
||||
pub fn remove<Q: Eq + Hash + ?Sized>(&self, name: &Q) -> Option<ModuleEntry>
|
||||
where
|
||||
VarName: Borrow<Q>,
|
||||
|
@ -185,4 +210,8 @@ impl SharedModuleCache {
|
|||
pub fn remove_by_id(&self, id: ModId) -> Option<ModuleEntry> {
|
||||
self.0.borrow_mut().remove_by_id(id)
|
||||
}
|
||||
|
||||
pub fn get_similar_name(&self, name: &str) -> Option<Str> {
|
||||
self.0.borrow().get_similar_name(name)
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue