Това е моят код:
testSplice :: C.Splice Handler
testSplice = return $ C.yieldRuntimeText $ do
return "中文"
И го свързвам с етикет:
splices :: Splices (C.Splice Handler)
splices =
"testSplice" ## testSplice
И го използва на layout.tpl:
<meta charset="UTF-8">
<testSplice/>
И изходът в браузъра е
-�
Какво съм направил грешно?
Съжалявам за закъснението, бях зает известно време и сега се връщам и мисля, че може да не направя въпроса достатъчно конкретен @mightybyte Ето кода, където възниква проблемът, надявам се, че ще направи въпроса по-конкретизиращ:
test.hs:
{-# LANGUAGE OverloadedStrings #-}
import Snap
import Heist
import qualified Heist.Compiled as C
import Data.Monoid
import Control.Monad.Trans.Either
import Data.Maybe
main :: IO ()
main = quickHttpServe site
site :: Snap ()
site =
route [("/", testSnap)]
testSnap :: Snap ()
testSnap = do
hs <- liftIO $ load "template" splices
let runtime = fromJust $ C.renderTemplate hs "test"
builder <-liftIO (fst runtime)
writeBuilder builder
where
splices :: Splices (C.Splice IO)
splices =
"testSplice" ## testSplice
load :: MonadIO n
=> FilePath
-> Splices (C.Splice n)
-> IO (HeistState n)
load baseDir splices = do
tmap <- runEitherT $ do
let t = loadTemplates baseDir
hc = HeistConfig
defaultInterpretedSplices
defaultLoadTimeSplices
splices
mempty
[t]
initHeist hc
either (error . concat) return tmap
testSplice :: C.Splice IO
testSplice = return $ C.yieldRuntimeText $ do return "中文"
шаблон/test.tpl
<html>
<head>
<meta charset="UTF-8">
</head>
<body>
<testSplice/>
</body>
</html>
Сега опитах heist-0.13.0.2 и вече работи добре, страхотна работа Даниел!