Sophie

Sophie

distrib > Fedora > 15 > i386 > by-pkgid > 0125b4ac7f14afa3977410cd764c8601 > files > 83

ghc-wai-extra-devel-0.4.3-1.fc15.i686.rpm

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html>
<head>
<!-- Generated by HsColour, http://www.cs.york.ac.uk/fp/darcs/hscolour/ -->
<title>Network/Wai/Middleware/Autohead.hs</title>
<link type='text/css' rel='stylesheet' href='hscolour.css' />
</head>
<body>
<pre><a name="line-1"></a><span class='hs-comment'>{-# LANGUAGE OverloadedStrings #-}</span>
<a name="line-2"></a><span class='hs-comment'>-- | Automatically produce responses to HEAD requests based on the underlying</span>
<a name="line-3"></a><span class='hs-comment'>-- applications GET response.</span>
<a name="line-4"></a><span class='hs-keyword'>module</span> <span class='hs-conid'>Network</span><span class='hs-varop'>.</span><span class='hs-conid'>Wai</span><span class='hs-varop'>.</span><span class='hs-conid'>Middleware</span><span class='hs-varop'>.</span><span class='hs-conid'>Autohead</span> <span class='hs-layout'>(</span><span class='hs-varid'>autohead</span><span class='hs-layout'>)</span> <span class='hs-keyword'>where</span>
<a name="line-5"></a>
<a name="line-6"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>Network</span><span class='hs-varop'>.</span><span class='hs-conid'>Wai</span>
<a name="line-7"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>Data</span><span class='hs-varop'>.</span><span class='hs-conid'>Monoid</span> <span class='hs-layout'>(</span><span class='hs-varid'>mempty</span><span class='hs-layout'>)</span>
<a name="line-8"></a><span class='hs-keyword'>import</span> <span class='hs-conid'>Data</span><span class='hs-varop'>.</span><span class='hs-conid'>Enumerator</span> <span class='hs-layout'>(</span><span class='hs-varid'>enumEOF</span><span class='hs-layout'>,</span> <span class='hs-layout'>(</span><span class='hs-varop'>$$</span><span class='hs-layout'>)</span><span class='hs-layout'>)</span>
<a name="line-9"></a>
<a name="line-10"></a><a name="autohead"></a><span class='hs-definition'>autohead</span> <span class='hs-keyglyph'>::</span> <span class='hs-conid'>Middleware</span>
<a name="line-11"></a><span class='hs-definition'>autohead</span> <span class='hs-varid'>app</span> <span class='hs-varid'>req</span>
<a name="line-12"></a>    <span class='hs-keyglyph'>|</span> <span class='hs-varid'>requestMethod</span> <span class='hs-varid'>req</span> <span class='hs-varop'>==</span> <span class='hs-str'>"HEAD"</span> <span class='hs-keyglyph'>=</span> <span class='hs-keyword'>do</span>
<a name="line-13"></a>        <span class='hs-varid'>res</span> <span class='hs-keyglyph'>&lt;-</span> <span class='hs-varid'>app</span> <span class='hs-varid'>req</span> <span class='hs-layout'>{</span> <span class='hs-varid'>requestMethod</span> <span class='hs-keyglyph'>=</span> <span class='hs-str'>"GET"</span> <span class='hs-layout'>}</span>
<a name="line-14"></a>        <span class='hs-keyword'>case</span> <span class='hs-varid'>res</span> <span class='hs-keyword'>of</span>
<a name="line-15"></a>            <span class='hs-conid'>ResponseFile</span> <span class='hs-varid'>s</span> <span class='hs-varid'>hs</span> <span class='hs-keyword'>_</span> <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>return</span> <span class='hs-varop'>$</span> <span class='hs-conid'>ResponseBuilder</span> <span class='hs-varid'>s</span> <span class='hs-varid'>hs</span> <span class='hs-varid'>mempty</span>
<a name="line-16"></a>            <span class='hs-conid'>ResponseBuilder</span> <span class='hs-varid'>s</span> <span class='hs-varid'>hs</span> <span class='hs-keyword'>_</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-varid'>return</span> <span class='hs-varop'>$</span> <span class='hs-conid'>ResponseBuilder</span> <span class='hs-varid'>s</span> <span class='hs-varid'>hs</span> <span class='hs-varid'>mempty</span>
<a name="line-17"></a>            <span class='hs-conid'>ResponseEnumerator</span> <span class='hs-varid'>e</span> <span class='hs-keyglyph'>-&gt;</span> <span class='hs-keyword'>do</span>
<a name="line-18"></a>                <span class='hs-keyword'>let</span> <span class='hs-varid'>helper</span> <span class='hs-varid'>f</span> <span class='hs-keyglyph'>=</span>
<a name="line-19"></a>                        <span class='hs-keyword'>let</span> <span class='hs-varid'>helper'</span> <span class='hs-varid'>s</span> <span class='hs-varid'>hs</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>enumEOF</span> <span class='hs-varop'>$$</span> <span class='hs-varid'>f</span> <span class='hs-varid'>s</span> <span class='hs-varid'>hs</span>
<a name="line-20"></a>                         <span class='hs-keyword'>in</span> <span class='hs-varid'>e</span> <span class='hs-varid'>helper'</span>
<a name="line-21"></a>                <span class='hs-varid'>return</span> <span class='hs-varop'>$</span> <span class='hs-conid'>ResponseEnumerator</span> <span class='hs-varid'>helper</span>
<a name="line-22"></a>    <span class='hs-keyglyph'>|</span> <span class='hs-varid'>otherwise</span> <span class='hs-keyglyph'>=</span> <span class='hs-varid'>app</span> <span class='hs-varid'>req</span>
<a name="line-23"></a>
</pre></body>
</html>