{-# LANGUAGE PatternSynonyms #-} -- For HasCallStack compatibility {-# LANGUAGE ImplicitParams, ConstraintKinds, KindSignatures #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} module JSDOM.Generated.ReadableByteStreamController (newReadableByteStreamController, enqueue, close, error, getByobRequest, getDesiredSize, ReadableByteStreamController(..), gTypeReadableByteStreamController) 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 -- | newReadableByteStreamController :: (MonadDOM m, ToJSVal underlyingByteSource) => ReadableStream -> underlyingByteSource -> Word -> m ReadableByteStreamController newReadableByteStreamController stream underlyingByteSource highWaterMark = liftDOM (ReadableByteStreamController <$> new (jsg "ReadableByteStreamController") [toJSVal stream, toJSVal underlyingByteSource, toJSVal highWaterMark]) -- | enqueue :: (MonadDOM m, ToJSVal chunk) => ReadableByteStreamController -> Maybe chunk -> m () enqueue self chunk = liftDOM (void (self ^. jsf "enqueue" [toJSVal chunk])) -- | close :: (MonadDOM m) => ReadableByteStreamController -> m () close self = liftDOM (void (self ^. jsf "close" ())) -- | error :: (MonadDOM m, ToJSVal error) => ReadableByteStreamController -> Maybe error -> m () error self error = liftDOM (void (self ^. jsf "error" [toJSVal error])) -- | getByobRequest :: (MonadDOM m) => ReadableByteStreamController -> m ReadableStreamBYOBRequest getByobRequest self = liftDOM ((self ^. js "byobRequest") >>= fromJSValUnchecked) -- | getDesiredSize :: (MonadDOM m) => ReadableByteStreamController -> m Double getDesiredSize self = liftDOM ((self ^. js "desiredSize") >>= valToNumber)