-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathFindConfig.hs
38 lines (33 loc) · 1.24 KB
/
FindConfig.hs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
module FindConfig(findLocalConfigs, localConfigsFileName) where
import Data.List
import System.Directory
import System.FilePath
import System.IO
findLocalConfigs :: FilePath -> IO ()
findLocalConfigs cDir = do
fs <- getDirectoryContents cDir
putStr "\nLooking for local configuration modules... "
let modNames = map dropExtension $ filter (".hs" `isSuffixOf`) fs
let imports = map importStmt $ modNames
let modules = map importAs $ modNames
putStrLn $ "found ("++ (show.length$ modNames)++")"
writeToFile (localConfigsFileName cDir) (imports ++ [modulesList modules])
where
importStmt m = "import qualified "++m++" as " ++importAs m
writeToFile fName contents = do
h <- openFile fName WriteMode
putStrLn $ " writing config manifest to " ++ fName
--putStrLn $ unlines contents
hPutStr h (unlines contents)
hClose h
modulesList :: [String] -> String
modulesList mods = typ ++ lst
where
typ = "localConfigs :: [RunConfig]\n"
lst = "localConfigs = [" ++ (join ", " cfgs) ++ "]"
cfgs = map (++".config") mods
join s = concat . intersperse s
importAs :: String -> String
importAs modName = modName++"_Config"
localConfigsFileName :: FilePath -> FilePath
localConfigsFileName baseDir = baseDir </> "LocalConfigs.txt"