forked from ndmitchell/shake
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtravis.hs
112 lines (90 loc) · 3.81 KB
/
travis.hs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
{-# OPTIONS_GHC -fno-warn-unused-binds -fno-warn-unused-imports #-}
import Data.Char
import Data.Function
import System.Directory.Extra
import System.Environment
import System.Time.Extra
import System.Info.Extra
import Data.Functor
import Data.List
import Data.Maybe
import Control.Exception.Extra
import Control.Monad
import System.Process.Extra
requiresShake = words "ghc-make shake-language-c"
ms x = show $ ceiling $ x * 1000
cmd :: String -> IO Seconds
cmd x = do
putStrLn $ "$ " ++ x
(t, _) <- duration $ system_ x
putStrLn $ "Took " ++ showDuration t
return t
main = do
args <- getArgs
unless (null args) $ error "Terminating early"
-- check the TypeScript pieces
unless isMac $
void $ cmd "sudo apt-get --allow-unauthenticated install nodejs"
cmd "npm install -g typescript"
cmd "tsc --project html/ts"
cmd "npm install -g tslint"
cmd "tslint --project html/ts"
-- grab ninja
cmd "git clone https://github.com/martine/ninja"
cmd "cd ninja && ./configure.py --bootstrap"
copyFile "ninja/ninja" "nin"
withCurrentDirectory "ninja" $ do
replicateM_ 3 $ do
ninjaVer <- cmd "../nin --version"
shakeVer <- cmd "shake --version --verbose"
shakeVer <- cmd "shake --version --verbose"
shakeVer <- cmd "shake --version --quiet"
shakeVer <- cmd "shake --version"
shakeVer <- cmd "shake --version"
putStrLn $ "--version for Ninja is " ++ ms ninjaVer ++ ", for Shake is " ++ ms shakeVer
cmd "shake --version; shake -C does_not_exist; echo end" -- check for #22
retry 3 $ do
-- time Ninja
cmd "../nin -t clean"
ninjaFull <- cmd "../nin -j3 -d stats"
ninjaProfile "build/.ninja_log"
putStrLn =<< readFile "build/.ninja_log"
ninjaZero <- cmd "../nin -j3 -d stats"
cmd "../nin -t clean"
shakeFull <- cmd "shake -j3 --verbose"
-- time Shake
cmd "../nin -t clean"
shakeFull <- cmd "shake -j3 --quiet --timings"
cmd "shake --no-build --report=-"
shakeZero <- cmd "shake -j3 --quiet --timings"
-- Diagnostics
cmd "ls -l .shake* build/.ninja*"
cmd "shake -VV"
shakeNone <- cmd "shake --rebuild --skip-commands --timings"
putStrLn $ "--rebuild --skip-commands took " ++ ms shakeNone
putStrLn $ "Ninja was " ++ ms ninjaFull ++ " then " ++ ms ninjaZero
putStrLn $ "Shake was " ++ ms shakeFull ++ " then " ++ ms shakeZero
when (ninjaFull < shakeFull) $
error "ERROR: Ninja build was faster than Shake"
when (ninjaZero + 0.1 < shakeZero) $
error "ERROR: Ninja zero build was more than 0.1s faster than Shake"
createDirectoryIfMissing True "temp"
withCurrentDirectory "temp" $
cmd "shake --demo --keep-going"
isHead <- (== Just "1") <$> lookupEnv "GHC_HEAD"
ghcver <- fromMaybe "" <$> lookupEnv "GHCVER"
unless isHead $ do
ver <- do
src <- readFile "shake.cabal"
return $ head [dropWhile isSpace x | x <- lines src, Just x <- [stripPrefix "version:" x]]
forM_ requiresShake $ \x ->
retry 3 $ cmd $ "cabal install " ++ x ++ " --constraint=shake==" ++ ver
ninjaProfile :: FilePath -> IO ()
ninjaProfile src = do
src <- readFile src
let times = [(read start, read stop)
| start:stop:_ <- nubBy ((==) `on` (!! 3)) $
reverse $ map words $ filter (not . isPrefixOf "#") $ lines src]
let work = sum $ map (uncurry subtract) times
let last = maximum $ map snd times
putStrLn $ "Ninja profile report: in " ++ show last ++ " ms did " ++ show work ++ " ms work, ratio of " ++ show (work / last)