module GHCJS.DOM.JSFFI.Generated.MessageChannel
(js_newMessageChannel, newMessageChannel, js_getPort1, getPort1,
getPort1Unsafe, getPort1Unchecked, js_getPort2, getPort2,
getPort2Unsafe, getPort2Unchecked, MessageChannel(..),
gTypeMessageChannel)
where
import Prelude ((.), (==), (>>=), return, IO, Int, Float, Double, Bool(..), Maybe, maybe, fromIntegral, round, fmap, Show, Read, Eq, Ord)
import qualified Prelude (error)
import Data.Typeable (Typeable)
import GHCJS.Types (JSVal(..), JSString)
import GHCJS.Foreign (jsNull)
import GHCJS.Foreign.Callback (syncCallback, asyncCallback, syncCallback1, asyncCallback1, syncCallback2, asyncCallback2, OnBlocked(..))
import GHCJS.Marshal (ToJSVal(..), FromJSVal(..))
import GHCJS.Marshal.Pure (PToJSVal(..), PFromJSVal(..))
import Control.Monad (void)
import Control.Monad.IO.Class (MonadIO(..))
import Data.Int (Int64)
import Data.Word (Word, Word64)
import Data.Maybe (fromJust)
import GHCJS.DOM.Types
import Control.Applicative ((<$>))
import GHCJS.DOM.EventTargetClosures (EventName, unsafeEventName)
import GHCJS.DOM.JSFFI.Generated.Enums
foreign import javascript unsafe "new window[\"MessageChannel\"]()"
js_newMessageChannel :: IO MessageChannel
newMessageChannel :: (MonadIO m) => m MessageChannel
newMessageChannel = liftIO (js_newMessageChannel)
foreign import javascript unsafe "$1[\"port1\"]" js_getPort1 ::
MessageChannel -> IO (Nullable MessagePort)
getPort1 :: (MonadIO m) => MessageChannel -> m (Maybe MessagePort)
getPort1 self = liftIO (nullableToMaybe <$> (js_getPort1 (self)))
getPort1Unsafe ::
(MonadIO m, HasCallStack) => MessageChannel -> m MessagePort
getPort1Unsafe self
= liftIO
((nullableToMaybe <$> (js_getPort1 (self))) >>=
maybe (Prelude.error "Nothing to return") return)
getPort1Unchecked :: (MonadIO m) => MessageChannel -> m MessagePort
getPort1Unchecked self
= liftIO (fromJust . nullableToMaybe <$> (js_getPort1 (self)))
foreign import javascript unsafe "$1[\"port2\"]" js_getPort2 ::
MessageChannel -> IO (Nullable MessagePort)
getPort2 :: (MonadIO m) => MessageChannel -> m (Maybe MessagePort)
getPort2 self = liftIO (nullableToMaybe <$> (js_getPort2 (self)))
getPort2Unsafe ::
(MonadIO m, HasCallStack) => MessageChannel -> m MessagePort
getPort2Unsafe self
= liftIO
((nullableToMaybe <$> (js_getPort2 (self))) >>=
maybe (Prelude.error "Nothing to return") return)
getPort2Unchecked :: (MonadIO m) => MessageChannel -> m MessagePort
getPort2Unchecked self
= liftIO (fromJust . nullableToMaybe <$> (js_getPort2 (self)))