+{-
+ - Copyright (C) 2015-2016 Ramakrishnan Muthukrishnan <ram@rkrishnan.org>
+ -
+ - This file is part of FuncTorrent.
+ -
+ - FuncTorrent is free software; you can redistribute it and/or modify
+ - it under the terms of the GNU General Public License as published by
+ - the Free Software Foundation; either version 3 of the License, or
+ - (at your option) any later version.
+ -
+ - FuncTorrent is distributed in the hope that it will be useful,
+ - but WITHOUT ANY WARRANTY; without even the implied warranty of
+ - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ - GNU General Public License for more details.
+ -
+ - You should have received a copy of the GNU General Public License
+ - along with FuncTorrent; if not, see <http://www.gnu.org/licenses/>
+ -}
+
+{-# LANGUAGE OverloadedStrings #-}
module FuncTorrent.Metainfo
(Info(..),
Metainfo(..),
- mkInfo,
torrentToMetainfo
) where
, md5sum :: !(Maybe String)
} deriving (Eq, Show)
-data Metainfo = Metainfo { info :: !Info
+data Metainfo = Metainfo { info :: !(Maybe Info)
, announceList :: ![String]
, creationDate :: !(Maybe Integer)
, comment :: !(Maybe String)
mkMetaInfo :: BVal -> Either String Metainfo
mkMetaInfo (Bdict m) =
- let (Just info') = mkInfo $ m ! "info"
+ let info' = mkInfo $ m ! "info"
announce' = lookup "announce" m
announceList' = lookup "announce-list" m
creationDate' = lookup "creation date" m
, encoding = bstrToString =<< encoding'
, infoHash = hash . encode $ (m ! "info")
}
-
mkMetaInfo _ = Left "mkMetaInfo: expect an input dict"
getAnnounceList :: Maybe BVal -> [String]
[Bstr s''] -> unpack s''
_ -> ""
_ -> "") l
-
getAnnounceList (Just (Bdict _)) = []
torrentToMetainfo :: ByteString -> Either String Metainfo
torrentToMetainfo s =
- case (decode s) of
- Right d ->
- mkMetaInfo d
- Left e ->
- Left $ show e
+ case decode s of
+ Right d -> mkMetaInfo d
+ Left e -> Left $ show e