mirror of
https://github.com/ilyakooo0/vty.git
synced 2024-11-29 08:49:40 +03:00
39 lines
1007 B
Haskell
39 lines
1007 B
Haskell
{-# LANGUAGE BangPatterns #-}
|
|
module BenchNoDiffOpt where
|
|
|
|
{-# LANGUAGE BangPatterns #-}
|
|
import Graphics.Vty
|
|
import Verify
|
|
|
|
import Control.Concurrent( threadDelay )
|
|
import Control.Monad( liftM2 )
|
|
|
|
import qualified Data.ByteString.Char8 as B
|
|
import Data.List
|
|
|
|
import System.Environment( getArgs )
|
|
import System.IO
|
|
import System.Random
|
|
|
|
bench0 = do
|
|
let fixedGen = mkStdGen 0
|
|
setStdGen fixedGen
|
|
vty <- mkVty defaultConfig
|
|
(w,h) <- displayBounds $ outputIface vty
|
|
let images = return $ (image0, image1)
|
|
image0 = charFill defAttr 'X' w h
|
|
image1 = charFill defAttr '0' w h
|
|
bench d = do
|
|
flipOut vty 300 image0 image1
|
|
shutdown vty
|
|
return $ Bench images bench
|
|
|
|
flipOut vty n image0 image1 =
|
|
let !pLeft = picForImage image0
|
|
!pRight = picForImage image1
|
|
wLeft 0 = return ()
|
|
wLeft n = update vty pLeft >> wRight (n-1)
|
|
wRight 0 = return ()
|
|
wRight n = update vty pRight >> wLeft (n-1)
|
|
in wLeft n
|