propellor spin

This commit is contained in:
Joey Hess 2014-03-31 01:06:44 -04:00
parent 2383674638
commit 9d348647d9
5 changed files with 69 additions and 62 deletions

View File

@ -5,7 +5,6 @@
--
-- A simple propellor program example:
--
--
-- > import Propellor
-- > import Propellor.CmdLine
-- > import qualified Propellor.Property.File as File
@ -31,12 +30,14 @@ module Propellor (
, module Propellor.Property
, module Propellor.Property.Cmd
, module Propellor.PrivData
, module Propellor.Engine
, module X
) where
import Propellor.Types
import Propellor.Property
import Propellor.Engine
import Propellor.Property.Cmd
import Propellor.PrivData

47
Propellor/Engine.hs Normal file
View File

@ -0,0 +1,47 @@
module Propellor.Engine where
import System.Console.ANSI
import System.Exit
import System.IO
import Propellor.Types
import Utility.Exception
ensureProperty :: Property -> IO Result
ensureProperty = catchDefaultIO FailedChange . propertySatisfy
ensureProperties :: [Property] -> IO ()
ensureProperties ps = do
r <- ensureProperties' [Property "overall" $ ensureProperties' ps]
case r of
FailedChange -> exitWith (ExitFailure 1)
_ -> exitWith ExitSuccess
ensureProperties' :: [Property] -> IO Result
ensureProperties' ps = ensure ps NoChange
where
ensure [] rs = return rs
ensure (l:ls) rs = do
r <- ensureProperty l
clearFromCursorToLineBeginning
setCursorColumn 0
putStr $ propertyDesc l ++ "... "
case r of
FailedChange -> do
setSGR [SetColor Foreground Vivid Red]
putStrLn "failed"
NoChange -> do
setSGR [SetColor Foreground Dull Green]
putStrLn "unchanged"
MadeChange -> do
setSGR [SetColor Foreground Vivid Green]
putStrLn "done"
setSGR []
ensure ls (combineResult r rs)
warningMessage :: String -> IO ()
warningMessage s = do
setSGR [SetColor Foreground Vivid Red]
putStrLn $ "** warning: " ++ s
setSGR []
hFlush stdout

View File

@ -9,7 +9,7 @@ import Data.Maybe
import Control.Monad
import Propellor.Types
import Propellor.Property
import Propellor.Engine
import Utility.Monad
import Utility.PartialPrelude
import Utility.Exception

View File

@ -2,13 +2,10 @@ module Propellor.Property where
import System.Directory
import Control.Monad
import System.Console.ANSI
import System.Exit
import System.IO
import Propellor.Types
import Propellor.Engine
import Utility.Monad
import Utility.Exception
makeChange :: IO () -> IO Result
makeChange a = a >> return MadeChange
@ -82,42 +79,3 @@ check c property = Property (propertyDesc property) $ ifM c
( ensureProperty property
, return NoChange
)
ensureProperty :: Property -> IO Result
ensureProperty = catchDefaultIO FailedChange . propertySatisfy
ensureProperties :: [Property] -> IO ()
ensureProperties ps = do
r <- ensureProperties' [propertyList "overall" ps]
case r of
FailedChange -> exitWith (ExitFailure 1)
_ -> exitWith ExitSuccess
ensureProperties' :: [Property] -> IO Result
ensureProperties' ps = ensure ps NoChange
where
ensure [] rs = return rs
ensure (l:ls) rs = do
r <- ensureProperty l
clearFromCursorToLineBeginning
setCursorColumn 0
putStr $ propertyDesc l ++ "... "
case r of
FailedChange -> do
setSGR [SetColor Foreground Vivid Red]
putStrLn "failed"
NoChange -> do
setSGR [SetColor Foreground Dull Green]
putStrLn "unchanged"
MadeChange -> do
setSGR [SetColor Foreground Vivid Green]
putStrLn "done"
setSGR []
ensure ls (combineResult r rs)
warningMessage :: String -> IO ()
warningMessage s = do
setSGR [SetColor Foreground Vivid Red]
putStrLn $ "** warning: " ++ s
setSGR []
hFlush stdout

View File

@ -1,5 +1,5 @@
Name: propellor
Version: 0.1
Version: 0.1.1
Cabal-Version: >= 1.6
License: GPL
Maintainer: Joey Hess <joey@kitenet.net>
@ -60,6 +60,7 @@ Library
Propellor.Property.User
Propellor.CmdLine
Propellor.PrivData
Propellor.Engine
Propellor.Types
Other-Modules:
Utility.Applicative