为什么这段代码会产生段错?

时间:2012-12-25 03:54:46

标签: xml json haskell segmentation-fault aeson

我正在尝试编写一个从api解析xml的模块,删除一些信息,并将结果打印为json,但我在打印步骤中遇到了打嗝。如果我打印节目我确实看到了正确的数据,但是,应该将记录转换为json encode shows的调用会产生段错误。

{-# LANGUAGE Arrows, NoMonomorphismRestriction, OverloadedStrings #-}
import Network.HTTP
import Text.XML.HXT.Core
import Data.Aeson
import qualified Data.ByteString.Lazy.Char8 as LazyByteString

openUrl :: String -> IO String
openUrl url = getResponseBody =<< simpleHTTP (getRequest url)

composeSearch :: String -> String
composeSearch query = "http://services.tvrage.com/feeds/search.php?show=" ++ urlEncode query

searchShow :: String -> IO String
searchShow query = openUrl $ composeSearch query

data TvShow = TvShow { showName, showId :: String } deriving (Show)

getShow = deep (isElem >>> hasName "show") >>>
    proc x -> do
        name <- getText <<< getChildren <<< deep (hasName "name")  -< x
        id <- getText <<< getChildren <<< deep (hasName "showid") -< x 
        returnA -< TvShow { showName = name, showId = id }

instance ToJSON TvShow where
    toJSON (TvShow name id) = object ["name" .= name, "id" .= id]

main :: IO ()
main = do
    results <- searchShow "Always Sunny" 
    shows <- runX (readString [ withValidate  no ] results >>> getShow)
    putStrLn (LazyByteString.unpack (encode shows))

编辑:正如user1891025所指出的,这可能是我的机器或软件包版本的问题。

  • 系统:Ubuntu 11.04 32位
  • Aeson v0.6.1.0
  • GHC v7.2.1

这个问题越来越具体,所以我会把它带到irc,但如果有人有任何帮助,请告诉我!

1 个答案:

答案 0 :(得分:0)

Aeson的encode函数从encodeUtf8包中调用Data.Text。该函数使用unsafeDupablePerformIO和其他不安全的函数在内存中查找。这可能是发生段错误的地方。

请参阅代码here