module Text.Feed.Export
( Text.Feed.Export.xmlFeed
, Text.Feed.Export.textFeed
, Text.Feed.Export.textFeedWith
) where
import Prelude.Compat
import Text.Feed.Types
import qualified Data.Text.Util as U
import Text.Atom.Feed.Export as Atom
import Text.RSS.Export as RSS
import Text.RSS1.Export as RSS1
import qualified Data.Text.Lazy as TL
import Data.XML.Types as XML
import Text.XML (RenderSettings)
xmlFeed :: Feed -> XML.Element
xmlFeed :: Feed -> Element
xmlFeed Feed
fe =
case Feed
fe of
AtomFeed Feed
f -> Feed -> Element
Atom.xmlFeed Feed
f
RSSFeed RSS
f -> RSS -> Element
RSS.xmlRSS RSS
f
RSS1Feed Feed
f -> Feed -> Element
RSS1.xmlFeed Feed
f
XMLFeed Element
e -> Element
e
textFeed :: Feed -> Maybe TL.Text
textFeed :: Feed -> Maybe Text
textFeed = (Feed -> Element) -> Feed -> Maybe Text
forall a. (a -> Element) -> a -> Maybe Text
U.renderFeed Feed -> Element
Text.Feed.Export.xmlFeed
textFeedWith :: RenderSettings -> Feed -> Maybe TL.Text
textFeedWith :: RenderSettings -> Feed -> Maybe Text
textFeedWith RenderSettings
settings = RenderSettings -> (Feed -> Element) -> Feed -> Maybe Text
forall a. RenderSettings -> (a -> Element) -> a -> Maybe Text
U.renderFeedWith RenderSettings
settings Feed -> Element
Text.Feed.Export.xmlFeed