{-# LANGUAGE PatternSynonyms #-} {-# LANGUAGE ForeignFunctionInterface #-} {-# LANGUAGE JavaScriptFFI #-} -- For HasCallStack compatibility {-# LANGUAGE ImplicitParams, ConstraintKinds, KindSignatures #-} module GHCJS.DOM.JSFFI.Generated.RTCStatsReport (js_stat, stat, stat_, js_names, names, names_, js_getTimestamp, getTimestamp, getTimestampUnsafe, getTimestampUnchecked, js_getId, getId, js_getType, getType, js_getLocal, getLocal, getLocalUnsafe, getLocalUnchecked, js_getRemote, getRemote, getRemoteUnsafe, getRemoteUnchecked, RTCStatsReport(..), gTypeRTCStatsReport) 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 "$1[\"stat\"]($2)" js_stat :: RTCStatsReport -> JSString -> IO JSString -- | stat :: (MonadIO m, ToJSString name, FromJSString result) => RTCStatsReport -> name -> m result stat self name = liftIO (fromJSString <$> (js_stat (self) (toJSString name))) -- | stat_ :: (MonadIO m, ToJSString name) => RTCStatsReport -> name -> m () stat_ self name = liftIO (void (js_stat (self) (toJSString name))) foreign import javascript unsafe "$1[\"names\"]()" js_names :: RTCStatsReport -> IO JSVal -- | names :: (MonadIO m, FromJSString result) => RTCStatsReport -> m [result] names self = liftIO ((js_names (self)) >>= fromJSValUnchecked) -- | names_ :: (MonadIO m) => RTCStatsReport -> m () names_ self = liftIO (void (js_names (self))) foreign import javascript unsafe "$1[\"timestamp\"]" js_getTimestamp :: RTCStatsReport -> IO (Nullable Date) -- | getTimestamp :: (MonadIO m) => RTCStatsReport -> m (Maybe Date) getTimestamp self = liftIO (nullableToMaybe <$> (js_getTimestamp (self))) -- | getTimestampUnsafe :: (MonadIO m, HasCallStack) => RTCStatsReport -> m Date getTimestampUnsafe self = liftIO ((nullableToMaybe <$> (js_getTimestamp (self))) >>= maybe (Prelude.error "Nothing to return") return) -- | getTimestampUnchecked :: (MonadIO m) => RTCStatsReport -> m Date getTimestampUnchecked self = liftIO (fromJust . nullableToMaybe <$> (js_getTimestamp (self))) foreign import javascript unsafe "$1[\"id\"]" js_getId :: RTCStatsReport -> IO JSString -- | getId :: (MonadIO m, FromJSString result) => RTCStatsReport -> m result getId self = liftIO (fromJSString <$> (js_getId (self))) foreign import javascript unsafe "$1[\"type\"]" js_getType :: RTCStatsReport -> IO JSString -- | getType :: (MonadIO m, FromJSString result) => RTCStatsReport -> m result getType self = liftIO (fromJSString <$> (js_getType (self))) foreign import javascript unsafe "$1[\"local\"]" js_getLocal :: RTCStatsReport -> IO (Nullable RTCStatsReport) -- | getLocal :: (MonadIO m) => RTCStatsReport -> m (Maybe RTCStatsReport) getLocal self = liftIO (nullableToMaybe <$> (js_getLocal (self))) -- | getLocalUnsafe :: (MonadIO m, HasCallStack) => RTCStatsReport -> m RTCStatsReport getLocalUnsafe self = liftIO ((nullableToMaybe <$> (js_getLocal (self))) >>= maybe (Prelude.error "Nothing to return") return) -- | getLocalUnchecked :: (MonadIO m) => RTCStatsReport -> m RTCStatsReport getLocalUnchecked self = liftIO (fromJust . nullableToMaybe <$> (js_getLocal (self))) foreign import javascript unsafe "$1[\"remote\"]" js_getRemote :: RTCStatsReport -> IO (Nullable RTCStatsReport) -- | getRemote :: (MonadIO m) => RTCStatsReport -> m (Maybe RTCStatsReport) getRemote self = liftIO (nullableToMaybe <$> (js_getRemote (self))) -- | getRemoteUnsafe :: (MonadIO m, HasCallStack) => RTCStatsReport -> m RTCStatsReport getRemoteUnsafe self = liftIO ((nullableToMaybe <$> (js_getRemote (self))) >>= maybe (Prelude.error "Nothing to return") return) -- | getRemoteUnchecked :: (MonadIO m) => RTCStatsReport -> m RTCStatsReport getRemoteUnchecked self = liftIO (fromJust . nullableToMaybe <$> (js_getRemote (self)))