2022-01-18 14:25:42 +03:00
|
|
|
module Main (main) where
|
|
|
|
|
2022-05-18 18:10:10 +03:00
|
|
|
import App
|
2022-09-14 17:16:15 +03:00
|
|
|
import CommonOptions
|
2022-04-05 20:57:21 +03:00
|
|
|
import Control.Exception qualified as IO
|
2022-07-29 14:35:48 +03:00
|
|
|
import Data.ByteString qualified as ByteString
|
|
|
|
import Data.Yaml
|
2022-08-03 14:20:40 +03:00
|
|
|
import Juvix.Compiler.Pipeline
|
2022-08-11 11:45:54 +03:00
|
|
|
import Juvix.Extra.Paths qualified as Paths
|
2022-09-14 17:16:15 +03:00
|
|
|
import TopCommand
|
|
|
|
import TopCommand.Options
|
2022-03-25 02:52:30 +03:00
|
|
|
|
2022-09-14 17:16:15 +03:00
|
|
|
main :: IO ()
|
|
|
|
main = do
|
|
|
|
let p = prefs showHelpOnEmpty
|
|
|
|
(global, cli) <- customExecParser p descr >>= secondM makeAbsPaths
|
|
|
|
(root, pkg) <- findRoot cli
|
|
|
|
runM (runAppIO global root pkg (runTopCommand cli))
|
|
|
|
|
|
|
|
findRoot :: TopCommand -> IO (FilePath, Package)
|
|
|
|
findRoot cli = do
|
2022-06-09 17:36:07 +03:00
|
|
|
let dir :: Maybe FilePath
|
2022-09-14 17:16:15 +03:00
|
|
|
dir = takeDirectory <$> topCommandInputFile cli
|
2022-06-09 17:36:07 +03:00
|
|
|
whenJust dir setCurrentDirectory
|
2022-07-29 14:35:48 +03:00
|
|
|
r <- IO.try go
|
2022-04-01 13:32:15 +03:00
|
|
|
case r of
|
2022-07-29 14:35:48 +03:00
|
|
|
Left (err :: IO.SomeException) -> do
|
2022-04-01 13:32:15 +03:00
|
|
|
putStrLn "Something went wrong when figuring out the root of the project."
|
|
|
|
putStrLn (pack (IO.displayException err))
|
2022-07-29 14:35:48 +03:00
|
|
|
exitFailure
|
2022-04-01 13:32:15 +03:00
|
|
|
Right root -> return root
|
|
|
|
where
|
2022-04-05 20:57:21 +03:00
|
|
|
possiblePaths :: FilePath -> [FilePath]
|
|
|
|
possiblePaths start = takeWhile (/= "/") (aux start)
|
|
|
|
where
|
|
|
|
aux f = f : aux (takeDirectory f)
|
2022-06-09 17:36:07 +03:00
|
|
|
|
2022-07-29 14:35:48 +03:00
|
|
|
go :: IO (FilePath, Package)
|
2022-04-05 20:57:21 +03:00
|
|
|
go = do
|
|
|
|
c <- getCurrentDirectory
|
2022-08-11 11:45:54 +03:00
|
|
|
l <- findFile (possiblePaths c) Paths.juvixYamlFile
|
2022-04-05 20:57:21 +03:00
|
|
|
case l of
|
2022-07-29 14:35:48 +03:00
|
|
|
Nothing -> return (c, emptyPackage)
|
|
|
|
Just yaml -> do
|
|
|
|
bs <- ByteString.readFile yaml
|
|
|
|
let isEmpty = ByteString.null bs
|
|
|
|
pkg <-
|
|
|
|
if
|
|
|
|
| isEmpty -> return emptyPackage
|
|
|
|
| otherwise -> decodeThrow bs
|
|
|
|
return (takeDirectory yaml, pkg)
|