X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2Fcompiler%2Fmain%2FMain.hs;h=7da0074e2c7536b24455c740cb388426620ef6ad;hb=3a223cd2811d46295048b3a2dab11403ca291b20;hp=c4670a3186566a00d47af5a79aa27c549ca7aa80;hpb=f91a2e4cc88cd71c7e22895df297e5dfcdd66f84;p=ghc-hetmet.git diff --git a/ghc/compiler/main/Main.hs b/ghc/compiler/main/Main.hs index c4670a3..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.126 2003/06/17 23:26:30 sof 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" @@ -160,7 +160,7 @@ main = extra_non_static <- processArgs static_flags (unreg_opts ++ way_opts ++ pkg_extra_opts) [] - -- give the static flags to hsc + -- Give the static flags to hsc static_opts <- buildStaticHscOpts writeIORef v_Static_hsc_opts static_opts @@ -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-} -- ----------------------------------------------------------------------------