mirror of
https://github.com/graninas/Hydra.git
synced 2024-12-04 11:40:12 +03:00
More failed attempts.
This commit is contained in:
parent
947152498a
commit
8521caa892
@ -1,4 +1,5 @@
|
|||||||
{-# LANGUAGE FlexibleContexts #-}
|
{-# LANGUAGE FlexibleContexts #-}
|
||||||
|
{-# LANGUAGE AllowAmbiguousTypes #-}
|
||||||
|
|
||||||
module Main where
|
module Main where
|
||||||
|
|
||||||
@ -7,12 +8,10 @@ import qualified Data.Set as Set
|
|||||||
|
|
||||||
import qualified Hydra.Domain as D
|
import qualified Hydra.Domain as D
|
||||||
import qualified Hydra.FTL as L
|
import qualified Hydra.FTL as L
|
||||||
import qualified Hydra.FTLI ()
|
|
||||||
-- import qualified Hydra.Language as L
|
|
||||||
import Hydra.Prelude
|
import Hydra.Prelude
|
||||||
import qualified Hydra.Runtime as R
|
import qualified Hydra.Runtime as R
|
||||||
|
|
||||||
import Hydra.Core.Evaluable
|
import Hydra.FTLI ()
|
||||||
|
|
||||||
type MTime = Int
|
type MTime = Int
|
||||||
|
|
||||||
@ -36,7 +35,9 @@ data AppState = AppState
|
|||||||
{ catalogue :: D.StateVar Catalogue
|
{ catalogue :: D.StateVar Catalogue
|
||||||
}
|
}
|
||||||
|
|
||||||
initState :: L.LangL m => m AppState
|
type AppType m a = ReaderT R.CoreRuntime m a
|
||||||
|
|
||||||
|
initState :: (MonadIO m, L.LangL m) => AppType m AppState
|
||||||
initState = L.atomically $ do
|
initState = L.atomically $ do
|
||||||
ne <- L.newVar Map.empty
|
ne <- L.newVar Map.empty
|
||||||
nw <- L.newVar Map.empty
|
nw <- L.newVar Map.empty
|
||||||
@ -51,38 +52,40 @@ initState = L.atomically $ do
|
|||||||
catalogue <- L.newVar catalogueMap
|
catalogue <- L.newVar catalogueMap
|
||||||
pure $ AppState catalogue
|
pure $ AppState catalogue
|
||||||
|
|
||||||
meteorCounter :: L.LangL m => AppState -> m ()
|
meteorCounter :: (L.LangL m, MonadIO m) => AppState -> AppType m ()
|
||||||
meteorCounter st = pure ()
|
meteorCounter st = do
|
||||||
|
void $ readFile "abc"
|
||||||
|
pure ()
|
||||||
|
|
||||||
getRandomMeteor :: L.RandomL m => m Meteor
|
getRandomMeteor :: (MonadIO m, L.RandomL m) => AppType m Meteor
|
||||||
getRandomMeteor = Meteor <$> L.getRandomInt (1, 100)
|
getRandomMeteor = Meteor <$> L.getRandomInt (1, 100)
|
||||||
|
|
||||||
getRandomMilliseconds :: L.RandomL m => m MTime
|
getRandomMilliseconds :: (MonadIO m, L.RandomL m) => AppType m MTime
|
||||||
getRandomMilliseconds = (* 1000) <$> L.getRandomInt (0, 3000)
|
getRandomMilliseconds = (* 1000) <$> L.getRandomInt (0, 3000)
|
||||||
|
|
||||||
meteorShower :: L.LangL m => AppState -> Region -> m ()
|
meteorShower :: (MonadIO m, L.LangL m) => AppState -> Region -> AppType m ()
|
||||||
meteorShower st region = do
|
meteorShower st region = do
|
||||||
getRandomMilliseconds >>= L.delay
|
getRandomMilliseconds >>= L.delay
|
||||||
meteor <- getRandomMeteor
|
meteor <- getRandomMeteor
|
||||||
L.logInfo $ "[MS] " <> " a new meteor appeared at " <> show region <> ": " <> show meteor
|
L.logInfo $ "[MS] " <> " a new meteor appeared at " <> show region <> ": " <> show meteor
|
||||||
meteorShower st region
|
meteorShower st region
|
||||||
|
|
||||||
meteorsMonitoring :: (L.ProcessL m, L.LangL m) => m ()
|
meteorsMonitoring :: (MonadIO m, L.LangL m) => AppType m ()
|
||||||
meteorsMonitoring = do
|
meteorsMonitoring = do
|
||||||
L.logInfo "Starting app..."
|
L.logInfo "Starting app..."
|
||||||
L.logInfo "Delaying..."
|
L.logInfo "Delaying..."
|
||||||
L.delay 10000
|
L.delay 10000
|
||||||
L.logInfo "Done."
|
L.logInfo "Done."
|
||||||
st <- initState
|
st <- initState
|
||||||
L.forkProcess $ cnt st
|
-- liftIO $ forkIO $ meteorCounter st
|
||||||
|
|
||||||
|
-- liftIO $ forkIO $ meteorCounter st
|
||||||
-- L.forkProcess $ meteorShower st NorthEast
|
-- L.forkProcess $ meteorShower st NorthEast
|
||||||
-- L.forkProcess $ meteorShower st NorthWest
|
-- L.forkProcess $ meteorShower st NorthWest
|
||||||
-- L.forkProcess $ meteorShower st SouthEast
|
-- L.forkProcess $ meteorShower st SouthEast
|
||||||
-- L.forkProcess $ meteorShower st SouthWest
|
-- L.forkProcess $ meteorShower st SouthWest
|
||||||
pure ()
|
pure ()
|
||||||
where
|
|
||||||
cnt :: (L.LangL m, Evaluable m) => AppState -> m ()
|
|
||||||
cnt st = meteorCounter st
|
|
||||||
|
|
||||||
loggerCfg :: D.LoggerConfig
|
loggerCfg :: D.LoggerConfig
|
||||||
loggerCfg = D.LoggerConfig
|
loggerCfg = D.LoggerConfig
|
||||||
@ -100,7 +103,7 @@ loggerCfg = D.LoggerConfig
|
|||||||
-- -- R.startApp appRt $ L.foreverApp meteorsMonitoring
|
-- -- R.startApp appRt $ L.foreverApp meteorsMonitoring
|
||||||
-- runReaderT (L.foreverApp meteorsMonitoring) appRt
|
-- runReaderT (L.foreverApp meteorsMonitoring) appRt
|
||||||
|
|
||||||
delayAction :: L.ControlFlowL m => Int -> m ()
|
delayAction :: (MonadIO m, L.ControlFlowL m) => Int -> AppType m ()
|
||||||
delayAction = L.delay
|
delayAction = L.delay
|
||||||
|
|
||||||
|
|
||||||
|
@ -6,5 +6,5 @@ import qualified Hydra.Core.FTL as L
|
|||||||
import qualified Hydra.Core.RLens as RLens
|
import qualified Hydra.Core.RLens as RLens
|
||||||
import qualified Hydra.Core.Runtime as R
|
import qualified Hydra.Core.Runtime as R
|
||||||
|
|
||||||
instance L.ControlFlowL (ReaderT R.CoreRuntime IO) where
|
instance MonadIO m => L.ControlFlowL (ReaderT R.CoreRuntime m) where
|
||||||
delay = liftIO . threadDelay
|
delay = liftIO . threadDelay
|
||||||
|
@ -1,13 +0,0 @@
|
|||||||
{-# LANGUAGE AllowAmbiguousTypes #-}
|
|
||||||
{-# LANGUAGE MultiParamTypeClasses #-}
|
|
||||||
{-# LANGUAGE TypeFamilies #-}
|
|
||||||
|
|
||||||
module Hydra.Core.Evaluable where
|
|
||||||
|
|
||||||
import Hydra.Prelude
|
|
||||||
|
|
||||||
import qualified Hydra.Core.Runtime as R
|
|
||||||
|
|
||||||
class Evaluable m where
|
|
||||||
data EvalM m :: * -> *
|
|
||||||
evaluate :: EvalM m a -> R.CoreRuntime -> IO a
|
|
@ -7,7 +7,6 @@ module Hydra.Core.Lang.FTL where
|
|||||||
import Hydra.Prelude
|
import Hydra.Prelude
|
||||||
|
|
||||||
import Hydra.Core.ControlFlow.FTL as L
|
import Hydra.Core.ControlFlow.FTL as L
|
||||||
import Hydra.Core.Evaluable
|
|
||||||
import Hydra.Core.Logger.FTL as L
|
import Hydra.Core.Logger.FTL as L
|
||||||
import Hydra.Core.Random.FTL as L
|
import Hydra.Core.Random.FTL as L
|
||||||
import qualified Hydra.Core.State.Language as L
|
import qualified Hydra.Core.State.Language as L
|
||||||
|
@ -12,6 +12,7 @@ import qualified Hydra.Core.State.Interpreter as Impl
|
|||||||
import qualified Hydra.Core.State.Language as L
|
import qualified Hydra.Core.State.Language as L
|
||||||
|
|
||||||
instance L.LangL (ReaderT R.CoreRuntime IO) where
|
instance L.LangL (ReaderT R.CoreRuntime IO) where
|
||||||
|
-- instance MonadIO m => L.LangL (ReaderT R.CoreRuntime m) where
|
||||||
evalStateAtomically action = do
|
evalStateAtomically action = do
|
||||||
coreRt <- ask
|
coreRt <- ask
|
||||||
let stateRt = coreRt ^. RLens.stateRuntime
|
let stateRt = coreRt ^. RLens.stateRuntime
|
||||||
|
@ -11,7 +11,7 @@ import qualified Hydra.Core.Logger.Impl.HsLogger as Hs
|
|||||||
import qualified System.Log.Logger as Hs
|
import qualified System.Log.Logger as Hs
|
||||||
|
|
||||||
-- TODO: hslogger specific is here!
|
-- TODO: hslogger specific is here!
|
||||||
instance L.LoggerL (ReaderT R.CoreRuntime IO) where
|
instance MonadIO m => L.LoggerL (ReaderT R.CoreRuntime m) where
|
||||||
logMessage lvl msg = do
|
logMessage lvl msg = do
|
||||||
coreRt <- ask
|
coreRt <- ask
|
||||||
let mbHsRt = coreRt ^. RLens.loggerRuntime ^. RLens.hsLoggerHandle
|
let mbHsRt = coreRt ^. RLens.loggerRuntime ^. RLens.hsLoggerHandle
|
||||||
|
@ -8,11 +8,11 @@ module Hydra.Core.Process.FTL where
|
|||||||
import Hydra.Prelude
|
import Hydra.Prelude
|
||||||
|
|
||||||
import qualified Hydra.Core.Domain as D
|
import qualified Hydra.Core.Domain as D
|
||||||
import Hydra.Core.Evaluable
|
|
||||||
|
|
||||||
|
|
||||||
class (Evaluable m', Monad m) => ProcessL m' m where
|
|
||||||
forkProcess :: EvalM m' a -> m (D.ProcessPtr a)
|
-- class (Monad m) => ProcessL m where
|
||||||
|
-- forkProcess :: m' a -> m (D.ProcessPtr a)
|
||||||
-- killProcess :: D.ProcessPtr a -> m ()
|
-- killProcess :: D.ProcessPtr a -> m ()
|
||||||
-- tryGetResult :: D.ProcessPtr a -> m (Maybe a)
|
-- tryGetResult :: D.ProcessPtr a -> m (Maybe a)
|
||||||
-- awaitResult :: D.ProcessPtr a -> m a
|
-- awaitResult :: D.ProcessPtr a -> m a
|
||||||
|
@ -11,19 +11,18 @@ import qualified Hydra.Core.Process.Interpreter as Impl
|
|||||||
import qualified Hydra.Core.RLens as RLens
|
import qualified Hydra.Core.RLens as RLens
|
||||||
import qualified Hydra.Core.Runtime as R
|
import qualified Hydra.Core.Runtime as R
|
||||||
|
|
||||||
import Hydra.Core.Evaluable
|
|
||||||
import Hydra.Core.Lang.FTLI ()
|
|
||||||
|
|
||||||
instance Evaluable m' => L.ProcessL m' (ReaderT R.CoreRuntime IO) where
|
-- instance L.ProcessL (ReaderT R.CoreRuntime IO) where
|
||||||
forkProcess action = do
|
-- forkProcess action = do
|
||||||
coreRt <- ask
|
-- coreRt <- ask
|
||||||
let processRt = coreRt ^. RLens.processRuntime
|
-- let processRt = coreRt ^. RLens.processRuntime
|
||||||
(pPtr, pVar) <- liftIO (Impl.getNextProcessId processRt >>= D.createProcessPtr)
|
-- (pPtr, pVar) <- liftIO (Impl.getNextProcessId processRt >>= D.createProcessPtr)
|
||||||
threadId <- liftIO $ forkIO $ do
|
-- threadId <- liftIO $ forkIO $ do
|
||||||
res <- evaluate action coreRt
|
-- res <- evaluate action coreRt
|
||||||
atomically $ putTMVar pVar res
|
-- atomically $ putTMVar pVar res
|
||||||
liftIO $ Impl.addProcess processRt pPtr threadId
|
-- liftIO $ Impl.addProcess processRt pPtr threadId
|
||||||
pure pPtr
|
-- pure pPtr
|
||||||
|
|
||||||
-- killProcess :: D.ProcessPtr a -> m ()
|
-- killProcess :: D.ProcessPtr a -> m ()
|
||||||
-- tryGetResult :: D.ProcessPtr a -> m (Maybe a)
|
-- tryGetResult :: D.ProcessPtr a -> m (Maybe a)
|
||||||
-- awaitResult :: D.ProcessPtr a -> m a
|
-- awaitResult :: D.ProcessPtr a -> m a
|
||||||
|
@ -10,5 +10,5 @@ import qualified Hydra.Core.Runtime as R
|
|||||||
import qualified Hydra.Core.State.Interpreter as Impl
|
import qualified Hydra.Core.State.Interpreter as Impl
|
||||||
import qualified Hydra.Core.State.Language as L
|
import qualified Hydra.Core.State.Language as L
|
||||||
|
|
||||||
instance L.RandomL (ReaderT R.CoreRuntime IO) where
|
instance MonadIO m => L.RandomL (ReaderT R.CoreRuntime m) where
|
||||||
getRandomInt range = liftIO $ randomRIO range
|
getRandomInt range = liftIO $ randomRIO range
|
||||||
|
Loading…
Reference in New Issue
Block a user