X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2Fdriver%2FPackageSrc.hs;h=6fcec811935923deb127367751df6e5e76e176c0;hb=fb7a723bfd7650a705cb226e07c5b08b7a8e9279;hp=c8a1840504a3d9857f76ca330f6d270cc6df878b;hpb=efc238188e61add0cd2e4c3b82d93f534e14236c;p=ghc-hetmet.git
diff --git a/ghc/driver/PackageSrc.hs b/ghc/driver/PackageSrc.hs
index c8a1840..6fcec81 100644
--- a/ghc/driver/PackageSrc.hs
+++ b/ghc/driver/PackageSrc.hs
@@ -1,29 +1,51 @@
+#include "../includes/config.h"
+#include "../includes/Derived.h"
+
module Main (main) where
+import Utils
+
import IO
import System
-import Config
import Package
main :: IO ()
main = do
args <- getArgs
case args of
- [ "install" ] -> do { putStr (dumpPackages (package_details True)) }
- [ "in-place" ] -> do { putStr (dumpPackages (package_details False)) }
- _ -> do hPutStr stderr "usage: pkgconf (install | in-place)\n"
- exitWith (ExitFailure 1)
+ ("install":rest) -> do { putStrLn (dumpPackages (package_details True rest)) }
+ ("in-place":rest) -> do { putStrLn (dumpPackages (package_details False rest)) }
+ _ -> do hPutStr stderr "usage: pkgconf (install | in-place) ...\n"
+ exitWith (ExitFailure 1)
+
+-- The compiler automatically replaces the string "$libdir" at the
+-- beginning of a path with the directory passed to the compiler via
+-- the -B
flag. Absolute path names will be unchanged.
+--
+-- This is how we make package.conf independent of GHC's installation
+-- location.
+
+package_details :: Bool -> [String] -> [PackageConfig]
+package_details installing
+ [ cTARGETPLATFORM
+ , cCURRENT_DIR
+ , cHaveLibGmp
+ , cLibsReadline
+ , cGHC_LIB_DIR
+ , cGHC_RUNTIME_DIR
+ , cGHC_UTILS_DIR
+ , cGHC_INCLUDE_DIR
+ ] =
-package_details :: Bool -> [(String,Package)]
-package_details installing =
[
- ( "gmp", -- GMP is at the bottom of the heap
Package {
+ name = "gmp", -- GMP is at the bottom of the heap
import_dirs = [],
+ source_dirs = [],
library_dirs = if cHaveLibGmp == "YES"
then []
else if installing
- then [ clibdir ]
+ then [ "$libdir" ]
else [ ghc_src_dir cGHC_RUNTIME_DIR ++ "/gmp" ],
hs_libraries = [],
extra_libraries = [ "gmp" ],
@@ -33,19 +55,32 @@ package_details installing =
extra_ghc_opts = [],
extra_cc_opts = [],
extra_ld_opts = []
- }
- ),
+ },
- ( "rts", -- The RTS is just another package!
Package {
+ name = "rts", -- The RTS is just another package!
import_dirs = [],
+ source_dirs = [],
library_dirs = if installing
- then [ clibdir ]
+ then [ "$libdir" ]
else [ ghc_src_dir cGHC_RUNTIME_DIR ],
hs_libraries = [ "HSrts" ],
- extra_libraries = [],
+ extra_libraries =
+ "m": -- for ldexp()
+#ifdef mingw32_TARGET_OS
+ "winmm": -- for the threadDelay timer
+ "wsock32": -- for the linker
+#endif
+#ifdef USING_LIBBFD
+ "bfd": "iberty": -- for debugging
+#endif
+ [],
include_dirs = if installing
- then [ clibdir ++ "/includes" ]
+ then [ "$libdir/include"
+#ifdef mingw32_TARGET_OS
+ , "$libdir/include/mingw"
+#endif
+ ]
else [ ghc_src_dir cGHC_INCLUDE_DIR ],
c_includes = [ "Stg.h" ], -- ha!
package_deps = [ "gmp" ],
@@ -53,52 +88,77 @@ package_details installing =
extra_cc_opts = [],
-- the RTS forward-references to a bunch of stuff in the prelude,
-- so we force it to be included with special options to ld.
- extra_ld_opts = [
- "-u PrelMain_mainIO_closure"
- , "-u PrelBase_Izh_static_info"
- , "-u PrelBase_Czh_static_info"
- , "-u PrelFloat_Fzh_static_info"
- , "-u PrelFloat_Dzh_static_info"
- , "-u PrelAddr_Azh_static_info"
- , "-u PrelAddr_Wzh_static_info"
- , "-u PrelAddr_I64zh_static_info"
- , "-u PrelAddr_W64zh_static_info"
- , "-u PrelStable_StablePtr_static_info"
- , "-u PrelBase_Izh_con_info"
- , "-u PrelBase_Czh_con_info"
- , "-u PrelFloat_Fzh_con_info"
- , "-u PrelFloat_Dzh_con_info"
- , "-u PrelAddr_Azh_con_info"
- , "-u PrelAddr_Wzh_con_info"
- , "-u PrelAddr_I64zh_con_info"
- , "-u PrelAddr_W64zh_con_info"
- , "-u PrelStable_StablePtr_con_info"
- , "-u PrelBase_False_closure"
- , "-u PrelBase_True_closure"
- , "-u PrelPack_unpackCString_closure"
- , "-u PrelIOBase_stackOverflow_closure"
- , "-u PrelIOBase_heapOverflow_closure"
- , "-u PrelIOBase_NonTermination_closure"
- , "-u PrelIOBase_PutFullMVar_closure"
- , "-u PrelIOBase_BlockedOnDeadMVar_closure"
- , "-u PrelWeak_runFinalizzerBatch_closure"
- , "-u __init_Prelude"
- , "-u __init_PrelMain"
- ]
- }
- ),
+ extra_ld_opts =
+ foldr (\ x xs -> "-u" : x : xs) []
+ (map (
+#ifndef LEADING_UNDERSCORE
+ ""
+#else
+ "_"
+#endif
+ ++ ) [
+ "PrelBase_Izh_static_info"
+ , "PrelBase_Czh_static_info"
+ , "PrelFloat_Fzh_static_info"
+ , "PrelFloat_Dzh_static_info"
+ , "PrelPtr_Ptr_static_info"
+ , "PrelWord_Wzh_static_info"
+ , "PrelInt_I8zh_static_info"
+ , "PrelInt_I16zh_static_info"
+ , "PrelInt_I32zh_static_info"
+ , "PrelInt_I64zh_static_info"
+ , "PrelWord_W8zh_static_info"
+ , "PrelWord_W16zh_static_info"
+ , "PrelWord_W32zh_static_info"
+ , "PrelWord_W64zh_static_info"
+ , "PrelStable_StablePtr_static_info"
+ , "PrelBase_Izh_con_info"
+ , "PrelBase_Czh_con_info"
+ , "PrelFloat_Fzh_con_info"
+ , "PrelFloat_Dzh_con_info"
+ , "PrelPtr_Ptr_con_info"
+ , "PrelStable_StablePtr_con_info"
+ , "PrelBase_False_closure"
+ , "PrelBase_True_closure"
+ , "PrelPack_unpackCString_closure"
+ , "PrelIOBase_stackOverflow_closure"
+ , "PrelIOBase_heapOverflow_closure"
+ , "PrelIOBase_NonTermination_closure"
+ , "PrelIOBase_BlockedOnDeadMVar_closure"
+ , "PrelWeak_runFinalizzerBatch_closure"
+ , "__stginit_Prelude"
+ ])
+ },
- ( "std", -- The Prelude & Standard Hs_libraries
Package {
- import_dirs = if installing
- then [ clibdir ++ "/imports/std" ]
+ name = "std", -- The Prelude & Standard Hs_libraries
+ import_dirs = if installing
+ then [ "$libdir/imports/std" ]
else [ ghc_src_dir cGHC_LIB_DIR ++ "/std" ],
+ source_dirs = [],
library_dirs = if installing
- then [ clibdir ]
+ then [ "$libdir" ]
else [ ghc_src_dir cGHC_LIB_DIR ++ "/std"
, ghc_src_dir cGHC_LIB_DIR ++ "/std/cbits" ],
- hs_libraries = [ "HSstd" ],
- extra_libraries = [ "HSstd_cbits" ],
+
+ hs_libraries =
+# ifndef mingw32_TARGET_OS
+ [ "HSstd" ]
+# else
+ -- This splitting is the subject of a totally
+ -- horrible hack, which glues HSstd1 and HSstd2
+ -- back into HSstd for the purposes of static linking.
+ -- See DriverState.getPackageLibraries for details.
+ [ "HSstd1", "HSstd2" ]
+# endif
+ ,
+ extra_libraries = [ "HSstd_cbits" ] ++
+# ifdef mingw32_TARGET_OS
+ [ "wsock32", "msvcrt" ]
+# else
+ [ ]
+# endif
+ ,
include_dirs = if installing
then []
else [ ghc_src_dir cGHC_LIB_DIR ++ "/std/cbits" ],
@@ -106,183 +166,198 @@ package_details installing =
package_deps = [ "rts" ],
extra_ghc_opts = [],
extra_cc_opts = [],
- extra_ld_opts = [ "-lm" ]
- }
- ),
+ extra_ld_opts = []
+ },
- ( "lang",
Package {
- import_dirs = if installing
- then [ clibdir ++ "/imports/lang" ]
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/lang"
- , cFPTOOLS_TOP_ABS ++ "/hslibs/lang/monads" ],
+ name = "lang",
+ import_dirs = if installing
+ then [ "$libdir/imports/lang" ]
+ else [ "$libdir/hslibs/lang"
+ , "$libdir/hslibs/lang/monads" ],
+ source_dirs = [],
library_dirs = if installing
- then [ clibdir ]
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/lang"
- , cFPTOOLS_TOP_ABS ++ "/hslibs/lang/cbits" ],
+ then [ "$libdir" ]
+ else [ "$libdir/hslibs/lang"
+ , "$libdir/hslibs/lang/cbits" ],
hs_libraries = [ "HSlang" ],
extra_libraries = [ "HSlang_cbits" ],
include_dirs = if installing
then []
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/lang/cbits" ],
+ else [ "$libdir/hslibs/lang/cbits" ],
c_includes = [ "HsLang.h" ],
package_deps = [],
extra_ghc_opts = [],
extra_cc_opts = [],
- extra_ld_opts = []
- }
- ),
+ extra_ld_opts = [
+#ifndef LEADING_UNDERSCORE
+ "-u", "Addr_Azh_static_info"
+#else
+ "-u", "_Addr_Azh_static_info"
+#endif
+ ]
+ },
- ( "concurrent",
Package {
+ name = "concurrent",
import_dirs = if installing
- then [ clibdir ++ "/imports/concurrent" ]
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/concurrent" ],
+ then [ "$libdir/imports/concurrent" ]
+ else [ "$libdir/hslibs/concurrent" ],
+ source_dirs = [],
library_dirs = if installing
- then [ clibdir ]
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/concurrent" ],
+ then [ "$libdir" ]
+ else [ "$libdir/hslibs/concurrent" ],
hs_libraries = [ "HSconcurrent" ],
extra_libraries = [],
include_dirs = if installing
then []
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/concurrent/cbits" ],
- c_includes = [ "HsConcurrent.h" ],
+ else [ "$libdir/hslibs/concurrent/cbits" ],
+ c_includes = [],
package_deps = [ "lang" ],
extra_ghc_opts = [],
extra_cc_opts = [],
extra_ld_opts = []
- }
- ),
+ },
- ( "data",
Package {
+ name = "data",
import_dirs = if installing
- then [ clibdir ++ "/imports/data" ]
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/data"
- , cFPTOOLS_TOP_ABS ++ "/hslibs/data/edison"
- , cFPTOOLS_TOP_ABS ++ "/hslibs/data/edison/Assoc"
- , cFPTOOLS_TOP_ABS ++ "/hslibs/data/edison/Coll"
- , cFPTOOLS_TOP_ABS ++ "/hslibs/data/edison/Seq" ],
+ then [ "$libdir/imports/data" ]
+ else [ "$libdir/hslibs/data"
+ , "$libdir/hslibs/data/edison"
+ , "$libdir/hslibs/data/edison/Assoc"
+ , "$libdir/hslibs/data/edison/Coll"
+ , "$libdir/hslibs/data/edison/Seq" ],
+ source_dirs = [],
library_dirs = if installing
- then [clibdir ]
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/data" ],
+ then [ "$libdir" ]
+ else [ "$libdir/hslibs/data" ],
hs_libraries = [ "HSdata" ],
extra_libraries = [],
include_dirs = if installing
then []
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/data/cbits" ],
- c_includes = [ "HsData.h" ],
- package_deps = [ "lang" ],
+ else [ "$libdir/hslibs/data/cbits" ],
+ c_includes = [],
+ package_deps = [ "lang", "util" ],
extra_ghc_opts = [],
extra_cc_opts = [],
extra_ld_opts = []
- }
- ),
+ },
- ( "net",
Package {
+ name = "net",
import_dirs = if installing
- then [ clibdir ++ "/imports/net" ]
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/net" ],
+ then [ "$libdir/imports/net" ]
+ else [ "$libdir/hslibs/net" ],
+ source_dirs = [],
library_dirs = if installing
- then [ clibdir ]
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/net"
- , cFPTOOLS_TOP_ABS ++ "/hslibs/net/cbits" ],
+ then [ "$libdir" ]
+ else [ "$libdir/hslibs/net"
+ , "$libdir/hslibs/net/cbits" ],
hs_libraries = [ "HSnet" ],
- extra_libraries = [ "HSnet_cbits" ],
+ extra_libraries = if suffixMatch "solaris2" cTARGETPLATFORM
+ then [ "nsl", "socket" ]
+ else []
+ ,
include_dirs = if installing
then []
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/net/cbits" ],
+ else [ "$libdir/hslibs/net/cbits" ],
c_includes = [ "HsNet.h" ],
- package_deps = [ "lang", "text" ],
+ package_deps = [ "lang", "text", "concurrent" ],
extra_ghc_opts = [],
extra_cc_opts = [],
- extra_ld_opts = if postfixMatch "solaris2" cTARGETPLATFORM
- then [ "-lnsl", "-lsocket" ]
- else []
- }
- ),
+ extra_ld_opts = []
+ },
- ( "posix",
Package {
+ name = "posix",
import_dirs = if installing
- then [ clibdir ++ "/imports/posix" ]
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/posix" ],
+ then [ "$libdir/imports/posix" ]
+ else [ "$libdir/hslibs/posix" ],
+ source_dirs = [],
library_dirs = if installing
- then [ clibdir ]
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/posix"
- , cFPTOOLS_TOP_ABS ++ "/hslibs/posix/cbits" ],
+ then [ "$libdir" ]
+ else [ "$libdir/hslibs/posix"
+ , "$libdir/hslibs/posix/cbits" ],
hs_libraries = [ "HSposix" ],
extra_libraries = [ "HSposix_cbits" ],
include_dirs = if installing
then []
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/posix/cbits" ],
+ else [ "$libdir/hslibs/posix/cbits" ],
c_includes = [ "HsPosix.h" ],
package_deps = [ "lang" ],
extra_ghc_opts = [],
extra_cc_opts = [],
extra_ld_opts = []
- }
- ),
+ },
- ( "text",
Package {
+ name = "text",
import_dirs = if installing
- then [ clibdir ++ "/imports/text" ]
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/text"
- , cFPTOOLS_TOP_ABS ++ "/hslibs/text/html"
- , cFPTOOLS_TOP_ABS ++ "/hslibs/text/haxml/lib"
- , cFPTOOLS_TOP_ABS ++ "/hslibs/text/parsec" ],
+ then [ "$libdir/imports/text" ]
+ else [ "$libdir/hslibs/text"
+ , "$libdir/hslibs/text/html"
+ , "$libdir/hslibs/text/HaXml/lib"
+ , "$libdir/hslibs/text/parsec" ],
+ source_dirs = [],
library_dirs = if installing
- then [ clibdir ]
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/text"
- , cFPTOOLS_TOP_ABS ++ "/hslibs/text/cbits" ],
+ then [ "$libdir" ]
+ else [ "$libdir/hslibs/text"
+ , "$libdir/hslibs/text/cbits" ],
hs_libraries = [ "HStext" ],
extra_libraries = [ "HStext_cbits" ],
include_dirs = if installing
then []
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/text/cbits" ],
+ else [ "$libdir/hslibs/text/cbits" ],
c_includes = [ "HsText.h" ],
- package_deps = [ "lang", "data" ],
+ package_deps = [ "lang" ],
extra_ghc_opts = [],
extra_cc_opts = [],
extra_ld_opts = []
- }
- ),
+ },
- ( "util",
Package {
+ name = "util",
import_dirs = if installing
- then [ clibdir ++ "/imports/util" ]
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/util"
- , cFPTOOLS_TOP_ABS ++ "/hslibs/util/check" ],
+ then [ "$libdir/imports/util" ]
+ else [ "$libdir/hslibs/util"
+ , "$libdir/hslibs/util/check" ],
+ source_dirs = [],
library_dirs = if installing
- then [ clibdir ]
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/util"
- , cFPTOOLS_TOP_ABS ++ "/hslibs/util/cbits" ],
+ then [ "$libdir" ]
+ else [ "$libdir/hslibs/util"
+ , "$libdir/hslibs/util/cbits" ],
hs_libraries = [ "HSutil" ],
- extra_libraries = [ "HSutil_cbits" ],
+ extra_libraries = [ "HSutil_cbits" ]
+#ifndef mingw32_TARGET_OS
+ ++ words cLibsReadline
+#endif
+ ,
include_dirs = if installing
then []
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/util/cbits" ],
+ else [ "$libdir/hslibs/util/cbits" ],
c_includes = [ "HsUtil.h" ],
- package_deps = [ "lang", "concurrent", "posix" ],
+ package_deps = [ "lang", "concurrent"
+#ifndef mingw32_TARGET_OS
+ , "posix"
+#endif
+ ],
extra_ghc_opts = [],
extra_cc_opts = [],
extra_ld_opts = []
- }
- ),
+ },
-- no cbits at the moment, we'll need to add one if this library
-- ever calls out to any C libs.
- ( "hssource",
Package {
+ name = "hssource",
import_dirs = if installing
- then [ clibdir ++ "/imports/hssource" ]
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/hssource" ],
+ then [ "$libdir/imports/hssource" ]
+ else [ "$libdir/hslibs/hssource" ],
+ source_dirs = [],
library_dirs = if installing
- then [ clibdir ]
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/hssource" ],
+ then [ "$libdir" ]
+ else [ "$libdir/hslibs/hssource" ],
hs_libraries = [ "HShssource" ],
extra_libraries = [],
include_dirs = [],
@@ -291,56 +366,108 @@ package_details installing =
extra_ghc_opts = [],
extra_cc_opts = [],
extra_ld_opts = []
- }
- ),
+ },
- ( "win32",
Package {
+ name = "greencard",
import_dirs = if installing
- then [ clibdir ++ "/imports/win32" ]
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/win32/src" ],
+ then [ "$libdir/imports/greencard" ]
+ else [ "$libdir/green-card/lib/ghc" ],
+ source_dirs = [],
library_dirs = if installing
- then [ clibdir ]
- else [ cFPTOOLS_TOP_ABS ++ "/hslibs/win32/src" ],
- hs_libraries = [ "HSwin32" ],
- extra_libraries = [],
+ then [ "$libdir" ]
+ else [ "$libdir/green-card/lib/ghc" ],
+ hs_libraries = [ "HSgreencard" ],
+ extra_libraries = [],
include_dirs = [],
- c_includes = [], -- ???
+ c_includes = [],
package_deps = [ "lang" ],
extra_ghc_opts = [],
extra_cc_opts = [],
- extra_ld_opts = [ "-luser32", "-lgdi32" ]
+ extra_ld_opts = [],
}
- ),
- ( "com",
+#if defined(mingw32_TARGET_OS) || defined(cygwin32_TARGET_OS)
+ ,Package {
+ name = "win32",
+ import_dirs = if installing
+ then [ "$libdir/imports/win32" ]
+ else [ "$libdir/hslibs/win32" ],
+ source_dirs = [],
+ library_dirs = if installing
+ then [ "$libdir" ]
+ else [ "$libdir/hslibs/win32" ],
+ hs_libraries = [ "HSwin321", "HSwin322" ],
+ extra_libraries = [ "user32", "gdi32", "winmm",
+ "kernel32", "advapi32" ],
+ include_dirs = [],
+ c_includes = [], -- ???
+ package_deps = [ "lang" ], -- greencard now built in
+ extra_ghc_opts = [],
+ extra_cc_opts = [],
+ extra_ld_opts = []
+ },
+
Package {
+ name = "com",
import_dirs = if installing
- then [ clibdir ++ "/imports/com" ]
- else [ cFPTOOLS_TOP_ABS ++ "/hdirect/lib" ],
+ then [ "$libdir/imports/com" ]
+ else [ "$libdir/hdirect/lib" ],
+ source_dirs = [],
library_dirs = if installing
- then [ clibdir ]
- else [ cFPTOOLS_TOP_ABS ++ "/hdirect/lib" ],
+ then [ "$libdir" ]
+ else [ "$libdir/hdirect/lib" ],
hs_libraries = [ "HScom" ],
- extra_libraries = [],
+ extra_libraries = [ "user32", "ole32", "oleaut32", "advapi32" ],
include_dirs = [],
c_includes = [], -- ???
package_deps = [ "lang" ],
extra_ghc_opts = [],
extra_cc_opts = [],
- extra_ld_opts = [ "-luser32", "-lole32", "-loleaut32", "-ladvapi32" ]
+ extra_ld_opts = []
}
- )
- ]
+#endif
-ghc_src_dir :: String -> String
-ghc_src_dir path = cFPTOOLS_TOP_ABS ++ '/':cCURRENT_DIR ++ '/':path
+ ,Package {
+ name = "xlib",
+ import_dirs = if installing
+ then [ "$libdir/imports/xlib" ]
+ else [ "$libdir/hslibs/xlib" ],
+ source_dirs = [],
+ library_dirs = if installing
+ then [ "$libdir" ]
+ else [ "$libdir/hslibs/xlib"
+ , "$libdir/hslibs/xlib/cbits" ],
+ hs_libraries = [ "HSxlib" ],
+ extra_libraries = [ "HSxlib_cbits", "X11" ],
+ include_dirs = if installing
+ then []
+ else [ "$libdir/hslibs/xlib/cbits" ],
+ c_includes = [ "HsXlib.h" ],
+ package_deps = [ "greencard" ],
+ extra_ghc_opts = [],
+ extra_cc_opts = [],
+ extra_ld_opts = []
+ }
-prefixMatch :: Eq a => [a] -> [a] -> Bool
-prefixMatch [] _str = True
-prefixMatch _pat [] = False
-prefixMatch (p:ps) (s:ss) | p == s = prefixMatch ps ss
- | otherwise = False
+ ,Package {
+ name = "HGL",
+ import_dirs = if installing
+ then [ "$libdir/imports/HGL" ]
+ else [ "$libdir/hslibs/graphics/lib/x11" ],
+ source_dirs = [],
+ library_dirs = [],
+ hs_libraries = [ "HSHGL" ],
+ extra_libraries= [],
+ include_dirs = [],
+ c_includes = [],
+ package_deps = [ "xlib", "concurrent" ],
+ extra_ghc_opts = [],
+ extra_cc_opts = [],
+ extra_ld_opts = []
+ }
-postfixMatch :: String -> String -> Bool
-postfixMatch pat str = prefixMatch (reverse pat) (reverse str)
+ ]
+ where
+ ghc_src_dir :: String -> String
+ ghc_src_dir path = "$libdir/" ++ cCURRENT_DIR ++ '/':path