{-# LANGUAGE PatternSynonyms #-}
{-# LANGUAGE ImplicitParams, ConstraintKinds, KindSignatures #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
module JSDOM.Generated.ReadableStreamDefaultReader
(newReadableStreamDefaultReader, read, read_, cancel, cancel_,
releaseLock, getClosed, ReadableStreamDefaultReader(..),
gTypeReadableStreamDefaultReader)
where
import Prelude ((.), (==), (>>=), return, IO, Int, Float, Double, Bool(..), Maybe, maybe, fromIntegral, round, realToFrac, fmap, Show, Read, Eq, Ord, Maybe(..))
import qualified Prelude (error)
import Data.Typeable (Typeable)
import Data.Traversable (mapM)
import Language.Javascript.JSaddle (JSM(..), JSVal(..), JSString, strictEqual, toJSVal, valToStr, valToNumber, valToBool, js, jss, jsf, jsg, function, asyncFunction, new, array, jsUndefined, (!), (!!))
import Data.Int (Int64)
import Data.Word (Word, Word64)
import JSDOM.Types
import Control.Applicative ((<$>))
import Control.Monad (void)
import Control.Lens.Operators ((^.))
import JSDOM.EventTargetClosures (EventName, unsafeEventName, unsafeEventNameAsync)
import JSDOM.Enums
newReadableStreamDefaultReader ::
(MonadDOM m) => ReadableStream -> m ReadableStreamDefaultReader
newReadableStreamDefaultReader :: ReadableStream -> m ReadableStreamDefaultReader
newReadableStreamDefaultReader ReadableStream
stream
= DOM ReadableStreamDefaultReader -> m ReadableStreamDefaultReader
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
(JSVal -> ReadableStreamDefaultReader
ReadableStreamDefaultReader (JSVal -> ReadableStreamDefaultReader)
-> JSM JSVal -> DOM ReadableStreamDefaultReader
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$>
JSM JSVal -> [JSM JSVal] -> JSM JSVal
forall constructor args.
(MakeObject constructor, MakeArgs args) =>
constructor -> args -> JSM JSVal
new ([Char] -> JSM JSVal
forall a. ToJSString a => a -> JSM JSVal
jsg [Char]
"ReadableStreamDefaultReader") [ReadableStream -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal ReadableStream
stream])
read :: (MonadDOM m) => ReadableStreamDefaultReader -> m JSVal
read :: ReadableStreamDefaultReader -> m JSVal
read ReadableStreamDefaultReader
self
= JSM JSVal -> m JSVal
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (((ReadableStreamDefaultReader
self ReadableStreamDefaultReader
-> Getting (JSM JSVal) ReadableStreamDefaultReader (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char] -> () -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf [Char]
"read" ()) JSM JSVal -> (JSVal -> JSM JSVal) -> JSM JSVal
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> JSM JSVal
readPromise) JSM JSVal -> (JSVal -> JSM JSVal) -> JSM JSVal
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal)
read_ :: (MonadDOM m) => ReadableStreamDefaultReader -> m ()
read_ :: ReadableStreamDefaultReader -> m ()
read_ ReadableStreamDefaultReader
self = DOM () -> m ()
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (JSM JSVal -> DOM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (ReadableStreamDefaultReader
self ReadableStreamDefaultReader
-> Getting (JSM JSVal) ReadableStreamDefaultReader (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char] -> () -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf [Char]
"read" ()))
cancel ::
(MonadDOM m, ToJSVal reason) =>
ReadableStreamDefaultReader -> Maybe reason -> m JSVal
cancel :: ReadableStreamDefaultReader -> Maybe reason -> m JSVal
cancel ReadableStreamDefaultReader
self Maybe reason
reason
= JSM JSVal -> m JSVal
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM
(((ReadableStreamDefaultReader
self ReadableStreamDefaultReader
-> Getting (JSM JSVal) ReadableStreamDefaultReader (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char] -> [JSM JSVal] -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf [Char]
"cancel" [Maybe reason -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal Maybe reason
reason]) JSM JSVal -> (JSVal -> JSM JSVal) -> JSM JSVal
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> JSM JSVal
readPromise) JSM JSVal -> (JSVal -> JSM JSVal) -> JSM JSVal
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>=
JSVal -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal)
cancel_ ::
(MonadDOM m, ToJSVal reason) =>
ReadableStreamDefaultReader -> Maybe reason -> m ()
cancel_ :: ReadableStreamDefaultReader -> Maybe reason -> m ()
cancel_ ReadableStreamDefaultReader
self Maybe reason
reason
= DOM () -> m ()
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (JSM JSVal -> DOM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (ReadableStreamDefaultReader
self ReadableStreamDefaultReader
-> Getting (JSM JSVal) ReadableStreamDefaultReader (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char] -> [JSM JSVal] -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf [Char]
"cancel" [Maybe reason -> JSM JSVal
forall a. ToJSVal a => a -> JSM JSVal
toJSVal Maybe reason
reason]))
releaseLock :: (MonadDOM m) => ReadableStreamDefaultReader -> m ()
releaseLock :: ReadableStreamDefaultReader -> m ()
releaseLock ReadableStreamDefaultReader
self = DOM () -> m ()
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (JSM JSVal -> DOM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (ReadableStreamDefaultReader
self ReadableStreamDefaultReader
-> Getting (JSM JSVal) ReadableStreamDefaultReader (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char] -> () -> JSF
forall name args.
(ToJSString name, MakeArgs args) =>
name -> args -> JSF
jsf [Char]
"releaseLock" ()))
getClosed :: (MonadDOM m) => ReadableStreamDefaultReader -> m Bool
getClosed :: ReadableStreamDefaultReader -> m Bool
getClosed ReadableStreamDefaultReader
self
= DOM Bool -> m Bool
forall (m :: * -> *) a. MonadDOM m => DOM a -> m a
liftDOM (((ReadableStreamDefaultReader
self ReadableStreamDefaultReader
-> Getting (JSM JSVal) ReadableStreamDefaultReader (JSM JSVal)
-> JSM JSVal
forall s a. s -> Getting a s a -> a
^. [Char]
-> IndexPreservingGetter ReadableStreamDefaultReader (JSM JSVal)
forall s name.
(MakeObject s, ToJSString name) =>
name -> IndexPreservingGetter s (JSM JSVal)
js [Char]
"closed") JSM JSVal -> (JSVal -> JSM JSVal) -> JSM JSVal
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> JSM JSVal
readPromise) JSM JSVal -> (JSVal -> DOM Bool) -> DOM Bool
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= JSVal -> DOM Bool
forall value. ToJSVal value => value -> DOM Bool
valToBool)