From ce7652c6189b289ffbc749dc3d1ffb465c758c01 Mon Sep 17 00:00:00 2001 From: Eugen Wissner Date: Fri, 26 Jul 2024 12:22:07 +0200 Subject: Add types for name analysis --- lib/Language/Elna/SymbolTable.hs | 45 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 lib/Language/Elna/SymbolTable.hs (limited to 'lib/Language/Elna/SymbolTable.hs') diff --git a/lib/Language/Elna/SymbolTable.hs b/lib/Language/Elna/SymbolTable.hs new file mode 100644 index 0000000..a33df44 --- /dev/null +++ b/lib/Language/Elna/SymbolTable.hs @@ -0,0 +1,45 @@ +module Language.Elna.SymbolTable + ( Info(..) + , ParameterInfo(..) + , SymbolTable(..) + , Type(..) + , booleanType + , intType + ) where + +import Data.HashMap.Strict (HashMap) +import Data.Text (Text) +import Data.Vector (Vector) +import Data.Word (Word32) +import Language.Elna.Location (Identifier(..), showArrayType) + +data Type + = PrimitiveType Text + | ArrayType Word32 Type + deriving Eq + +instance Show Type + where + show (PrimitiveType typeName) = show typeName + show (ArrayType elementCount typeName) = showArrayType elementCount typeName + +intType :: Type +intType = PrimitiveType "int" + +booleanType :: Type +booleanType = PrimitiveType "boolean" + +newtype SymbolTable = SymbolTable (HashMap Identifier Info) + deriving (Eq, Show) + +data ParameterInfo = ParameterInfo + { name :: Identifier + , type' :: Type + , isReferenceParameter :: Bool + } deriving (Eq, Show) + +data Info + = TypeInfo Type + | VariableInfo Type Bool + | ProcedureInfo SymbolTable (Vector ParameterInfo) + deriving (Eq, Show) -- cgit v1.2.3