aboutsummaryrefslogtreecommitdiff
path: root/CabalHelper/Main.hs
diff options
context:
space:
mode:
authorDaniel Gröber <dxld@darkboxed.org>2015-04-11 20:10:29 +0200
committerDaniel Gröber <dxld@darkboxed.org>2015-04-11 20:10:29 +0200
commitb1b374764fa6040681480e7746505c32e13ab5e7 (patch)
treedbe978d1c70425f3697032730607509a11ebfd8b /CabalHelper/Main.hs
parent9b58cd9fb2596ed2a946cfc545868604131a6c5b (diff)
Add language options query
Diffstat (limited to 'CabalHelper/Main.hs')
-rw-r--r--CabalHelper/Main.hs23
1 files changed, 22 insertions, 1 deletions
diff --git a/CabalHelper/Main.hs b/CabalHelper/Main.hs
index ef3447b..a09a634 100644
--- a/CabalHelper/Main.hs
+++ b/CabalHelper/Main.hs
@@ -92,6 +92,7 @@ usage = do
++" | ghc-options [--with-inplace]\n"
++" | ghc-src-options [--with-inplace]\n"
++" | ghc-pkg-options [--with-inplace]\n"
+ ++" | ghc-lang-options [--with-inplace]\n"
++" | entrypoints\n"
++" | source-dirs\n"
++" ) ...\n"
@@ -103,6 +104,7 @@ commands = [ "print-bli"
, "ghc-options"
, "ghc-src-options"
, "ghc-pkg-options"
+ , "ghc-lang-options"
, "entrypoints"
, "source-dirs"]
@@ -178,7 +180,7 @@ main = do
opts' = mempty {
-- Not really needed but "unexpected package db stack: []"
- ghcOptPackageDBs = [GlobalPackageDB],
+ ghcOptPackageDBs = [GlobalPackageDB, UserPackageDB],
ghcOptCppOptions = ghcOptCppOptions opts,
ghcOptCppIncludePath = ghcOptCppIncludePath opts,
@@ -207,6 +209,25 @@ main = do
in renderGhcOptions' lbi v $ opts' `mappend` adopts
return $ Just $ ChResponseStrings (res ++ [(ChSetupHsName, [])])
+ "ghc-lang-options":flags -> do
+ res <- componentsMap lbi v distdir $ \c clbi bi -> let
+ comp = compiler lbi
+ outdir = componentOutDir lbi c
+ (clbi', adopts) = case flags of
+ ["--with-inplace"] -> (clbi, mempty)
+ [] -> removeInplaceDeps v lbi pd clbi
+ opts = componentGhcOptions v lbi bi clbi' outdir
+
+ opts' = mempty {
+ ghcOptPackageDBs = [GlobalPackageDB, UserPackageDB],
+
+ ghcOptLanguage = ghcOptLanguage opts,
+ ghcOptExtensions = ghcOptExtensions opts,
+ ghcOptExtensionMap = ghcOptExtensionMap opts
+ }
+ in renderGhcOptions' lbi v $ opts' `mappend` adopts
+ return $ Just $ ChResponseStrings (res ++ [(ChSetupHsName, [])])
+
"entrypoints":[] -> do
eps <- componentsMap lbi v distdir $ \c clbi bi ->
return $ componentEntrypoints c