vimeta-0.2.5.0: Frontend for video metadata tagging tools

Safe HaskellNone
LanguageHaskell2010

Vimeta.Core.Vimeta

Synopsis

Documentation

newtype Vimeta m a Source #

Constructors

Vimeta 

Fields

Instances
Monad m => MonadReader Context (Vimeta m) Source # 
Instance details

Defined in Vimeta.Core.Vimeta

Methods

ask :: Vimeta m Context #

local :: (Context -> Context) -> Vimeta m a -> Vimeta m a #

reader :: (Context -> a) -> Vimeta m a #

Monad m => Monad (Vimeta m) Source # 
Instance details

Defined in Vimeta.Core.Vimeta

Methods

(>>=) :: Vimeta m a -> (a -> Vimeta m b) -> Vimeta m b #

(>>) :: Vimeta m a -> Vimeta m b -> Vimeta m b #

return :: a -> Vimeta m a #

fail :: String -> Vimeta m a #

Functor m => Functor (Vimeta m) Source # 
Instance details

Defined in Vimeta.Core.Vimeta

Methods

fmap :: (a -> b) -> Vimeta m a -> Vimeta m b #

(<$) :: a -> Vimeta m b -> Vimeta m a #

Monad m => Applicative (Vimeta m) Source # 
Instance details

Defined in Vimeta.Core.Vimeta

Methods

pure :: a -> Vimeta m a #

(<*>) :: Vimeta m (a -> b) -> Vimeta m a -> Vimeta m b #

liftA2 :: (a -> b -> c) -> Vimeta m a -> Vimeta m b -> Vimeta m c #

(*>) :: Vimeta m a -> Vimeta m b -> Vimeta m b #

(<*) :: Vimeta m a -> Vimeta m b -> Vimeta m a #

MonadIO m => MonadIO (Vimeta m) Source # 
Instance details

Defined in Vimeta.Core.Vimeta

Methods

liftIO :: IO a -> Vimeta m a #

data Context Source #

Instances
Monad m => MonadReader Context (Vimeta m) Source # 
Instance details

Defined in Vimeta.Core.Vimeta

Methods

ask :: Vimeta m Context #

local :: (Context -> Context) -> Vimeta m a -> Vimeta m a #

reader :: (Context -> a) -> Vimeta m a #

class Monad m => MonadIO (m :: * -> *) #

Monads in which IO computations may be embedded. Any monad built by applying a sequence of monad transformers to the IO monad will be an instance of this class.

Instances should satisfy the following laws, which state that liftIO is a transformer of monads:

Minimal complete definition

liftIO

Instances
MonadIO IO

Since: base-4.9.0.0

Instance details

Defined in Control.Monad.IO.Class

Methods

liftIO :: IO a -> IO a #

MonadIO TheMovieDB 
Instance details

Defined in Network.API.TheMovieDB.Internal.TheMovieDB

Methods

liftIO :: IO a -> TheMovieDB a #

MonadIO m => MonadIO (Byline m) 
Instance details

Defined in System.Console.Byline.Internal.Byline

Methods

liftIO :: IO a -> Byline m a #

MonadIO m => MonadIO (ResourceT m) 
Instance details

Defined in Control.Monad.Trans.Resource.Internal

Methods

liftIO :: IO a -> ResourceT m a #

MonadIO m => MonadIO (PErrorT m) 
Instance details

Defined in Data.Yaml.Internal

Methods

liftIO :: IO a -> PErrorT m a #

MonadIO m => MonadIO (Vimeta m) # 
Instance details

Defined in Vimeta.Core.Vimeta

Methods

liftIO :: IO a -> Vimeta m a #

MonadIO m => MonadIO (IdentityT m) 
Instance details

Defined in Control.Monad.Trans.Identity

Methods

liftIO :: IO a -> IdentityT m a #

MonadIO m => MonadIO (ExceptT e m) 
Instance details

Defined in Control.Monad.Trans.Except

Methods

liftIO :: IO a -> ExceptT e m a #

(Error e, MonadIO m) => MonadIO (ErrorT e m) 
Instance details

Defined in Control.Monad.Trans.Error

Methods

liftIO :: IO a -> ErrorT e m a #

MonadIO m => MonadIO (ReaderT r m) 
Instance details

Defined in Control.Monad.Trans.Reader

Methods

liftIO :: IO a -> ReaderT r m a #

MonadIO m => MonadIO (ConduitT i o m) 
Instance details

Defined in Data.Conduit.Internal.Conduit

Methods

liftIO :: IO a -> ConduitT i o m a #

MonadIO m => MonadIO (ParsecT s u m) 
Instance details

Defined in Text.Parsec.Prim

Methods

liftIO :: IO a -> ParsecT s u m a #

MonadIO m => MonadIO (Pipe l i o u m) 
Instance details

Defined in Data.Conduit.Internal.Pipe

Methods

liftIO :: IO a -> Pipe l i o u m a #

die :: Monad m => String -> Vimeta m a Source #

Terminate a Vimeta session with an error message.

runIO :: MonadIO m => IO a -> Vimeta m a Source #

tmdb :: MonadIO m => TheMovieDB a -> Vimeta m a Source #

Run a TheMovieDB operation.

verbose :: MonadIO m => Text -> Vimeta m () Source #

execVimetaWithContext :: Context -> Vimeta m a -> m (Either String a) Source #

Very primitive way of running a Vimeta value with the given Context. Mostly useful for running vimeta action within another vimeta action.

execVimeta Source #

Arguments

:: MonadIO m 
=> (Config -> Config)

Modify configuration before running.

-> Vimeta m a

The Vimeta value to execute.

-> m (Either String a)

The result.

Run a Vimeta operation after loading the configuration file from disk.

runVimeta :: MonadIO m => Vimeta m a -> m (Either String a) Source #

Simple wrapper around execVimeta.

ask :: MonadReader r m => m r #

Retrieves the monad environment.

asks #

Arguments

:: MonadReader r m 
=> (r -> a)

The selector function to apply to the environment.

-> m a 

Retrieves a function of the current environment.

liftIO :: MonadIO m => IO a -> m a #

Lift a computation from the IO monad.