module Text.ValveVKV(parseValveVKV, parseToVKV, fromValveVKV, (.:), (^:), ValveVKV,
ValveKeyValueEntry(KVObject, KVInt, KVString), Pair (Pair), unpair, Context, vkvParser) where
import Text.Parsec
import Text.ValveVKV.Internal
import Text.ValveVKV.Class
import Data.Maybe (mapMaybe)
parseValveVKV :: ValveVKV a => String -> Either String a
parseValveVKV :: String -> Either String a
parseValveVKV String
input =
let parseRes :: Either ParseError [ValveKeyValueEntry]
parseRes = Parsec String () [ValveKeyValueEntry]
-> String -> String -> Either ParseError [ValveKeyValueEntry]
forall s t a.
Stream s Identity t =>
Parsec s () a -> String -> s -> Either ParseError a
parse Parsec String () [ValveKeyValueEntry]
vkvParser String
"" String
input in
case Either ParseError [ValveKeyValueEntry]
parseRes of
Left ParseError
s -> String -> Either String a
forall a b. a -> Either a b
Left (ParseError -> String
forall a. Show a => a -> String
show ParseError
s)
Right [ValveKeyValueEntry]
a ->
let topObj :: ValveKeyValueEntry
topObj = Pair [ValveKeyValueEntry] -> ValveKeyValueEntry
KVObject (String -> [ValveKeyValueEntry] -> Pair [ValveKeyValueEntry]
forall a. String -> a -> Pair a
Pair String
"top" [ValveKeyValueEntry]
a) in
ValveKeyValueEntry -> ValveKeyValueEntry -> Either String a
forall a.
ValveVKV a =>
ValveKeyValueEntry -> ValveKeyValueEntry -> Either String a
fromValveVKV ValveKeyValueEntry
topObj ValveKeyValueEntry
topObj
parseToVKV :: String -> Either ParseError [ValveKeyValueEntry]
parseToVKV :: String -> Either ParseError [ValveKeyValueEntry]
parseToVKV = Parsec String () [ValveKeyValueEntry]
-> String -> String -> Either ParseError [ValveKeyValueEntry]
forall s t a.
Stream s Identity t =>
Parsec s () a -> String -> s -> Either ParseError a
parse Parsec String () [ValveKeyValueEntry]
vkvParser String
""