summaryrefslogtreecommitdiff
path: root/examples/phrasebook/Compile.hs
blob: bc64a6f30d824680467381ec744bbd9facc6c8bf (plain)
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
import Data.List(partition)
import Control.Monad(when)
import System.Cmd(system)
import System.Environment(getArgs)

-- (c) Aarne Ranta 2010 under GNU LGPL

-- Compile files into pgf, in chosen combinations.

-- Usage: runghc Compile (-make | -link)? Eng Fre Fin ...
-- The -make option links all pgf files to one in the end
-- The -link option only links, without first compiling
-- Arguments whose length are 3 characters are prefixed with mainmodu.
-- Other arguments are passed literally.

-- Thus, for instance, to produce an English-Swedish-Romanian phrasebook with English
-- disambiguation, the command is
--
--  runghc Compile -link Eng Swe Ron DisambPhrasebookEng


-- change this to apply to another project; alternatively, just use full file names
mainmodu = "Phrasebook"

main = do
  (opts,langs) <- partition ((=='-') . head) `fmap` getArgs
  let modus = [mkFile la | la <- langs]
  let opt = elem "-opt" opts
  putStrLn $ unwords modus
  when (notElem "-link" opts) $ mapM_ (compileOne opt) modus
  case opts of
    _ | elem "-make" opts || elem "-link" opts -> do
      let comm = "gf -make -s " ++ unwords (map (++ ".pgf") modus)
      putStrLn comm
      system comm
      return () 
    _ -> return ()

compileOne opt modu = do
  let optim = if opt then " -optimize-pgf" else ""
      comm = "gf -make -s" ++ optim ++ " -name=" ++ 
             modu ++ " " ++ modu ++ ".gf" ++
             " +RTS -K32M"
  putStrLn comm
  system comm

mkFile la = if length la == 3 then mainmodu ++ la else la