mirror of
https://github.com/roc-lang/roc.git
synced 2025-10-01 15:51:12 +00:00
even more cleanup
This commit is contained in:
parent
6fb014baba
commit
4ad5e532c1
1 changed files with 22 additions and 25 deletions
|
@ -12,8 +12,6 @@ use bitvec::vec::BitVec;
|
||||||
|
|
||||||
#[derive(Clone, Debug)]
|
#[derive(Clone, Debug)]
|
||||||
pub struct Scope {
|
pub struct Scope {
|
||||||
pub locals: ScopedIdentIds,
|
|
||||||
|
|
||||||
/// The type aliases currently in scope
|
/// The type aliases currently in scope
|
||||||
pub aliases: VecMap<Symbol, Alias>,
|
pub aliases: VecMap<Symbol, Alias>,
|
||||||
|
|
||||||
|
@ -27,7 +25,11 @@ pub struct Scope {
|
||||||
/// The first `exposed_ident_count` identifiers are exposed
|
/// The first `exposed_ident_count` identifiers are exposed
|
||||||
exposed_ident_count: usize,
|
exposed_ident_count: usize,
|
||||||
|
|
||||||
|
/// Identifiers that are imported (and introduced in the header)
|
||||||
imports: Vec<(Ident, Symbol, Region)>,
|
imports: Vec<(Ident, Symbol, Region)>,
|
||||||
|
|
||||||
|
/// Identifiers that are in scope, and defined in the current module
|
||||||
|
pub locals: ScopedIdentIds,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Scope {
|
impl Scope {
|
||||||
|
@ -49,15 +51,9 @@ impl Scope {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn lookup(&self, ident: &Ident, region: Region) -> Result<Symbol, RuntimeError> {
|
pub fn lookup(&self, ident: &Ident, region: Region) -> Result<Symbol, RuntimeError> {
|
||||||
match self.locals.get_symbol(ident) {
|
match self.scope_contains(ident) {
|
||||||
Some(symbol) => Ok(symbol),
|
Some((symbol, _)) => Ok(symbol),
|
||||||
None => {
|
None => {
|
||||||
for (import, symbol, _) in self.imports.iter() {
|
|
||||||
if ident == import {
|
|
||||||
return Ok(*symbol);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let error = RuntimeError::LookupNotInScope(
|
let error = RuntimeError::LookupNotInScope(
|
||||||
Loc {
|
Loc {
|
||||||
region,
|
region,
|
||||||
|
@ -163,6 +159,19 @@ impl Scope {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Is an identifier in scope, either in the locals or imports
|
||||||
|
fn scope_contains(&self, ident: &Ident) -> Option<(Symbol, Region)> {
|
||||||
|
self.locals.has_in_scope(ident).or_else(|| {
|
||||||
|
for (import, shadow, original_region) in self.imports.iter() {
|
||||||
|
if ident == import {
|
||||||
|
return Some((*shadow, *original_region));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
None
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
/// Introduce a new ident to scope.
|
/// Introduce a new ident to scope.
|
||||||
///
|
///
|
||||||
/// Returns Err if this would shadow an existing ident, including the
|
/// Returns Err if this would shadow an existing ident, including the
|
||||||
|
@ -193,7 +202,7 @@ impl Scope {
|
||||||
ident: &Ident,
|
ident: &Ident,
|
||||||
region: Region,
|
region: Region,
|
||||||
) -> Result<Symbol, (Region, Loc<Ident>)> {
|
) -> Result<Symbol, (Region, Loc<Ident>)> {
|
||||||
match self.locals.has_in_scope(ident) {
|
match self.scope_contains(ident) {
|
||||||
Some((_, original_region)) => {
|
Some((_, original_region)) => {
|
||||||
let shadow = Loc {
|
let shadow = Loc {
|
||||||
value: ident.clone(),
|
value: ident.clone(),
|
||||||
|
@ -201,19 +210,7 @@ impl Scope {
|
||||||
};
|
};
|
||||||
Err((original_region, shadow))
|
Err((original_region, shadow))
|
||||||
}
|
}
|
||||||
None => {
|
None => Ok(self.commit_introduction(ident, region)),
|
||||||
for (import, _, original_region) in self.imports.iter() {
|
|
||||||
if ident == import {
|
|
||||||
let shadow = Loc {
|
|
||||||
value: ident.clone(),
|
|
||||||
region,
|
|
||||||
};
|
|
||||||
return Err((*original_region, shadow));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Ok(self.commit_introduction(ident, region))
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -229,7 +226,7 @@ impl Scope {
|
||||||
ident: Ident,
|
ident: Ident,
|
||||||
region: Region,
|
region: Region,
|
||||||
) -> Result<(Symbol, Option<Symbol>), (Region, Loc<Ident>, Symbol)> {
|
) -> Result<(Symbol, Option<Symbol>), (Region, Loc<Ident>, Symbol)> {
|
||||||
match self.locals.has_in_scope(&ident) {
|
match self.scope_contains(&ident) {
|
||||||
Some((original_symbol, original_region)) => {
|
Some((original_symbol, original_region)) => {
|
||||||
let shadow_symbol = self.scopeless_symbol(&ident, region);
|
let shadow_symbol = self.scopeless_symbol(&ident, region);
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue