-- Hoogle documentation, generated by Haddock
-- See Hoogle, http://www.haskell.org/hoogle/


-- | Parsers and printers for bencoded data.
--   
--   Parsers and printers for bencoded data. Bencode (pronounced like B
--   encode) is the encoding used by the peer-to-peer file sharing system
--   BitTorrent for storing and transmitting loosely structured data.
@package bencode
@version 0.6.1.1


module Data.BEncode.Lexer
data Token
TDict :: Token
TList :: Token
TInt :: Token
TString :: ByteString -> Token
TNumber :: Integer -> Token
TEnd :: Token
lexer :: ByteString -> [Token]
instance GHC.Classes.Eq Data.BEncode.Lexer.Token
instance GHC.Show.Show Data.BEncode.Lexer.Token


-- | Provides a BEncode data type is well as functions for converting this
--   data type to and from a String.
--   
--   Also supplies a number of properties which the module must satisfy.
module Data.BEncode

-- | The B-coding defines an abstract syntax tree given as a simple data
--   type here
data BEncode
BInt :: Integer -> BEncode
BString :: ByteString -> BEncode
BList :: [BEncode] -> BEncode
BDict :: Map String BEncode -> BEncode

-- | bRead is a conversion routine. It assumes a B-coded string as input
--   and attempts a parse of it into a BEncode data type
bRead :: ByteString -> Maybe BEncode

-- | Render a BEncode structure to a B-coded string
bShow :: BEncode -> ShowS
bPack :: BEncode -> ByteString
instance GHC.Show.Show Data.BEncode.BEncode
instance GHC.Classes.Ord Data.BEncode.BEncode
instance GHC.Classes.Eq Data.BEncode.BEncode
instance Data.Binary.Class.Binary Data.BEncode.BEncode


-- | A parsec style parser for BEncoded data

-- | <i>Deprecated: Use <a>Data.BEncode.Reader</a> instead</i>
module Data.BEncode.Parser
data BParser a
runParser :: BParser a -> BEncode -> Either String a
token :: BParser BEncode
dict :: String -> BParser BEncode
list :: String -> BParser a -> BParser [a]
optional :: BParser a -> BParser (Maybe a)
bstring :: BParser BEncode -> BParser String
bbytestring :: BParser BEncode -> BParser ByteString
bint :: BParser BEncode -> BParser Integer
setInput :: BEncode -> BParser ()

-- | An associative binary operation
(<|>) :: Alternative f => f a -> f a -> f a
infixl 3 <|>
instance GHC.Base.Alternative Data.BEncode.Parser.BParser
instance GHC.Base.MonadPlus Data.BEncode.Parser.BParser
instance GHC.Base.Applicative Data.BEncode.Parser.BParser
instance GHC.Base.Monad Data.BEncode.Parser.BParser
instance Control.Monad.Fail.MonadFail Data.BEncode.Parser.BParser
instance GHC.Base.Functor Data.BEncode.Parser.BParser


-- | Reader monad and combinators for BEncoded data.
--   
--   This is intended to replace the older <a>Data.BEncode.Parser</a>
--   module.
--   
--   Usage example:
--   
--   <pre>
--   &gt;&gt;&gt; :set -XOverloadedStrings
--   
--   &gt;&gt;&gt; let bd = (BDict $ Map.fromList [("baz", BInt 1), ("foo", BString "bar")])
--   
--   &gt;&gt;&gt; :{
--   let bReader = do
--         baz &lt;- dict "baz" bint
--         foo &lt;- dict "foo" bstring
--         shouldBeNothing &lt;- optional $ dict "optionalKey" bint
--         return (foo, baz, shouldBeNothing)
--   in runBReader bReader bd
--   :}
--   Right ("bar",1,Nothing)
--   </pre>
module Data.BEncode.Reader

-- | Reader monad for extracting data from a BEncoded structure.
data BReader a

-- | Run a BReader. See usage examples elsewhere in this file.
runBReader :: BReader a -> BEncode -> Either String a

-- | <pre>
--   &gt;&gt;&gt; runBReader bint (BInt 42)
--   Right 42
--   </pre>
bint :: BReader Integer

-- | Usage same as bstring, below. (sadly, doctests for this cause errors
--   on GHC 7.4)
bbytestring :: BReader ByteString

-- | <pre>
--   &gt;&gt;&gt; runBReader bstring (BString "foo")
--   Right "foo"
--   </pre>
bstring :: BReader String

-- | One or none.
--   
--   It is useful for modelling any computation that is allowed to fail.
--   
--   <h4><b>Examples</b></h4>
--   
--   Using the <a>Alternative</a> instance of <a>Control.Monad.Except</a>,
--   the following functions:
--   
--   <pre>
--   &gt;&gt;&gt; import Control.Monad.Except
--   </pre>
--   
--   <pre>
--   &gt;&gt;&gt; canFail = throwError "it failed" :: Except String Int
--   
--   &gt;&gt;&gt; final = return 42                :: Except String Int
--   </pre>
--   
--   Can be combined by allowing the first function to fail:
--   
--   <pre>
--   &gt;&gt;&gt; runExcept $ canFail *&gt; final
--   Left "it failed"
--   
--   &gt;&gt;&gt; runExcept $ optional canFail *&gt; final
--   Right 42
--   </pre>
optional :: Alternative f => f a -> f (Maybe a)

-- | Read a list of BEncoded data
--   
--   <pre>
--   &gt;&gt;&gt; runBReader (list bint) (BList [BInt 1, BInt 2])
--   Right [1,2]
--   </pre>
--   
--   <pre>
--   &gt;&gt;&gt; runBReader (list bint) (BList [])
--   Right []
--   </pre>
--   
--   <pre>
--   &gt;&gt;&gt; let bs = (BList [BList [BString "foo", BString "bar"], BList []])
--   
--   &gt;&gt;&gt; runBReader (list $ list bstring) bs
--   Right [["foo","bar"],[]]
--   </pre>
list :: BReader a -> BReader [a]

-- | Read the values of a BDict corresponding to a string key
--   
--   <pre>
--   &gt;&gt;&gt; let bd = (BDict $ Map.fromList [("bar", BInt 2), ("foo", BInt 1)])
--   
--   &gt;&gt;&gt; runBReader (dict "foo" bint) bd
--   Right 1
--   </pre>
--   
--   <pre>
--   &gt;&gt;&gt; :{
--   let bs = (BList [BDict $ Map.fromList [("baz", BInt 2),
--                                          ("foo", BString "bar")],
--                    BDict $ Map.singleton "foo" (BString "bam")])
--   in runBReader (list $ dict "foo" bstring) bs
--   :}
--   Right ["bar","bam"]
--   </pre>
--   
--   <pre>
--   &gt;&gt;&gt; :{
--   let bd = (BDict $ Map.singleton "foo" (BList [
--               BString "foo", BString "bar"
--            ]))
--   in runBReader (dict "foo" $ list $ bstring) bd
--   :}
--   Right ["foo","bar"]
--   </pre>
dict :: String -> BReader a -> BReader a
instance GHC.Base.MonadPlus Data.BEncode.Reader.BReader
instance GHC.Base.Monad Data.BEncode.Reader.BReader
instance GHC.Base.Alternative Data.BEncode.Reader.BReader
instance GHC.Base.Applicative Data.BEncode.Reader.BReader
instance GHC.Base.Functor Data.BEncode.Reader.BReader
