summaryrefslogtreecommitdiff
path: root/examples/tutorial/embedded/TranslatorLoop.hs
blob: 18b20146ec569589c44f95090cbced0ea38ae644 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
module Main where

import GF.Embed.EmbedAPI
import System (getArgs)

main :: IO () 
main = do
  file:_ <- getArgs
  gr <- file2grammar file
  loop (translate gr)

loop :: (String -> String) -> IO ()
loop trans = do 
  s <- getLine
  if s == "quit" then putStrLn "bye" else do  
    putStrLn $ trans s
    loop trans

translate :: MultiGrammar -> String -> String
translate gr = unlines . map transLine . lines where
  transLine s = case parseAllLang gr (startCat gr) s of
    (lg,t:_):_ -> unlines [linearize gr l t | l <- languages gr, l /= lg]
    _ -> "NO PARSE"