text / tests / benchmarks / HtmlCombinator.hs

The default branch has multiple heads

{-# LANGUAGE BangPatterns, OverloadedStrings #-}
import Data.Monoid (mappend, mconcat)
import Prelude hiding (putStr)
import Data.Text.Lazy.Builder (Builder, fromText, toLazyText)
import Data.Text.Lazy.IO (putStr)

import qualified Data.Text as T

main :: IO ()
main = do
  putStr "Content-Type: text/html\n\n<table>"
  putStr . toLazyText $ mconcat (replicate 20000 makeRow) 
  putStr "</table>"

makeRow :: Builder
makeRow = mconcat (map makeCol [1..50])

makeCol :: Int -> Builder
makeCol 1 = fromText "<tr><td>1</td>"
makeCol 50 = fromText "<td>50</td></tr>"
makeCol i = fromText "<td>" `mappend` (textInt i `mappend` fromText "</td>")

textInt :: Int -> Builder
textInt = fromText . T.pack . show
Tip: Filter by directory path e.g. /media app.js to search for public/media/app.js.
Tip: Use camelCasing e.g. ProjME to search for ProjectModifiedEvent.java.
Tip: Filter by extension type e.g. /repo .js to search for all .js files in the /repo directory.
Tip: Separate your search with spaces e.g. /ssh pom.xml to search for src/ssh/pom.xml.
Tip: Use ↑ and ↓ arrow keys to navigate and return to view the file.
Tip: You can also navigate files with Ctrl+j (next) and Ctrl+k (previous) and view the file with Ctrl+o.
Tip: You can also navigate files with Alt+j (next) and Alt+k (previous) and view the file with Alt+o.