diff options
Diffstat (limited to 'compiler/ghci/ObjLink.hs')
| -rw-r--r-- | compiler/ghci/ObjLink.hs | 47 | 
1 files changed, 29 insertions, 18 deletions
| diff --git a/compiler/ghci/ObjLink.hs b/compiler/ghci/ObjLink.hs index c9cf78cc4d..d5d4980387 100644 --- a/compiler/ghci/ObjLink.hs +++ b/compiler/ghci/ObjLink.hs @@ -9,14 +9,16 @@  -- | Primarily, this module consists of an interface to the C-land  -- dynamic linker.  module ObjLink ( -   initObjLinker,        -- :: IO () -   loadDLL,              -- :: String -> IO (Maybe String) -   loadArchive,          -- :: String -> IO () -   loadObj,              -- :: String -> IO () -   unloadObj,            -- :: String -> IO () -   insertSymbol,         -- :: String -> String -> Ptr a -> IO () -   lookupSymbol,         -- :: String -> IO (Maybe (Ptr a)) -   resolveObjs           -- :: IO SuccessFlag +   initObjLinker,          -- :: IO () +   loadDLL,                -- :: String -> IO (Maybe String) +   loadArchive,            -- :: String -> IO () +   loadObj,                -- :: String -> IO () +   unloadObj,              -- :: String -> IO () +   insertSymbol,           -- :: String -> String -> Ptr a -> IO () +   lookupSymbol,           -- :: String -> IO (Maybe (Ptr a)) +   resolveObjs,            -- :: IO SuccessFlag +   addLibrarySearchPath,   -- :: CFilePath -> IO (Ptr ()) +   removeLibrarySearchPath -- :: Ptr() -> IO Bool    )  where  import Panic @@ -29,7 +31,7 @@ import Foreign.C  import Foreign          ( nullPtr )  import GHC.Exts         ( Ptr(..) )  import System.Posix.Internals ( CFilePath, withFilePath ) -import System.FilePath  ( dropExtension ) +import System.FilePath  ( dropExtension, normalise )  -- --------------------------------------------------------------------------- @@ -75,7 +77,7 @@ loadDLL str0 = do       str | isWindowsHost = dropExtension str0           | otherwise     = str0    -- -  maybe_errmsg <- withFilePath str $ \dll -> c_addDLL dll +  maybe_errmsg <- withFilePath (normalise str) $ \dll -> c_addDLL dll    if maybe_errmsg == nullPtr          then return Nothing          else do str <- peekCString maybe_errmsg @@ -99,6 +101,13 @@ unloadObj str =       r <- c_unloadObj c_str       when (r == 0) (panic ("unloadObj " ++ show str ++ ": failed")) +addLibrarySearchPath :: String -> IO (Ptr ()) +addLibrarySearchPath str = +   withFilePath str c_addLibrarySearchPath + +removeLibrarySearchPath :: Ptr () -> IO Bool +removeLibrarySearchPath = c_removeLibrarySearchPath +  resolveObjs :: IO SuccessFlag  resolveObjs = do     r <- c_resolveObjs @@ -108,11 +117,13 @@ resolveObjs = do  -- Foreign declarations to RTS entry points which does the real work;  -- --------------------------------------------------------------------------- -foreign import ccall unsafe "addDLL"       c_addDLL :: CFilePath -> IO CString -foreign import ccall unsafe "initLinker"   initObjLinker :: IO () -foreign import ccall unsafe "insertSymbol" c_insertSymbol :: CFilePath -> CString -> Ptr a -> IO () -foreign import ccall unsafe "lookupSymbol" c_lookupSymbol :: CString -> IO (Ptr a) -foreign import ccall unsafe "loadArchive"  c_loadArchive :: CFilePath -> IO Int -foreign import ccall unsafe "loadObj"      c_loadObj :: CFilePath -> IO Int -foreign import ccall unsafe "unloadObj"    c_unloadObj :: CFilePath -> IO Int -foreign import ccall unsafe "resolveObjs"  c_resolveObjs :: IO Int +foreign import ccall unsafe "addDLL"                  c_addDLL                  :: CFilePath -> IO CString +foreign import ccall unsafe "initLinker"              initObjLinker             :: IO () +foreign import ccall unsafe "insertSymbol"            c_insertSymbol            :: CFilePath -> CString -> Ptr a -> IO () +foreign import ccall unsafe "lookupSymbol"            c_lookupSymbol            :: CString -> IO (Ptr a) +foreign import ccall unsafe "loadArchive"             c_loadArchive             :: CFilePath -> IO Int +foreign import ccall unsafe "loadObj"                 c_loadObj                 :: CFilePath -> IO Int +foreign import ccall unsafe "unloadObj"               c_unloadObj               :: CFilePath -> IO Int +foreign import ccall unsafe "resolveObjs"             c_resolveObjs             :: IO Int +foreign import ccall unsafe "addLibrarySearchPath"    c_addLibrarySearchPath    :: CFilePath -> IO (Ptr ()) +foreign import ccall unsafe "removeLibrarySearchPath" c_removeLibrarySearchPath :: Ptr() -> IO Bool | 
