X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;ds=sidebyside;f=ghc%2Fcompiler%2Fmain%2FMain.hs;h=7da0074e2c7536b24455c740cb388426620ef6ad;hb=3a223cd2811d46295048b3a2dab11403ca291b20;hp=20a551ea1ad34fe6ba0bd1b67fa05f6586d87921;hpb=d28ba8c800901bea01f70c4719278c2a364cf9fc;p=ghc-hetmet.git diff --git a/ghc/compiler/main/Main.hs b/ghc/compiler/main/Main.hs index 20a551e..7da0074 100644 --- a/ghc/compiler/main/Main.hs +++ b/ghc/compiler/main/Main.hs @@ -1,7 +1,7 @@ {-# OPTIONS -fno-warn-incomplete-patterns -optc-DNON_POSIX_SOURCE #-} ----------------------------------------------------------------------------- --- $Id: Main.hs,v 1.127 2003/06/23 10:35:17 simonpj Exp $ +-- $Id: Main.hs,v 1.131 2003/07/21 15:14:18 ross Exp $ -- -- GHC Driver program -- @@ -97,7 +97,7 @@ main = hFlush stdout case exception of -- an IO exception probably isn't our fault, so don't panic - IOException _ -> hPutStr stderr (show exception) + IOException _ -> hPutStrLn stderr (show exception) AsyncException StackOverflow -> hPutStrLn stderr "stack overflow: use +RTS -K \ \to increase it" @@ -233,6 +233,12 @@ main = ---------------- Final sanity checking ----------- checkOptions mode srcs objs + -- We always link in the base package in + -- one-shot linking. Any other packages + -- required must be given using -package + -- options on the command-line. + let def_hs_pkgs = [basePackage, haskell98Package] + ---------------- Do the business ----------- case mode of DoMake -> doMake srcs @@ -242,16 +248,11 @@ main = endMkDependHS } StopBefore p -> do { compileFiles mode srcs; return () } DoMkDLL -> do { o_files <- compileFiles mode srcs; - doMkDLL o_files } + doMkDLL o_files def_hs_pkgs } DoLink -> do { o_files <- compileFiles mode srcs; omit_linking <- readIORef v_NoLink; when (not omit_linking) - (staticLink o_files - [basePackage, haskell98Package]) } - -- We always link in the base package in - -- one-shot linking. Any other packages - -- required must be given using -package - -- options on the command-line. + (staticLink o_files def_hs_pkgs) } #ifndef GHCI DoInteractive -> throwDyn (CmdLineError "not built for interactive use") @@ -265,6 +266,10 @@ main = checkOptions :: GhcMode -> [String] -> [String] -> IO () -- Final sanity checking before kicking off a compilation (pipeline). checkOptions mode srcs objs = do + -- Complain about any unknown flags + let unknown_opts = [ f | f@('-':_) <- srcs ] + when (notNull unknown_opts) (unknownFlagsErr unknown_opts) + -- -ohi sanity check ohi <- readIORef v_Output_hi if (isJust ohi && @@ -284,10 +289,6 @@ checkOptions mode srcs objs = do then throwDyn (UsageError "no input files") else do - -- Complain about any unknown flags - let unknown_opts = [ f | f@('-':_) <- srcs ] - when (notNull unknown_opts) (unknownFlagsErr unknown_opts) - -- Verify that output files point somewhere sensible. verifyOutputFiles @@ -317,7 +318,7 @@ compileFile mode stop_flag src = do | mode==DoLink || mode==DoMkDLL = Nothing | otherwise = o_file - runPipeline mode stop_flag True maybe_o_file src + runPipeline mode stop_flag True maybe_o_file src Nothing{-no ModLocation-} -- ----------------------------------------------------------------------------