Hook up the command line flags to the serf.

This commit is contained in:
Elliot Glaysher 2019-10-02 11:50:03 -07:00
parent ea2be11f7c
commit 1dd90f310b
2 changed files with 41 additions and 22 deletions

View File

@ -20,7 +20,7 @@ data Opts = Opts
, oDryRun :: Bool , oDryRun :: Bool
, oVerbose :: Bool , oVerbose :: Bool
, oAmesPort :: Maybe Word16 , oAmesPort :: Maybe Word16
, oProf :: Bool , oTrace :: Bool
, oCollectFx :: Bool , oCollectFx :: Bool
, oLocalhost :: Bool , oLocalhost :: Bool
, oOffline :: Bool , oOffline :: Bool
@ -212,9 +212,9 @@ opts = do
<> help "Dry run -- Don't persist" <> help "Dry run -- Don't persist"
<> hidden <> hidden
oProf <- switch $ short 'p' oTrace <- switch $ short 't'
<> long "profile" <> long "trace"
<> help "Enable profiling" <> help "Enable tracing"
<> hidden <> hidden
oLocalhost <- switch $ short 'L' oLocalhost <- switch $ short 'L'

View File

@ -87,7 +87,7 @@ import UrbitPrelude
import Arvo import Arvo
import Data.Acquire import Data.Acquire
import Data.Conduit import Data.Conduit
import Data.Conduit.List hiding (replicate, take) import Data.Conduit.List hiding (catMaybes, replicate, take)
import Data.RAcquire import Data.RAcquire
import Noun hiding (Parser) import Noun hiding (Parser)
import Noun.Atom import Noun.Atom
@ -134,9 +134,25 @@ removeFileIfExists pax = do
-------------------------------------------------------------------------------- --------------------------------------------------------------------------------
toSerfFlags :: CLI.Opts -> Serf.Flags
toSerfFlags CLI.Opts{..} = catMaybes m
where
-- TODO: This is not all the flags.
m = [ from oQuiet Serf.Quiet
, from oTrace Serf.Trace
, from oHashless Serf.Hashless
, from oQuiet Serf.Quiet
, from oVerbose Serf.Verbose
, from oDryRun Serf.DryRun
]
from True flag = Just flag
from False _ = Nothing
tryBootFromPill :: HasLogFunc e tryBootFromPill :: HasLogFunc e
=> FilePath -> FilePath -> Ship -> LegacyBootEvent -> RIO e () => FilePath -> FilePath -> Serf.Flags -> Ship -> LegacyBootEvent
tryBootFromPill pillPath shipPath ship boot = do -> RIO e ()
tryBootFromPill pillPath shipPath flags ship boot = do
rwith bootedPier $ \(serf, log, ss) -> do rwith bootedPier $ \(serf, log, ss) -> do
logTrace "Booting" logTrace "Booting"
logTrace $ displayShow ss logTrace $ displayShow ss
@ -147,7 +163,7 @@ tryBootFromPill pillPath shipPath ship boot = do
where where
bootedPier = do bootedPier = do
lockFile shipPath lockFile shipPath
Pier.booted pillPath shipPath [] ship boot Pier.booted pillPath shipPath flags ship boot
runAcquire :: (MonadUnliftIO m, MonadIO m) runAcquire :: (MonadUnliftIO m, MonadIO m)
=> Acquire a -> m a => Acquire a -> m a
@ -157,17 +173,17 @@ runRAcquire :: (MonadUnliftIO (m e), MonadIO (m e), MonadReader e (m e))
=> RAcquire e a -> m e a => RAcquire e a -> m e a
runRAcquire act = rwith act pure runRAcquire act = rwith act pure
tryPlayShip :: HasLogFunc e => FilePath -> RIO e () tryPlayShip :: HasLogFunc e => FilePath -> Serf.Flags -> RIO e ()
tryPlayShip shipPath = do tryPlayShip shipPath flags = do
runRAcquire $ do runRAcquire $ do
lockFile shipPath lockFile shipPath
rio $ logTrace "RESUMING SHIP" rio $ logTrace "RESUMING SHIP"
sls <- Pier.resumed shipPath [] sls <- Pier.resumed shipPath flags
rio $ logTrace "SHIP RESUMED" rio $ logTrace "SHIP RESUMED"
Pier.pier shipPath Nothing sls Pier.pier shipPath Nothing sls
tryResume :: HasLogFunc e => FilePath -> RIO e () tryResume :: HasLogFunc e => FilePath -> Serf.Flags -> RIO e ()
tryResume shipPath = do tryResume shipPath flags = do
rwith resumedPier $ \(serf, log, ss) -> do rwith resumedPier $ \(serf, log, ss) -> do
logTrace (displayShow ss) logTrace (displayShow ss)
threadDelay 500000 threadDelay 500000
@ -177,12 +193,12 @@ tryResume shipPath = do
where where
resumedPier = do resumedPier = do
lockFile shipPath lockFile shipPath
Pier.resumed shipPath [] Pier.resumed shipPath flags
tryFullReplay :: HasLogFunc e => FilePath -> RIO e () tryFullReplay :: HasLogFunc e => FilePath -> Serf.Flags -> RIO e ()
tryFullReplay shipPath = do tryFullReplay shipPath flags = do
wipeSnapshot wipeSnapshot
tryResume shipPath tryResume shipPath flags
where where
wipeSnapshot = do wipeSnapshot = do
logTrace "wipeSnapshot" logTrace "wipeSnapshot"
@ -317,13 +333,13 @@ validateNounVal inpVal = do
-------------------------------------------------------------------------------- --------------------------------------------------------------------------------
newShip :: HasLogFunc e => CLI.New -> CLI.Opts -> RIO e () newShip :: HasLogFunc e => CLI.New -> CLI.Opts -> RIO e ()
newShip CLI.New{..} _ newShip CLI.New{..} opts
| CLI.BootComet <- nBootType = | CLI.BootComet <- nBootType =
error "Comets don't work yet" error "Comets don't work yet"
| CLI.BootFake name <- nBootType = | CLI.BootFake name <- nBootType =
let ship = shipFrom name let ship = shipFrom name
in tryBootFromPill nPillPath (pierPath name) ship (Fake ship) in tryBootFromPill nPillPath (pierPath name) flags ship (Fake ship)
| CLI.BootFromKeyfile keyFile <- nBootType = do | CLI.BootFromKeyfile keyFile <- nBootType = do
text <- readFileUtf8 keyFile text <- readFileUtf8 keyFile
@ -343,7 +359,7 @@ newShip CLI.New{..} _
Right dawn -> Right dawn ->
let ship = sShip $ dSeed dawn let ship = sShip $ dSeed dawn
path = (pierPath $ nameFromShip ship) path = (pierPath $ nameFromShip ship)
in tryBootFromPill nPillPath path ship (Dawn dawn) in tryBootFromPill nPillPath path flags ship (Dawn dawn)
where where
shipFrom :: Text -> Ship shipFrom :: Text -> Ship
@ -364,10 +380,13 @@ newShip CLI.New{..} _
Nothing -> error "Urbit.ob didn't produce string with ~" Nothing -> error "Urbit.ob didn't produce string with ~"
Just x -> x Just x -> x
flags = toSerfFlags opts
runShip :: HasLogFunc e => CLI.Run -> CLI.Opts -> RIO e () runShip :: HasLogFunc e => CLI.Run -> CLI.Opts -> RIO e ()
runShip (CLI.Run pierPath) _ = tryPlayShip pierPath runShip (CLI.Run pierPath) opts = tryPlayShip pierPath (toSerfFlags opts)
startBrowser :: HasLogFunc e => FilePath -> RIO e () startBrowser :: HasLogFunc e => FilePath -> RIO e ()
startBrowser pierPath = runRAcquire $ do startBrowser pierPath = runRAcquire $ do