aboutsummaryrefslogtreecommitdiff
path: root/src/Build.hs
diff options
context:
space:
mode:
Diffstat (limited to 'src/Build.hs')
-rw-r--r--src/Build.hs27
1 files changed, 17 insertions, 10 deletions
diff --git a/src/Build.hs b/src/Build.hs
index 813c10e..2febb87 100644
--- a/src/Build.hs
+++ b/src/Build.hs
@@ -88,10 +88,11 @@ buildPrograms programDirectory libraryDirectories sourceExtensions buildDirector
}
$ do
buildDirectory </> "*" <.> "o" %> \objectFile -> do
- let
- sourceFile = fromMaybe
+ let realObjectFile =
+ foldl (</>) "" $ splitDirectories objectFile
+ let sourceFile = fromMaybe
undefined
- (Map.lookup objectFile sourceFileLookupMap)
+ (Map.lookup realObjectFile sourceFileLookupMap)
need [sourceFile]
modulesUsed <- liftIO $ getModulesUsed sourceFile
let
@@ -104,11 +105,14 @@ buildPrograms programDirectory libraryDirectories sourceExtensions buildDirector
includeFlags
flags
["-o", objectFile, sourceFile]
- (`elem` executables) ?> \exe -> do
- let objectFile = map toLower exe -<.> "o"
- need [objectFile]
- need archives
- cmd compiler objectFile archives ["-o", exe] flags
+ (\file ->
+ foldl (</>) "" (splitDirectories file) `elem` executables
+ )
+ ?> \exe -> do
+ let objectFile = map toLower exe -<.> "o"
+ need [objectFile]
+ need archives
+ cmd compiler objectFile archives ["-o", exe] flags
want executables
buildLibrary
@@ -140,9 +144,12 @@ buildLibrary libraryDirectory sourceExtensions buildDirectory compiler flags lib
map (\ext -> buildDirectory </> "*" <.> ext) ["o", "mod"]
&%> \[objectFile, moduleFile] -> do
let
- sourceFile = fromMaybe
+ realObjectFile = foldl (</>) ""
+ $ splitDirectories objectFile
+ let sourceFile = fromMaybe
undefined
- (Map.lookup objectFile sourceFileLookupMap
+ (Map.lookup realObjectFile
+ sourceFileLookupMap
)
need [sourceFile]
modulesUsed <- liftIO $ getModulesUsed sourceFile