shell-conduit-4.7.0: Write shell scripts with Conduit

Safe HaskellNone
LanguageHaskell98

Data.Conduit.Shell.Process

Contents

Description

Reading from the process.

Synopsis

Running scripts

run :: Segment r -> IO r Source #

Run a segment.

Conduit types

text :: (r ~ (), m ~ IO) => ConduitT Text Text m r -> Segment r Source #

Work on the stream as Text values from UTF-8.

bytes :: (a ~ ByteString, m ~ IO) => ConduitT a ByteString m r -> Segment r Source #

Lift a conduit into a segment.

General conduits

conduit :: (a ~ ByteString, m ~ IO) => ConduitT a ByteString m r -> Segment r Source #

Lift a conduit into a segment.

conduitEither :: (a ~ ByteString, m ~ IO) => ConduitT a (Either ByteString ByteString) m r -> Segment r Source #

Lift a conduit into a segment, which can yield stderr.

Running processes

shell :: String -> Segment () Source #

Run a shell command.

proc :: String -> [String] -> Segment () Source #

Run a process command.

($|) :: Segment () -> Segment b -> Segment b infixl 0 Source #

Fuse two segments (either processes or conduits).

data Segment r Source #

A pipeable segment. Either a conduit or a process.

Instances

Monad Segment Source # 

Methods

(>>=) :: Segment a -> (a -> Segment b) -> Segment b #

(>>) :: Segment a -> Segment b -> Segment b #

return :: a -> Segment a #

fail :: String -> Segment a #

Functor Segment Source # 

Methods

fmap :: (a -> b) -> Segment a -> Segment b #

(<$) :: a -> Segment b -> Segment a #

Applicative Segment Source # 

Methods

pure :: a -> Segment a #

(<*>) :: Segment (a -> b) -> Segment a -> Segment b #

liftA2 :: (a -> b -> c) -> Segment a -> Segment b -> Segment c #

(*>) :: Segment a -> Segment b -> Segment b #

(<*) :: Segment a -> Segment b -> Segment a #

Alternative Segment Source # 

Methods

empty :: Segment a #

(<|>) :: Segment a -> Segment a -> Segment a #

some :: Segment a -> Segment [a] #

many :: Segment a -> Segment [a] #

MonadIO Segment Source # 

Methods

liftIO :: IO a -> Segment a #

(~) * r () => ProcessType (Segment r) Source # 

Methods

spr :: String -> [Text] -> Segment r Source #

class ToChunk a where Source #

Used to allow outputting stdout or stderr.

Minimal complete definition

toChunk

tryS :: Exception e => Segment r -> Segment (Either e r) Source #

Try something in a segment.