summaryrefslogtreecommitdiff
path: root/src/compiler/GF.hs
diff options
context:
space:
mode:
authorkrasimir <krasimir@chalmers.se>2009-12-13 18:50:29 +0000
committerkrasimir <krasimir@chalmers.se>2009-12-13 18:50:29 +0000
commitf85232947e74ee7ef8c7b0ad2338212e7e68f1be (patch)
tree667b886a5e3a4b026a63d4e3597f32497d824761 /src/compiler/GF.hs
parentd88a865faff59c98fc91556ff8700b10ee5f2df8 (diff)
reorganize the directories under src, and rescue the JavaScript interpreter from deprecated
Diffstat (limited to 'src/compiler/GF.hs')
-rw-r--r--src/compiler/GF.hs45
1 files changed, 45 insertions, 0 deletions
diff --git a/src/compiler/GF.hs b/src/compiler/GF.hs
new file mode 100644
index 000000000..32a95ca1f
--- /dev/null
+++ b/src/compiler/GF.hs
@@ -0,0 +1,45 @@
+{-# OPTIONS -cpp #-}
+module Main where
+
+import GFC
+import GFI
+import GF.Data.ErrM
+import GF.Infra.Option
+import GF.Infra.UseIO
+import Paths_gf
+
+import Data.Version
+import System.Directory
+import System.Environment (getArgs)
+import System.Exit
+import System.IO
+#ifdef mingw32_HOST_OS
+import System.Win32.Console
+import System.Win32.NLS
+#endif
+
+main :: IO ()
+main = do
+#ifdef mingw32_HOST_OS
+ codepage <- getACP
+ setConsoleCP codepage
+ setConsoleOutputCP codepage
+#endif
+ args <- getArgs
+ case parseOptions args of
+ Ok (opts,files) -> do curr_dir <- getCurrentDirectory
+ lib_dir <- getLibraryDirectory opts
+ mainOpts (fixRelativeLibPaths curr_dir lib_dir opts) files
+ Bad err -> do hPutStrLn stderr err
+ hPutStrLn stderr "You may want to try --help."
+ exitFailure
+
+mainOpts :: Options -> [FilePath] -> IO ()
+mainOpts opts files =
+ case flag optMode opts of
+ ModeVersion -> putStrLn $ "Grammatical Framework (GF) version " ++ showVersion version
+ ModeHelp -> putStrLn helpMessage
+ ModeInteractive -> mainGFI opts files
+ ModeRun -> mainRunGFI opts files
+ ModeCompiler -> dieIOE (mainGFC opts files)
+