From e5ae4ea1288a555c4019dad43ee27e960eec46b9 Mon Sep 17 00:00:00 2001 From: Mel Date: Tue, 12 Jul 2022 00:29:56 +0200 Subject: Extract scopes and scope chain from compiler --- pkg/lang/compiler/scope/scopes.go | 50 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100644 pkg/lang/compiler/scope/scopes.go (limited to 'pkg/lang/compiler/scope/scopes.go') diff --git a/pkg/lang/compiler/scope/scopes.go b/pkg/lang/compiler/scope/scopes.go new file mode 100644 index 0000000..39e48ef --- /dev/null +++ b/pkg/lang/compiler/scope/scopes.go @@ -0,0 +1,50 @@ +package scope + +import "jinx/pkg/lang/vm/code" + +type ScopeID int + +type ScopeKind int + +const ( + ScopeKindNormal ScopeKind = iota + ScopeKindFunction +) + +type SymbolScope struct { + variableSymbols []Symbol[SymbolVariable] + functionSymbols []Symbol[SymbolFunction] +} + +func NewSymbolScope() SymbolScope { + return SymbolScope{ + variableSymbols: make([]Symbol[SymbolVariable], 0), + functionSymbols: make([]Symbol[SymbolFunction], 0), + } +} + +type FunctionScope struct { + id ScopeID + unit code.Marker + subUnitCount int +} + +func NewFunctionScope(id ScopeID, unit code.Marker) FunctionScope { + return FunctionScope{ + id: id, + unit: unit, + subUnitCount: 0, + } +} + +func (sf FunctionScope) ID() ScopeID { + return sf.id +} + +func (sf FunctionScope) Unit() code.Marker { + return sf.unit +} + +func (sf FunctionScope) IsRootScope() bool { + return sf.ID() == ScopeID(0) +} -- cgit 1.4.1