Ich versuche Modul dynamisch zu laden und auszuführen,ghc 7.4.2, dynamisch aufrufen Module
Unten ist mein Code
TestModule.hs
module TestModule
where
evaluate = "Hello !!!"
Invoke.hs
module Invoke
where
import GHC
import DynFlags
import GHC.Paths (libdir)
import Unsafe.Coerce (unsafeCoerce)
import Data.Dynamic
execFnGhc :: String -> String -> Ghc a
execFnGhc modname fn = do
mod <- findModule (mkModuleName modname) Nothing
--setContext [IIModule mod]
GHC.setContext [ GHC.IIDecl $ (GHC.simpleImportDecl . GHC.mkModuleName $ modname) {GHC.ideclQualified = True} ]
value <- compileExpr (modname ++ "." ++ fn)
let value' = (unsafeCoerce value) :: a
return value'
Main2.hs
import GHC.Paths (libdir)
import GHC
import Invoke
-- import TestModule
main :: IO()
main = runGhc (Just libdir) $ do
str <- execFnGhc "TestModule" "evaluate"
return str
Wenn ich versuche, das Programm auszuführen es mir zeigen, unter Fehler
[[email protected] mypproj]# ./Main2
Main2: <command line>: module is not loaded: `TestModule' (./TestModule.hs)
nicht sicher, was mir fehlt, kann mir bitte jemand diesen Fehler beheben helfen
Ich weiß nicht viel darüber, aber es scheint, als ob Sie das viel einfacher mit den [plugins] (http: //hackage.haskell. org/Paket/Plugins) Paket. – Almanildo