hasql/library/Hasql/Commands.hs
Nikita Volkov 7954c8d734 Semigroup
2016-02-23 09:43:07 +03:00

34 lines
785 B
Haskell

module Hasql.Commands
(
Commands,
asBytes,
setEncodersToUTF8,
setMinClientMessagesToWarning,
)
where
import Hasql.Prelude
import qualified Data.ByteString as B
import qualified Data.ByteString.Lazy.Builder as BB
import qualified Data.ByteString.Lazy.Builder.ASCII as BB
import qualified Data.ByteString.Lazy as BL
newtype Commands =
Commands (DList BB.Builder)
deriving (Monoid)
instance Semigroup Commands
asBytes :: Commands -> ByteString
asBytes (Commands list) =
BL.toStrict $ BB.toLazyByteString $ foldMap (<> BB.char7 ';') $ list
setEncodersToUTF8 :: Commands
setEncodersToUTF8 =
Commands (pure "SET client_encoding = 'UTF8'")
setMinClientMessagesToWarning :: Commands
setMinClientMessagesToWarning =
Commands (pure "SET client_min_messages TO WARNING")