aboutsummaryrefslogtreecommitdiff
path: root/bootstrap/src
diff options
context:
space:
mode:
authorBrad Richardson <everythingfunctional@protonmail.com>2020-10-20 14:36:30 -0500
committerBrad Richardson <everythingfunctional@protonmail.com>2020-10-20 14:36:30 -0500
commit0799961cdd047005021549c32d8f8d7731f40d27 (patch)
tree1cf86eaab40ac47e8ed66ec32f58b0479eb66039 /bootstrap/src
parent55590e78dd6df0eac312eaadfc230533adfe0018 (diff)
downloadfpm-0799961cdd047005021549c32d8f8d7731f40d27.tar.gz
fpm-0799961cdd047005021549c32d8f8d7731f40d27.zip
Split submodule name into two components
Diffstat (limited to 'bootstrap/src')
-rw-r--r--bootstrap/src/BuildModel.hs28
1 files changed, 20 insertions, 8 deletions
diff --git a/bootstrap/src/BuildModel.hs b/bootstrap/src/BuildModel.hs
index c6e422b..b8fc537 100644
--- a/bootstrap/src/BuildModel.hs
+++ b/bootstrap/src/BuildModel.hs
@@ -30,7 +30,7 @@ data LineContents =
| ModuleDeclaration String
| ModuleUsed String
| ModuleSubprogramDeclaration
- | SubmoduleDeclaration String
+ | SubmoduleDeclaration String String
| Other
data RawSource = RawSource {
@@ -55,6 +55,7 @@ data Source =
{ submoduleSourceFileName :: FilePath
, submoduleObjectFileName :: FilePath -> FilePath
, submoduleModulesUsed :: [String]
+ , submoduleParentName :: String
, submoduleName :: String
}
@@ -86,11 +87,13 @@ processRawSource rawSource =
, moduleProducesSmod = hasModuleSubprogramDeclaration parsedContents
}
else if hasSubmoduleDeclaration parsedContents
- then Submodule { submoduleSourceFileName = sourceFileName
- , submoduleObjectFileName = objectFileName
- , submoduleModulesUsed = modulesUsed
- , submoduleName = getSubmoduleName parsedContents
- }
+ then Submodule
+ { submoduleSourceFileName = sourceFileName
+ , submoduleObjectFileName = objectFileName
+ , submoduleModulesUsed = modulesUsed
+ , submoduleParentName = getSubmoduleParentName parsedContents
+ , submoduleName = getSubmoduleName parsedContents
+ }
else undefined
constructCompileTimeInfo :: Source -> [String] -> FilePath -> CompileTimeInfo
@@ -178,11 +181,20 @@ getModuleName pc = head $ mapMaybe contentToMaybeModuleName pc
ModuleDeclaration moduleName -> Just moduleName
_ -> Nothing
+getSubmoduleParentName :: [LineContents] -> String
+getSubmoduleParentName pc = head $ mapMaybe contentToMaybeModuleName pc
+ where
+ contentToMaybeModuleName content = case content of
+ SubmoduleDeclaration submoduleParentName submoduleName ->
+ Just submoduleParentName
+ _ -> Nothing
+
getSubmoduleName :: [LineContents] -> String
getSubmoduleName pc = head $ mapMaybe contentToMaybeModuleName pc
where
contentToMaybeModuleName content = case content of
- SubmoduleDeclaration submoduleName -> Just submoduleName
+ SubmoduleDeclaration submoduleParentName submoduleName ->
+ Just submoduleName
_ -> Nothing
readFileLinesIO :: FilePath -> IO [String]
@@ -236,7 +248,7 @@ submoduleDeclaration = do
skipSpaces
name <- validIdentifier
skipSpaceCommentOrEnd
- return $ SubmoduleDeclaration ((intercalate "@" parents) ++ "@" ++ name)
+ return $ SubmoduleDeclaration (intercalate "@" parents) name
submoduleParents :: ReadP [String]
submoduleParents = do