Проблема:
Я хотел бы иметь возможность интерпретировать любой код на Haskell во время выполнения, а также код, который не связан ни одной строкой.
Сейчас я использую подсказку , чтобы сделать это ниже, что работает с одиночными строками:
html :: String -> IO String
html code = do
r <- runInterpreter $ do
setImports ["Prelude"]
interpret code (as :: () -> String)
case r of
Left err -> return $ show err
Right func -> return $ func()
Пример:
Если code
сверху - \() -> "Hello World"
, это работает.
Но если code
- это что-то вроде этого ниже, мой код сверху не работает : ( Обновление : это работает).
\() -> let concatString :: String -> String -> String
concatString str1 str2 = str1 ++ str2
in concatString "Hello" "World"
Вопрос:
Как интерпретировать многострочные строки Haskell во время выполнения, используя подсказку или любую другую библиотеку?
Обновление
Это работает - я допустил ошибку в исходном выражении (которое я сейчас исправил).