module GitHUD (
githud
) where
import Control.Monad (when)
import Control.Monad.Reader (runReader)
import Data.Text
import System.Environment (getArgs)
import System.Posix.Files (fileExist)
import System.Posix.User (getRealUserID, getUserEntryForID, UserEntry(..))
import GitHUD.Config.Parse
import GitHUD.Config.Types
import GitHUD.Terminal.Prompt
import GitHUD.Terminal.Types
import GitHUD.Git.Parse.Base
import GitHUD.Git.Command
import GitHUD.Types
githud :: IO ()
githud = do
isGit <- checkInGitDirectory
when isGit $ do
shell <- processArguments getArgs
config <- getAppConfig
repoState <- getGitRepoState
let prompt = runReader buildPromptWithConfig $ buildOutputConfig shell repoState config
putStrLn $ unpack (strip (pack prompt))
processArguments :: IO [String]
-> IO Shell
processArguments args = do
arguments <- args
return $ getShell arguments
getShell :: [String]
-> Shell
getShell ("zsh":_) = ZSH
getShell ("bash":_) = BASH
getShell _ = Other
getAppConfig :: IO Config
getAppConfig = do
userEntry <- getRealUserID >>= getUserEntryForID
let configFilePath = (homeDirectory userEntry) ++ "/.githudrc"
configFilePresent <- fileExist configFilePath
if configFilePresent
then parseConfigFile configFilePath
else return defaultConfig