summaryrefslogtreecommitdiff
path: root/src-3.0/GF/Embed/TemplateApp.hs
diff options
context:
space:
mode:
authoraarne <aarne@cs.chalmers.se>2008-05-21 09:26:44 +0000
committeraarne <aarne@cs.chalmers.se>2008-05-21 09:26:44 +0000
commit055c0d0d5a5bb0dc75904fe53df7f2e4f5732a8f (patch)
tree0e63fb68c69c8f6ad0f78893c63420f0a3600e1c /src-3.0/GF/Embed/TemplateApp.hs
parent915a1de71783ab8446b1af9e72c7ba7dfbc12d3f (diff)
GF/src is now for 2.9, and the new sources are in src-3.0 - keep it this way until the release of GF 3
Diffstat (limited to 'src-3.0/GF/Embed/TemplateApp.hs')
-rw-r--r--src-3.0/GF/Embed/TemplateApp.hs44
1 files changed, 44 insertions, 0 deletions
diff --git a/src-3.0/GF/Embed/TemplateApp.hs b/src-3.0/GF/Embed/TemplateApp.hs
new file mode 100644
index 000000000..f8722691f
--- /dev/null
+++ b/src-3.0/GF/Embed/TemplateApp.hs
@@ -0,0 +1,44 @@
+module Main where
+
+import GF.Embed.EmbedAPI
+import System
+
+-- Simple translation application built on EmbedAPI. AR 7/10/2005
+
+main :: IO ()
+main = do
+ file:_ <- getArgs
+ grammar <- file2grammar file
+ translate grammar
+
+translate :: MultiGrammar -> IO ()
+translate grammar = do
+ s <- getLine
+ if s == "quit" then return () else do
+ treat grammar s
+ translate grammar
+
+treat :: MultiGrammar -> String -> IO ()
+treat grammar s = putStrLn $ case comm of
+ ["lin"] -> unlines $ linearizeAll grammar $ readTree grammar rest
+ ["lin",lang] -> linearize grammar lang $ readTree grammar rest
+ ["parse",cat] -> unlines $ map showTree $ concat $ parseAll grammar cat rest
+ ["parse",lang,cat] -> unlines $ map showTree $ parse grammar lang cat rest
+ ["langs"] -> unwords $ languages grammar
+ ["cats"] -> unwords $ categories grammar
+ ["help"] -> helpMsg
+ _ -> "command not interpreted: " ++ s
+ where
+ (comm,rest) = (words c,drop 1 r) where
+ (c,r) = span (/=':') s
+
+helpMsg = unlines [
+ "lin : <Tree>",
+ "lin <Lang> : <Tree>",
+ "parse <Cat> : <String>",
+ "parse <Lang> <Cat> : <String>",
+ "langs",
+ "cats",
+ "help",
+ "quit"
+ ]