}>      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~!SafeSafe  None<NoneSafeBlackRedRed 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  SafefStarting 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 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 . SafeMutable 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?Plain channel: TCPEncrypted channel: TLS or SSL@The result of Application Layer Protocol Negociation in RFC 7301Type 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  HeaderName.ATCP port number.+Read from a Source, ignoring any leftovers.5  !"#$%&'()*+,-./0123456789:;<=>?@A!"#$%&'3  !"#$%&'()*+,-./0123456789:;<=>?@A!"#$%  !"#$% &'()*+,-./0123456789:;<=>?@A!"#$%&'NoneBThe 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()*+,-./01E2 BCD*+01E2BCD()*+,-./01E2None 3456789:;<=>3 3456789:;<=>None4F 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".? The size for F for HTTP Response.F@ABCDEFGGHIJK?LMF@ABCDEFGGHIJK?LMF@ABCDEFGGHIJK?LMNone 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.0NHOPIQHOIQNHOPIQNone GIJNJ$Specify usage of the PROXY protocol.KSee setProxyProtocolNone.LSee setProxyProtocolRequired.MSee setProxyProtocolOptional.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 R when an exception occurs.0Default: 500, text/plain, "Something went wrong" Since 2.0.3T+What to do when a connection is open. When Ss is returned, the connection is closed immediately. Otherwise, the connection is going on. Default: always returns T.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 UXrCache 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 T. 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[\]^_`abcdeJKLMNOPQRSTUVWXYZ[\]^_`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().VWfXYZ[\WfYZ[VWfXYZ[\None] Contains a Source. and a byte count that is still to be read in.^ 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._`abcde]fg^hij_`abcde]fg^hij_`abcde]fg^hijNonekThe concurrency IORef in which this stream has been counted. The client and server each have separate concurrency values to respect, so pushed streams need to decrement a different count when they're closed. This should be either concurrency ctx or pushConcurrency ctx.l"The context for HTTP/2 connection.maNumber of active streams initiated by the client; for enforcing our own max concurrency setting.ngNumber of active streams initiated by the server; for respecting the client's max concurrency setting.oRFC 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.p.Last client-initiated stream ID we've handled.q*Next available server-initiated stream ID.r`Auxiliary information needed to communicate with a running stream: a queue of stream elements (s) and a t connected to its waiter thread.u@A message from the sender to a stream's dedicated waiter thread.v4Nothing interesting has happened. Go back to sleep.wThe stream has ended.x]The stream's queue has been drained; wait for more to be available and re-enqueue the given y.slAn element on the queue between a running stream and the sender; the order should consist of any number of z, {, and |, followed by a single }.}.The stream is over; its trailers are provided.|-Any buffered data should be sent immediately.{%Append a chunk of data to the stream.z2Append a chunk of a file's contents to the stream.~Terminate the connection.1Send a goaway frame and terminate the connection./Update settings and send an ack settings frame.!Send an entire pre-encoded frame.JSend the headers and as much of the response as is immediately available.gSend a PUSH_PROMISE frame, then act like OResponse; signal the MVar whether the promise has been sent.Send a chunk of the response.AThe result of writing data from a stream's queue into the buffer.6The stream has ended, and the trailers should be sent.qThe stream has more data immediately available, and we should re-enqueue it when the stream window becomes open.The stream queue has been drained and we've handed it off to its dedicated waiter thread, which will re-enqueue it when more data is available.Zklmnopqruvwxs}|{zy~Wklmnopqruvwxs}|{zy~$kl mnopqruvwxs}|{zy~NoneContent-Length None+GIN )The type to store enough information for settingsOnException.NIt would nice if responders could return values to workers. Unfortunately, i is already defined in WAI 2.0. It is not wise to change this type. So, a reference is shared by a W and its worker. The reference refers a value of this type as a return value. If TO, the worker continue to serve requests. Otherwise, the worker get finished.An y takes a function of status, headers, trailers, and body; this type implements that by currying some internal arguments.The token type of the RespondFunc is set to be (). This is a bit anti-climactic, but the real benefit of the token type is that the application is forced to call the responder, and making it a boring type doesn't break that property.This is the argument to a .DThis function is passed to workers. They also pass responses from Ls to this function. This function enqueues commands for the HTTP/2 sender.JSet up a waiter thread and run the stream body with functions to enqueue ss on the stream's queue.eHandle abnormal termination of a stream: mark it as closed, send a reset frame, and call the user's settingsOnException handler if applicable.Push the given 7 to the client if the settings allow it (specifically  and  ). Returns T$ if the stream was actually pushed.&This is the push function given to an .#Set up a pushed stream and run the | in its own thread. Waits for the sender thread to handle the push request. This can fail to push the stream and return SQ if the sender dequeued the push request after the associated stream was closed.A dedicated waiter thread to re-enqueue the stream in the priority tree whenever output becomes available. When the sender drains the queue and moves on to another stream, it drops a message in the td, and this thread wakes up, waits for more output to become available, and re-enqueues the stream.NoneNoneFINgSending a HTTP response to % according to R./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 R:  ::  ->  ->  ->   -> RHTTP 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 U 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. ::  ->  ->  -> R#HTTP response body is created from 6. Transfer-Encoding: chunked is used in HTTP/1.1. ::  ->  ->  -> R#HTTP response body is created from 6. Transfer-Encoding: chunked is used in HTTP/1.1. :: (  -> ( ->  ()) ->  ()) -> R -> R8No header is added and no Transfer-Encoding: is applied.Use (2 to send this data while respecting timeout rules.hThe version of Warp.;replaceHeader "Content-Type" "new" [("content-type","old")][("Content-Type","new")]   gdefault 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.  h gh   g  hNoneconcatCookie [("foo","bar")][("foo","bar")]OconcatCookie [("cookie","a=b"),("foo","bar"),("cookie","c=d"),("cookie","e=f")]*[("cookie","a=b; c=d; e=f"),("foo","bar")]NoneG !"# !"#None$!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","")&$%'&&$%NoneiReceiving a HTTP request from %% and parsing its header to create (.)*+,-iPeer'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 body/01content lengthtransfer-encoding234 remaining567i/7)*+,-i/01234567None8The platform-specific type of an open file to stream from. On Windows we don't have pread, so this is just a Handle; on Unix platforms with pread, this is a file descriptor supplied by the fd cache.9aRun the given action if the stream is not closed; handle any exceptions by resetting the stream.:5Open the file and start reading into the send buffer.;Read the given (OS-specific) file representation into the buffer. On non-Windows systems this uses pread; on Windows this ignores the position because we use the Handle's internal read position instead (because it's not potentially shared with other readers).<SRead as much of the file as is currently available into the buffer, then return a =q to indicate whether this file chunk has more data to send. If this read hit the end of the file range, return >; otherwise return ?^ so this stream will continue reading from the file the next time it's pulled from the queue.=>@A?89BCDE:;<FGHC =>@A?89BCDE:;<FGH NoneIJIIJ!NoneFNk Creating %( for plain HTTP based on a given socket.lRun an . on the given port. This calls r with a.m Serve an  and an . together on the given port.nThe generalized form of l.oRun an . on the port present in the PORT! environment variable. Uses the A/ given when the variable is unset. This calls r with a. Since 3.0.9pThe HTTP/2-aware form of o.qThe generalized form of o.rRun an . with the given N5. This opens a listen socket on the port defined in N and calls u.sThe HTTP/2-aware form of r.tThe generalized form of r.uAThis installs a shutdown handler for the given socket and calls x 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.vThe HTTP/2-aware form of u.wThe generalized form of u.xThe 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 z 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.5yThe generalized form of x.z6This modifies the connection maker so that it returns  for  (i.e. plain HTTP) then calls |.{The generalized form of z.|"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.4}The generalized form of |.jkKlmnopqrstuvwxyz{|}LM~NOget next chunkmaximum to flush3True == flushed the entire body, False == we didn'tPQRjkKlmnopqrstuvwxyz{|}LM~NOPQRjkKlmnopqrstuvwxyz{|}LM~NOPQRNonei  !"#$%&'()*+,-./01234567@BCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`fghijknqtwxyz{|}~iNOPQRSTUVWXYZ[\]^_`JKLMxz|nqtwy{}j~%&'()*+,-.k0/f21BCDE45673HIh !"#$@FG igNoneGIN&Port to listen on. Default value: 3000 Since 2.1.0-Interface to bind to. Default value: HostIPv4 Since 2.1.0QWhat to do with exceptions thrown by either the application or server. Default: c Since 2.1.0A function to create a R when an exception occurs. Default: d Since 2.1.0-What to do when a connection is opened. When Su is returned, the connection is closed immediately. Otherwise, the connection is going on. Default: always returns T. Since 2.1.0<What to do when a connection is closed. Default: do nothing. Since 2.1.0+Timeout value in seconds. Default value: 30 Since 2.1.0IUse an existing timeout manager instead of spawning a new one. If used, V is ignored. Since 2.1.0aCache 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 10Code 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.0Get the listening port. Since 2.1.1Get 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.10u  !"#$%&'()*+,-.123456789:;<=>?@ABCDFGHINabcdeghiklmoprsuvxz|ulorumpsvNacbdeA89:;<=>?xz|%&'()*+,-.k21BCD45673HIh !"#$@FGig S"#$ % % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9:;<=>?@ABBCDEFGGHIJKLMNOPQRSTUUVWXYZ[\]^_`abcdefghijklmnnopqrstuvwxyz{|}~!!!!!!!!!!!!!!!!!!!!!!     ( (                      &    ! ) "#$ % & ' ' ( ( )   * + , - . / 0 ) 1 2 345A6789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijkljkmnopqrstuvwxyz{|}~~w)1ghggg )  n gh nggghgjk !"#$%&'()*+,-./0123456789:;<gh=gh>??@ABgCDEFGHIJKLMNOPQRSTUVWXYZe[\ ] ^!_!`!a!b!c!d!e!fgwarp_EeR8pPP3WKqFEe3cKIDej0Network.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.Request%Network.Wai.Handler.Warp.HTTP2.WorkerNetwork.Wai.Handler.Warp.IO!Network.Wai.Handler.Warp.Response$Network.Wai.Handler.Warp.HTTP2.HPACK'Network.Wai.Handler.Warp.HTTP2.Receiver&Network.Wai.Handler.Warp.RequestHeader Network.Wai.Handler.Warp.Request%Network.Wai.Handler.Warp.HTTP2.SenderNetwork.Wai.Handler.Warp.HTTP2Network.Wai.Handler.Warp.Runstrea_DGqjBf0vAJlDggX4NRDaSwData.Streaming.Network.InternalHostPreference TimeoutThreadHandle TimeoutActionManager initialize stopManagerregisterregisterKillThreadticklecancelpauseresume withManager DateCacheGMTDate withDateCachegetDateMutableFdCacheRefresh withFdCachegetFd TransportTCPTLStlsMajorVersiontlsMinorVersiontlsNegotiatedProtocol tlsChiperIDSource InternalInfo threadHandletimeoutManagerfdCacher dateCacher Connection connSendMany connSendAll connSendFile connCloseconnRecv connRecvBufconnWriteBufferconnBufferSizeRecvBufRecvBufSizeBufferSendFileFileId fileIdPathfileIdFdInvalidRequestNotEnoughLines BadFirstLineNonHttpIncompleteHeadersConnectionClosedByPeerOverLargeHeaderBadProxyHeader HeaderValuePort bufferSizeallocateBuffer freeBuffercopy IndexedHeaderrequestMaxIndexsendFile readSendFile ProxyProtocolProxyProtocolNoneProxyProtocolRequiredProxyProtocolOptionalSettings settingsPort settingsHostsettingsOnExceptionsettingsOnExceptionResponsesettingsOnOpensettingsOnClosesettingsTimeoutsettingsManagersettingsFdCacheDurationsettingsBeforeMainLoop settingsForksettingsNoParsePathsettingsInstallShutdownHandlersettingsServerNamesettingsMaximumBodyFlushsettingsProxyProtocolsettingsSlowlorisSizedefaultSettingsdefaultShouldDisplayExceptiondefaultOnExceptiondefaultOnExceptionResponseexceptionResponseForDebugmakePlainReceiveN sendResponse warpVersion recvRequestServeConnectionsocketConnectionrunrunHTTP2runServerunEnv runHTTP2Env runServeEnv runSettingsrunHTTP2SettingsrunServeSettingsrunSettingsSocketrunHTTP2SettingsSocketrunServeSettingsSocketrunSettingsConnectionrunServeSettingsConnectionrunSettingsConnectionMakerrunServeSettingsConnectionMaker runSettingsConnectionMakerSecure%runServeSettingsConnectionMakerSecure serveDefault serveHTTP2setPortsetHostsetOnExceptionsetOnExceptionResponse setOnOpen setOnClose setTimeout setManagersetFdCacheDurationsetBeforeMainLoopsetNoParsePathgetPortgetHost getOnOpen getOnClosegetOnExceptionsetInstallShutdownHandler setServerNamesetMaximumBodyFlushsetForksetProxyProtocolNonesetProxyProtocolRequiredsetProxyProtocolOptionalsetSlowlorisSize pauseTimeoutwindowsThreadBlockHackcatchIOversionbindirlibdirdatadir libexecdir sysconfdir getBinDir getLibDir getDataDir getLibexecDir getSysconfDirgetDataFileNameTablereadInt readInt64 mhDigitToIntisDigit goawayFrame resetFrame settingsFrame pingFramewindowUpdateFrameBRMMapSomesearch searchWithisEmptyempty singletoninsertfromListtoListfromSortedList toSortedList pruneWithDigitUnoDueColorLeafNodeOneTomsnoctopinsert' balanceL' balanceR'turnBincraddlinkAlllinkmergevalid isBalanced isBlackSameblacks isRedSeparatereds isOrdered$fEqMMapbase Data.IORefatomicModifyIORef'atomicWriteIORefatomicModifyIORef modifyIORef' modifyIORef mkWeakIORef GHC.IORef writeIORef readIORefnewIORefIORefstart setAction ThreadSetCommandStopSpawnReplacestop spawnActionreplaceWithAction newThreadSetdelkillCounter newCounter waitForZeroincreasedecreaseStateActiveInactivePausedCanceled ignoreAll killIfExist$fShowTimeoutThread$fExceptionTimeoutThreadgetCurrentGMTDateSystem.Posix.TypesFdFdCacheHashFdEntry MutableStatusStatusstatusnewActiveStatusrefreshinactive newFdEntryfdCachelookcleanprune terminate BufferPool readSource'mkSource readSourceleftoverSourcereadLeftoverSourceisTransportSecure$fExceptionInvalidRequest$fShowInvalidRequestlargeBufferSize minBufferSize newBufferPoolmallocBS usefulBuffer getBuffer putBufferwithForeignBufferwithBufferPooltoBuilderBufferbufferIO composeHeader httpVer11 httpVer10 copyStatus copyHeaders copyHeadercopyCRLFzerospccoloncrlfresponseMaxIndexindexRequestHeaderidxContentLengthidxTransferEncoding idxExpect idxConnectionidxRangeidxHostrequestKeyIndexdefaultIndexRequestHeaderindexResponseHeader idxServeridxDateresponseKeyIndextraverseHeaderc_pread packHeadermini positionReadwai_3sHomsuP6HT0MoMaMYttFuNetwork.Wai.InternalResponseghc-prim GHC.TypesFalseTrueGHC.BaseNothingc_recv makeReceiveNreceiveNspellreceive receiveBuf receiveloopISource readISource ChunkStateNeedLenNeedLenNewlineHaveLen DoneChunkingCSource mkISource mkCSource readCSource isHexDigitconcurrencyRefContext concurrencypushConcurrency continuedcurrentStreamIdnextPushStreamIdAuxSequence GHC.Conc.SyncTVarSyncSyncNone SyncFinishSyncNextOutputSFileSBuilderSFlushSFinishOFinishOGoaway OSettingsOFrame OResponseOPushONextControlCFinishCNextCNone StreamTableStream streamNumber streamStatestreamContentLengthstreamBodyLength streamWindowstreamPriority StreamStateIdleOpen HalfClosedClosed ClosedCodeFinishedKilledReset ResetByMe OpenState JustOpened ContinuedNoBodyHasBodyBody http2settings streamTableinputQoutputQencodeDynamicTabledecodeDynamicTableconnectionWindowPersistNext BytesFilledDynaNextInputhttp2verisHTTP2 outputStream newContext clearContextisIdleisOpen isHalfClosedisClosed newStreamopenedclosedenqueueWhenWindowIsOpenenqueueOrSpawnTemporaryWaiter $fShowStream$fShowStreamState $fShowControlvhCLPseudo colonMethod colonPath colonAuth contentLenMkReq ValidHeadersvhMethodvhPathvhAuthvhHeader mkRequest emptyPseudovalidateHeaders newReadBodyreadBody StreamInfoThreadContinueResponseReceivedRespondNetwork.Wai.HTTP2HTTP2Application Responderresponse runStream cleanupStream pushResponderhttp2_J9mKVBOtGJFB48ysSqvLykNetwork.HTTP2.Types enablePushmaxConcurrentStreamsactuallyPushResponderwaiterBreakworkernewThreadContinuesetThreadContinuegetThreadContinue newStreamInfoclearStreamInfo setStreamInfo getStreamInfo$fExceptionBreak toBufIOWithhttpt_K1GcYiiEBxaBOQVfjX52vaNetwork.HTTP.Types.HeaderResponseHeaders Network.Wai responseFileNetwork.HTTP.Types.StatusGHC.IOFilePathMaybeFilePartJustresponseBuilderbytes_6elQVSg5cWdFrvRnfxTUrH Data.ByteString.Builder.InternalBuilderresponseStream StreamingBody responseRawIOData.ByteString.Internal ByteString sendFragment replaceHeaderRspRspFile RspBuilder RspStreamRspRaw fileRangefileRangeSizedsanitizeHeaderscontainsNewlinessanitizeHeaderValuesendRspsendResponseNoBodyinfoFromRequest checkPersist checkChunkinfoFromResponsehasBodyaddTransferEncodingaddDate addServercomposeHeaderBuilder concatCookiehpackEncodeHeaderhpackEncodeCIHeadershpackEncodeRawHeadershpackDecodeHeader frameReceivercontrolguardIt checkPrioritystreamparseRequestLine parseHeaderparseHeaderLinesparseByteRangesRequestTHStatus BSEndoListBSEndomaxTotalHeaderLength Application headerLines handleExpect bodyAndSourcetoLength isChunked timeoutBodypushcheckCRpauseTimeoutKeyOpenFile unlessClosed runStreamFile readOpenFile fillBufFileLeftoverLZeroLFileLOneLTwo getWindowSize frameSenderfillStreamBodyGetNextrunStreamBuilder fillBufStream nextForStreamhttp2goaway.:acceptConnectionforkflushEntireBody flushBody wrappedRecvsetSocketCloseOnExecgracefulShutdown