Использование Haskell для интерпретации многострочных строк кода во время выполнения - PullRequest
0 голосов
/ 12 января 2019

Проблема:

Я хотел бы иметь возможность интерпретировать любой код на 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 во время выполнения, используя подсказку или любую другую библиотеку?


Обновление

Это работает - я допустил ошибку в исходном выражении (которое я сейчас исправил).

1 Ответ

0 голосов
/ 12 января 2019

Я не использовал подсказку, но могу вам сказать, что ваш пример не является допустимым выражением Haskell. where предложения не привязаны к выражениям, они прикреплены к определениям . То есть вы должны иметь знак =, чтобы иметь возможность иметь предложение where.

-- Correct
foo = bar
    where
    bar = baz
        where 
        baz = 42

-- Incorrect
foo = (bar + 1 where bar = 41)

Если вы хотите определить что-то в контексте выражения, вы должны использовать let

let concatString :: String -> String -> String
    concatString str1 str2 = str1 ++ str2
in concatString "Hello" "World"
...