From 5187b97f70608b8a1cb3177b4ad98a6c81cc3084 Mon Sep 17 00:00:00 2001 From: David Johnson Date: Wed, 30 Oct 2024 19:08:32 -0500 Subject: [PATCH] Expose global sink --- src/Miso.hs | 20 +++++++++++++++----- 1 file changed, 15 insertions(+), 5 deletions(-) diff --git a/src/Miso.hs b/src/Miso.hs index 9eb7836..6f708ca 100644 --- a/src/Miso.hs +++ b/src/Miso.hs @@ -41,17 +41,18 @@ import Control.Monad import Control.Monad.IO.Class import Data.IORef import Data.List -import Data.Sequence ((|>)) +import Data.Sequence ((|>)) +import qualified Data.Sequence as S +import qualified JavaScript.Object.Internal as OI +import System.IO.Unsafe import System.Mem.StableName -import qualified Data.Sequence as S -import qualified JavaScript.Object.Internal as OI #ifndef ghcjs_HOST_OS -import Language.Javascript.JSaddle (eval, waitForAnimationFrame) +import Language.Javascript.JSaddle (eval, waitForAnimationFrame) #ifdef IOS import Miso.JSBits #else -import GHCJS.Types (JSString) +import GHCJS.Types (JSString) import Data.FileEmbed #endif #else @@ -99,6 +100,8 @@ common App {..} m getView = do let writeEvent a = void . liftIO . forkIO $ do atomicModifyIORef' actionsRef $ \as -> (as |> a, ()) notify + -- init global sink + liftIO (writeIORef globalSinkRef writeEvent) -- init Subs forM_ subs $ \sub -> sub writeEvent @@ -152,6 +155,13 @@ miso f = do -- Create virtual dom, perform initial diff liftIO (newIORef initialVTree) +globalSinkRef :: IORef (Sink action) +{-# NOINLINE globalSinkRef #-} +globalSinkRef = unsafePerformIO $ newIORef (\_ -> pure ()) + +globalSink :: IO (Sink action) +globalSink = readIORef globalSinkRef + -- | Runs a miso application startApp :: Eq model => App model action -> JSM () startApp app@App {..} =