ghc 7.4.2,动态调用模块

Xin*_*nus 11 haskell dynamic-loading ghc

我正在尝试动态加载和执行模块,

以下是我的代码

TestModule.hs

module TestModule
        where

evaluate = "Hello !!!"
Run Code Online (Sandbox Code Playgroud)

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'
Run Code Online (Sandbox Code Playgroud)

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
Run Code Online (Sandbox Code Playgroud)

当我尝试运行该程序时,它会向我显示以下错误

[root@vps mypproj]# ./Main2 
Main2: <command line>: module is not loaded: `TestModule' (./TestModule.hs)
Run Code Online (Sandbox Code Playgroud)

不确定我错过了什么,有人可以帮我解决这个错误

Mar*_*ver 1

我的想法是问题与您的路径有关,并且程序在无法加载“TestModule”时会默默地出错,然后抱怨模块未加载。您是否尝试过将 execFnGhc 与已加载的模块一起使用,并且是否尝试过自然加载 GHC 中的模块(例如 Text.Parsec),然后在其中执行某些操作?

我会测试自己,但我在任何地方都没有看到 GHC.Paths 库:/。