T7      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~! Safe-Inferred Safe-Inferred  None;None Safe-InferredRedBlackRed black tree as multimap.(One ore more list to implement multimap.O(log N)O(log N)O(1)O(1)O(1)O(log N) O(N log N)O(N)2O(N) "Constructing Red-Black Trees" by Ralf HinzeO(N)O(N)*" Safe-Inferred   Safe-InferredfStarting a thread pool manager. Its action is initially set to 'return ()' and should be set by @. This allows that the action can include the manager itself.   Safe-Inferred None+; A handle used by %An action to be performed on timeout.A timeout manager\Creating timeout manager which works every N micro seconds where N is the first argument.Stopping timeout manager.Registering a timeout action. 4Registering a timeout action of killing this thread.  Setting the state to active. % turns active to inactive repeatedly. "Setting the state to canceled. 0 eventually removes this without timeout action.  Setting the state to paused.  does not change the value. ;Setting the paused state to active. This is an alias to  ./Call the inner function with a timeout manager. timeout in microseconds   None/The type of the cache of the Date header value."The type of the Date header value. Creating  and executing the action.Getting  based on .  Safe-InferredMutable Fd cacher.'An action to activate a Fd cache entry. Creating f and executing the action in the second argument. The first argument is a cache duration in second.Getting  and  from the mutable Fd cacher.          None+3What kind of transport is used for this connection?Encrypted channel: TLS or SSL@The result of Application Layer Protocol Negociation in RFC 7301Plain channel: TCPType for input streaming.Internal information.%|Data type to manipulate IO actions for connections. This is used to abstract IO actions for plain HTTP and HTTP over TLS.' This is not used at this moment.(The sending function.)+The sending function for files in HTTP/1.1.* The connection closing function.+;The connection receiving function. This returns "" for EOF.,{The connection receiving function. This tries to fill the buffer. This returns when the buffer is filled or reaches EOF.-The write buffer..The size of the write buffer./Type for the action to receive input data with a buffer. The result boolean indicates whether or not the buffer is fully filled.0)Type for the action to receive input data1Type for buffer size2Type for bufferType for read buffer pool31fileid, offset, length, hook action, HTTP headers Since: 3.1.04Data type to abstract file identifiers. On Unix, a file descriptor would be specified to make use of the file descriptor cache. Since: 3.1.08Error types for bad Request.@$The type for header value used with .ATCP port number.+Read from a Source, ignoring any leftovers.9 !"#$%&'()*+,-./0123456789:;<=>?@A7 !"#$%&'()*+,-./0123456789:;<=>?@A !"#$% &'()*+,-./012345678?>=<;:9@ANoneBThe default size of the write buffer: 16384 (2^14 = 1024 * 16). This is the maximum size of TLS record. This is also the maximum size of HTTP/2 frame payload (excluding frame header).C"Allocating a buffer with malloc().DReleasing a buffer with free().EjCopying the bytestring to the buffer. This function returns the point where the next copy should start.BCD !"#$%&'(E) BCD!"'(E)BCD !"#$%&'(E)None *+,-./012345* *+,-./012345None3F Array for a set of HTTP headers.G The size for F for HTTP Request. From 0 to this corresponds to "Content-Length", "Transfer-Encoding", "Expect", "Connection", "Range", and "Host".6 The size for F for HTTP Response.F789:;<=G>?@AB6CDF789:;<=G>?@AB6CDF789:;<=G>?@AB6CDNone HFunction to send a file based on sendfile() for Linux/Mac/FreeBSD. This makes use of the file descriptor cache. For other OSes, this is identical to I. Since: 3.1.0IFunction to send a file based on pread()/send() for Unix. This makes use of the file descriptor cache. For Windows, this is emulated by Handle. Since: 3.1.0EHFGIHHFIHEHFGIHNone FHIMJ$Specify usage of the PROXY protocol.KSee setProxyProtocolOptional.LSee setProxyProtocolRequired.MSee setProxyProtocolNone.NVarious Warp server settings. This is purposely kept as an abstract data type so that new settings can be added without breaking backwards compatibility. In order to create a N value, use aK and the various 'set' functions to modify individual fields. For example: setTimeout 20 defaultSettingsP&Port to listen on. Default value: 3000QDefault value: HostIPv4RxWhat to do with exceptions thrown by either the application or server. Default: ignore server-generated exceptions (see 89) and print application-generated applications to stderr.SA function to create I when an exception occurs.0Default: 500, text/plain, "Something went wrong" Since 2.0.3T+What to do when a connection is open. When Js is returned, the connection is closed immediately. Otherwise, the connection is going on. Default: always returns K.U;What to do when a connection is close. Default: do nothing.V+Timeout value in seconds. Default value: 30WHUse an existing timeout manager instead of spawning a new one. If used, V is ignored. Default is LXrCache duration time of file descriptors in seconds. 0 means that the cache mechanism is not used. Default value: 0YCode to run after the listening socket is ready but before entering the main event loop. Useful for signaling to tests that they can start running, or to drop permissions after binding to a restricted port.Default: do nothing. Since 1.3.6Z1Code to fork a new thread to accept a connection.kThis may be useful if you need OS bound threads, or if you wish to develop an alternative threading model. Default: void . forkIOWithUnmask Since 3.0.4[&Perform no parsing on the rawPathInfo.(This is useful for writing HTTP proxies.Default: False Since 2.0.3]4Default server name if application does not set one. Since 3.0.2^See setMaximumBodyFlush. Since 3.0.3_$Specify usage of the PROXY protocol. Since 3.0.5.`GSize of bytes read to prevent Slowloris protection. Default value: 2048 Since 3.1.2.a]The default settings for the Warp server. See the individual settings for the default value.bApply the logic provided by c to determine if an exception should be shown or not. The goal is to hide exceptions which occur under the normal course of the web server running. Since 2.1.3c.Printing an exception to standard error if b returns K. Since: 3.1.0dESending 400 for bad requests. Sending 500 for internal server errors. Since: 3.1.0eTException handler for the debugging purpose. 500, text/plain, a showed exception.Since: 2.0.3.2JKLMNOPQRSTUVWXYZ[\]^_`abcdeJKLMNOPQRSTUVWXYZ[\]^_`abcdeJMLKNOPQRSTUVWXYZ[\]^_`abcdeNone fThis function returns a receiving function based on two receiving functions. The returned function efficiently manages received data which is initialized by the first argument. The returned function may allocate a byte string with malloc().MNfOPQRSNfPQRMNfOPQRSNoneT Contains a Source. and a byte count that is still to be read in.U Given an IsolatedBSSource provide a Source} that only allows up to the specified number of bytes to be passed downstream. All leftovers should be retained within the Source5. If there are not enough bytes available, throws a ConnectionClosedByPeer exception.VExtract the underlying Source from an IsolatedBSSource-, which will not perform any more isolation.WXYZ[\]T^_UV`abWXYZ[\]T^_UV`ab W[ZYX\]T^_UV`abNonec"The context for HTTP/2 connection.dRFC 7540 says "Other frames (from any stream) MUST NOT occur between the HEADERS frame and any CONTINUATION frames that might follow". This field is used to implement this requirement.Qefghijklmnopqrstuvwxyz{|c}~dNefghijklmnopqrstuvwxyz{|c}~d!efghijklmqponrvutsw|{zyxc }~dNone NoneNone!parseRequestLine "GET / HTTP/1.1"("GET","/","",HTTP/1.1)8parseRequestLine "POST /cgi/search.cgi?key=foo HTTP/1.0".("POST","/cgi/search.cgi","?key=foo",HTTP/1.0)parseRequestLine "GET ":*** Exception: Warp: Invalid first line of request: "GET "+parseRequestLine "GET /NotHTTP UNKNOWN/1.1">*** Exception: Warp: Request line specified a non-HTTP request!parseRequestLine "PRI * HTTP/2.0"("PRI","*","",HTTP/2.0)parseHeader "Content-Length:47"("Content-Length","47")"parseHeader "Accept-Ranges: bytes"("Accept-Ranges","bytes")%parseHeader "Host: example.com:8080"("Host","example.com:8080")parseHeader "NoSemiColon"("NoSemiColon","")NonegReceiving a HTTP request from %% and parsing its header to create .gPeer's address.Where HTTP request comes from. passed to 3, how many bytes remain to be consumed, if known F\ of HTTP request for internal use, Body producing action used for flushing the request bodycontent lengthtransfer-encoding remainingggNoneEHMhSending a HTTP response to % according to I./Applications/middlewares MUST specify a proper U. so that inconsistency does not happen. No header is deleted by this function.Especially, Applications/middlewares MUST take care of Content-Length, Content-Range, and Transfer-Encoding because they are inserted, when necessary, regardless they already exist. This function does not insert Content-Encoding. It's middleware's responsibility.LThe Date and Server header is added if not exist in HTTP response header.%There are three basic APIs to create I:  ::  ->  ->  ->   -> IHTTP response body is sent by sendfile() for GET method. HTTP response body is not sent by HEAD method. Applications are categorized into simple and sophisticated. Simple applications should specify L to  . The size of the specified file is obtained by disk access. Then Range is handled. Sophisticated applications should specify  to  p. They should treat Range (and If-Range) by themselves. In both cases, Content-Length and Content-Range (if necessary) are automatically added into the HTTP response header. If Content-Length and Content-Range exist in the HTTP response header, they would cause inconsistency. Status is also changed to 206 (Partial Content) if necessary. ::  ->  ->  -> I#HTTP response body is created from 6. Transfer-Encoding: chunked is used in HTTP/1.1. ::  ->  ->  -> I#HTTP response body is created from 6. Transfer-Encoding: chunked is used in HTTP/1.1. :: (  -> ( ->  ()) ->  ()) -> I -> I8No header is added and no Transfer-Encoding: is applied.Use (2 to send this data while respecting timeout rules.iThe version of Warp.;replaceHeader "Content-Type" "new" [("content-type","old")][("Content-Type","new")]hdefault server value HTTP request.Indexed header of HTTP request.$source from client, for raw response8HTTP response including status code and response header..Returing True if the connection is persistent.ihihiNone+F)The type to store enough information for settingsOnException.NIt would nice if responders could return values to workers. Unfortunately,  is already defined in WAI 2.0. It is not wise to change this type. So, a reference is shared by a responder and its worker. The reference refers a value of this type as a return value. If KO, the worker continue to serve requests. Otherwise, the worker get finished.The wai definition is 'type Application = Request -> (Response -> IO ResponseReceived) -> IO ResponseReceived'. This type implements the second argument (Response -> IO ResponseReceived) with extra arguments.6This function is passed to workers. They also pass Is from Ms to this function. This function enqueues commands for the HTTP/2 sender.           NoneNoneFNone !"#$%&'()*+,-./$! "#$%&'()*+,-./ None01001!NoneEMj Creating %( for plain HTTP based on a given socket.kRun an  on the given port. This calls m with a.lRun an  on the port present in the PORT! environment variable. Uses the A/ given when the variable is unset. This calls m with a. Since 3.0.9mRun an  with the given N5. This opens a listen socket on the port defined in N and calls n.nAThis installs a shutdown handler for the given socket and calls o with the default connection setup action which handles plain (non-cipher) HTTP. When the listen socket in the second argument is closed, all live connections are gracefully shut down.tThe supplied socket can be a Unix named socket, which can be used when reverse HTTP proxying into your application.Note that the P will still be passed to  s via the  serverPort record.oThe connection setup action would be expensive. A good example is initialization of TLS. So, this converts the connection setup action to the connection maker which will be executed after forking a new worker thread. Then this calls p with the connection maker. This allows the expensive computations to be performed in a separate worker thread instead of the main server loop. Since 1.3.5p6This modifies the connection maker so that it returns  for  (i.e. plain HTTP) then calls q.q"The core run function which takes N, a connection maker and W. The connection maker can return a connection of either plain HTTP or HTTP over TLS. Since 2.1.4jklmnopq23456get next chunkmaximum to flush3True == flushed the entire body, False == we didn't789jklmnopq23456789jklmnopq23456789None_  !"#$%&'()*+,-./01234567@BCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`fghijopq_NOPQRSTUVWXYZ[\]^_`JMLKopq%&'()*+,-.j0/f21BCDE45673HIi !"#$@FG ghNoneFHMr&Port to listen on. Default value: 3000 Since 2.1.0s-Interface to bind to. Default value: HostIPv4 Since 2.1.0tQWhat to do with exceptions thrown by either the application or server. Default: c Since 2.1.0uA function to create a I when an exception occurs. Default: d Since 2.1.0v-What to do when a connection is opened. When Ju is returned, the connection is closed immediately. Otherwise, the connection is going on. Default: always returns K. Since 2.1.0w<What to do when a connection is closed. Default: do nothing. Since 2.1.0x+Timeout value in seconds. Default value: 30 Since 2.1.0yIUse an existing timeout manager instead of spawning a new one. If used, V is ignored. Since 2.1.0zaCache duration time of file descriptors in seconds. 0 means that the cache mechanism is not used.The FD cache is an optimization that is useful for servers dealing with static files. However, if files are being modified, it can cause incorrect results in some cases. Therefore, we disable it by default. If you know that your files will be static or you prefer performance to file consistency, it's recommended to turn this on; a reasonable value for those cases is 10. Enabling this cache results in drastic performance improvement for file transfers.BDefault value: since 3.0.13, default value is 0, was previously 10{Code to run after the listening socket is ready but before entering the main event loop. Useful for signaling to tests that they can start running, or to drop permissions after binding to a restricted port.Default: do nothing. Since 2.1.0|&Perform no parsing on the rawPathInfo.(This is useful for writing HTTP proxies.Default: False Since 2.1.0}Get the listening port. Since 2.1.1~Get the interface to bind to. Since 2.1.1%Get the action on opening connection.&Get the action on closeing connection.Get the exception handler.#A code to install shutdown handler.For instance, this code should set up a UNIX signal handler. The handler should call the first argument, which close the listen socket, at shutdown.#Default: does not install any code. Since 3.0.14Default server name if application does not set one. Since 3.0.2EThe maximum number of bytes to flush from an unconsumed request body.By default, Warp does not flush the request body so that, if a large body is present, the connection is simply terminated instead of wasting time and bandwidth on transmitting it. However, some clients do not deal with that situation well. You can either change this setting to Nothingx to flush the entire body in all cases, or in your application ensure that you always consume the entire request body.Default: 8192 bytes. Since 3.0.31Code to fork a new thread to accept a connection.kThis may be useful if you need OS bound threads, or if you wish to develop an alternative threading model. Default: void . forkIOWithUnmask Since 3.0.4Do not use the PROXY protocol. Since 3.0.5Require PROXY header.SThis is for cases where a "dumb" TCP/SSL proxy is being used, which cannot add an X-Forwarded-ForC HTTP header field but has enabled support for the PROXY protocol.See  :http://www.haproxy.org/download/1.5/doc/proxy-protocol.txt and  shttp://docs.aws.amazon.com/ElasticLoadBalancing/latest/DeveloperGuide/TerminologyandKeyConcepts.html#proxy-protocol.iOnly the human-readable header format (version 1) is supported. The binary header format (version 2) is not supported. Since 3.0.5YUse the PROXY header if it exists, but also accept connections without the header. See .WARNING: This is contrary to the PROXY protocol specification and using it can indicate a security problem with your architecture if the web server is directly accessable to the public, since it would allow easy IP address spoofing. However, it can be useful in some cases, such as if a load balancer health check uses regular HTTP without the PROXY header, but proxied connections do include the PROXY header. Since 3.0.5GSize in bytes read to prevent Slowloris protection. Default value: 2048 Since 3.1.2'Explicitly pause the slowloris timeout.`This is useful for cases where you partially consume a request body. For more information, see *https://github.com/yesodweb/wai/issues/351 Since 3.0.10rstuvwxyz{|}~q  !"#$%&'()*+,-.123456789:;<=>?@ABCDFGHINabcdeghijklmnopqrstuvwxyz{|}~qklmnNarstuvwxyz{|}~cbdeA8?>=<;:9opq%&'()*+,-.j21BCD45673HIi !"#$@FGgh rstuvwxyz{|}~:"#$ % % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9:;<=>?@ABBCDEFGGHIJKLMNOPQRSTUUVWXYZ[\]^_`abcdefghijklmnnopqrstuvwxyz{|}~!!!!!!!!   ( (                      &     )                ! " ) # $ %&'()*A+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdecdfghijklmnopqrstuvwxxpyz{|}~})#`a`'(`'g`ag```a`cd     `a !"#$%&'()*+,-./0123456789:;<=>?^ @ A!B!C!D!E!F!G!H!IJ warp-3.1.2Network.Wai.Handler.Warp!Network.Wai.Handler.Warp.Internal Network.Wai.Handler.Warp.Windows Paths_warp Network.Wai.Handler.Warp.ReadInt*Network.Wai.Handler.Warp.HTTP2.EncodeFrame!Network.Wai.Handler.Warp.MultiMapNetwork.Wai.Handler.Warp.IORef&Network.Wai.Handler.Warp.HTTP2.Manager Network.Wai.Handler.Warp.Counter Network.Wai.Handler.Warp.TimeoutNetwork.Wai.Handler.Warp.Date Network.Wai.Handler.Warp.FdCacheNetwork.Wai.Handler.Warp.TypesNetwork.Wai.Handler.Warp.Buffer'Network.Wai.Handler.Warp.ResponseHeaderNetwork.Wai.Handler.Warp.Header!Network.Wai.Handler.Warp.SendFile!Network.Wai.Handler.Warp.SettingsNetwork.Wai.Handler.Warp.Recv Network.Wai.Handler.Warp.Conduit$Network.Wai.Handler.Warp.HTTP2.Types&Network.Wai.Handler.Warp.HTTP2.RequestNetwork.Wai.Handler.Warp.IO&Network.Wai.Handler.Warp.RequestHeader Network.Wai.Handler.Warp.Request!Network.Wai.Handler.Warp.Response%Network.Wai.Handler.Warp.HTTP2.Worker$Network.Wai.Handler.Warp.HTTP2.HPACK'Network.Wai.Handler.Warp.HTTP2.Receiver%Network.Wai.Handler.Warp.HTTP2.SenderNetwork.Wai.Handler.Warp.HTTP2Network.Wai.Handler.Warp.Runstreaming-commons-0.1.12.1Data.Streaming.Network.InternalHostPreference TimeoutThreadHandle TimeoutActionManager initialize stopManagerregisterregisterKillThreadticklecancelpauseresume withManager DateCacheGMTDate withDateCachegetDateMutableFdCacheRefresh withFdCachegetFd TransportTLStlsMajorVersiontlsMinorVersiontlsNegotiatedProtocol tlsChiperIDTCPSource InternalInfo threadHandletimeoutManagerfdCacher dateCacher Connection connSendMany connSendAll connSendFile connCloseconnRecv connRecvBufconnWriteBufferconnBufferSizeRecvBufRecvBufSizeBufferSendFileFileId fileIdPathfileIdFdInvalidRequestBadProxyHeaderOverLargeHeaderConnectionClosedByPeerIncompleteHeadersNonHttp BadFirstLineNotEnoughLines HeaderValuePort bufferSizeallocateBuffer freeBuffercopy IndexedHeaderrequestMaxIndexsendFile readSendFile ProxyProtocolProxyProtocolOptionalProxyProtocolRequiredProxyProtocolNoneSettings settingsPort settingsHostsettingsOnExceptionsettingsOnExceptionResponsesettingsOnOpensettingsOnClosesettingsTimeoutsettingsManagersettingsFdCacheDurationsettingsBeforeMainLoop settingsForksettingsNoParsePathsettingsInstallShutdownHandlersettingsServerNamesettingsMaximumBodyFlushsettingsProxyProtocolsettingsSlowlorisSizedefaultSettingsdefaultShouldDisplayExceptiondefaultOnExceptiondefaultOnExceptionResponseexceptionResponseForDebugmakePlainReceiveN recvRequest sendResponse warpVersionsocketConnectionrunrunEnv runSettingsrunSettingsSocketrunSettingsConnectionrunSettingsConnectionMaker runSettingsConnectionMakerSecuresetPortsetHostsetOnExceptionsetOnExceptionResponse setOnOpen setOnClose setTimeout setManagersetFdCacheDurationsetBeforeMainLoopsetNoParsePathgetPortgetHost getOnOpen getOnClosegetOnExceptionsetInstallShutdownHandler setServerNamesetMaximumBodyFlushsetForksetProxyProtocolNonesetProxyProtocolRequiredsetProxyProtocolOptionalsetSlowlorisSize pauseTimeoutwindowsThreadBlockHackcatchIOversionbindirlibdirdatadir libexecdir sysconfdir getBinDir getLibDir getDataDir getLibexecDir getSysconfDirgetDataFileNameTablereadInt readInt64 mhDigitToIntisDigit goawayFrame resetFrame settingsFrame pingFramewindowUpdateFrameRBMMapSomesearch searchWithisEmptyempty singletoninsertfromListtoListfromSortedList toSortedList pruneWithDigitDueUnoColorNodeLeafTomOnesnoctopinsert' balanceL' balanceR'turnBincraddlinkAlllinkmergevalid isBalanced isBlackSameblacks isRedSeparatereds isOrdered$fEqMMapbase Data.IORefatomicModifyIORef'atomicWriteIORefatomicModifyIORef modifyIORef' modifyIORef mkWeakIORef GHC.IORef writeIORef readIORefnewIORefIORefstart setAction ThreadSetCommandReplaceSpawnStopstop spawnActionreplaceWithAction newThreadSetdelkillCounter newCounter waitForZeroincreasedecreaseStateCanceledPausedInactiveActive ignoreAll killIfExist$fShowTimeoutThread$fExceptionTimeoutThreadgetCurrentGMTDateSystem.Posix.TypesFdFdCacheHashFdEntry MutableStatusStatusstatusnewActiveStatusrefreshinactive newFdEntryfdCachelookcleanprune terminate BufferPoolhttp-types-0.8.6Network.HTTP.Types.Header HeaderName readSource'hTransferEncoding hContentRange hAcceptRangeshServermkSource readSourceleftoverSourcereadLeftoverSourceisTransportSecure$fExceptionInvalidRequest$fShowInvalidRequestlargeBufferSize minBufferSize newBufferPoolmallocBS usefulBuffer getBuffer putBufferwithForeignBufferwithBufferPool toBlazeBufferbufferIO composeHeader httpVer11 httpVer10 copyStatus copyHeaders copyHeadercopyCRLFzerospccoloncrlfresponseMaxIndexindexRequestHeaderidxContentLengthidxTransferEncoding idxExpect idxConnectionidxRangeidxHostrequestKeyIndexdefaultIndexRequestHeaderindexResponseHeader idxServeridxDateresponseKeyIndextraverseHeaderc_pread packHeadermini positionRead wai-3.0.3.0Network.Wai.InternalResponseghc-prim GHC.TypesFalseTrue Data.MaybeNothingc_recv makeReceiveNreceiveNspellreceive receiveBuf receiveloopISource readISource isourceDone ChunkState DoneChunkingHaveLenNeedLenNewlineNeedLenCSource mkISource mkCSource readCSource isHexDigitContext continued StreamTableStream streamNumber streamStatestreamContentLengthstreamBodyLength streamWindow StreamStateClosed HalfClosedOpenIdle ClosedCode ResetByMeResetKilledFinished OpenStateBodyHasBodyNoBody Continued JustOpened http2settings streamTable concurrencycurrentStreamIdinputQoutputQencodeDynamicTabledecodeDynamicTableconnectionWindowAuxPersistOneshotSyncSyncNext SyncFinishSyncNoneSequenceSBuilderSFlushSFinishOutputONext OResponseOFrameOGoawayOFinishNext BytesFilledDynaNextControlCNoneCNextCFinishInputhttp2verisHTTP2 newContext clearContextisIdleisOpen isHalfClosedisClosed newStreamopenedclosed $fShowStream$fShowStreamState $fShowControlPseudo colonMethod colonPath colonAuth contentLenMkReq ValidHeadersvhMethodvhPathvhAuthvhCLvhHeader mkRequest emptyPseudovalidateHeaders newReadBodyreadBody toBufIOWithparseRequestLine parseHeaderparseHeaderLinesparseByteRangesRequestTHStatus BSEndoListBSEndomaxTotalHeaderLength Network.Wai Application headerLines handleExpect bodyAndSourcetoLength isChunked timeoutBodypushcheckCRpauseTimeoutKeyResponseHeaders responseFileNetwork.HTTP.Types.StatusGHC.IOFilePathMaybeFilePartJustresponseBuilderbytestring-0.10.4.0 Data.ByteString.Builder.InternalBuilderresponseStream StreamingBody responseRawIOData.ByteString.Internal ByteString sendFragment replaceHeaderRspRspRaw RspStream RspBuilderRspFilemapRight fileRangefileRangeSizedcheckPartRangesendRspsendResponseNoBodyinfoFromRequest checkPersist checkChunkinfoFromResponsehasBodyaddAcceptRangesaddTransferEncodingaddContentLengthaddContentRangeaddDatedefaultServerValue addServercomposeHeaderBuilder StreamInfoThreadContinueResponseReceived ResponderresponseBreakworkerwaiternewThreadContinuesetThreadContinuegetThreadContinue newStreamInfoclearStreamInfo setStreamInfo getStreamInfo$fExceptionBreakhpackEncodeHeaderhpackDecodeHeader frameReceivercontrolguardIt checkPrioritystreamLeftoverLTwoLOneLZero unlessClosedcheckWindowSize frameSenderfillResponseBodyGetNext fileStartEndfillStreamBodyGetNextfillBufBuildernextForBuilderrunStreamBuilder fillBufStream nextForStream fillBufFile nextForFilehttp2goawayacceptConnectionforkserveConnectionflushEntireBody flushBody wrappedRecvsetSocketCloseOnExecgracefulShutdown