{- This file is part of the Haskell package playlists. It is subject to the license terms in the LICENSE file found in the top-level directory of this distribution and at git://pmade.com/playlists/LICENSE. No part of playlists package, including this file, may be copied, modified, propagated, or distributed except according to the terms contained in the LICENSE file. -} -------------------------------------------------------------------------------- module Text.Playlist.M3U.Writer (writePlaylist) where -------------------------------------------------------------------------------- import Data.ByteString.Lazy.Builder (Builder) import qualified Data.ByteString.Lazy.Builder as B import Data.Monoid import Data.Text (Text) import Data.Text.Encoding (encodeUtf8) import Text.Playlist.Types -------------------------------------------------------------------------------- writePlaylist :: Playlist -> Builder writePlaylist x = B.byteString "#EXTM3U\n" <> mconcat (map writeTrack x) -------------------------------------------------------------------------------- writeTrack :: Track -> Builder writeTrack x = writeTitle (trackTitle x) <> B.byteString (encodeUtf8 $ trackURL x) <> B.charUtf8 '\n' -------------------------------------------------------------------------------- writeTitle :: Maybe Text -> Builder writeTitle Nothing = mempty writeTitle (Just x) = B.byteString "#EXTINF:-1," <> B.byteString (encodeUtf8 x) <> B.charUtf8 '\n'