{-# OPTIONS -fno-warn-incomplete-patterns #-}
-----------------------------------------------------------------------------
--- $Id: Main.hs,v 1.55 2001/02/27 12:36:37 rrt Exp $
+-- $Id: Main.hs,v 1.58 2001/03/05 12:18:21 simonpj Exp $
--
-- GHC Driver program
--
#ifdef GHCI
import InteractiveUI
+import Char ( toLower )
#endif
#ifndef mingw32_TARGET_OS
import DriverMkDepend
import DriverUtil
import Panic
-import DriverPhases ( Phase(..), haskellish_file )
+import DriverPhases ( Phase(..), haskellish_file, objish_file )
import CmdLineOpts
import TmpFiles
import Finder ( initFinder )
import IO
import Monad
import List
-import Char ( toLower )
import System
import Maybe
else do am_inplace <- doesFileExist inplace_pkgconfig
if am_inplace
then writeIORef v_Path_package_config inplace_pkgconfig
- else throwDyn (OtherError "can't find package.conf")
+ else throwDyn (OtherError ("Can't find package.conf in " ++ inplace_pkgconfig))
-- set the location of our various files
if am_installed
return others
beginMake :: [String] -> IO ()
-beginMake mods
- = do case mods of
+beginMake fileish_args
+ = do let (objs, mods) = partition objish_file fileish_args
+ mapM (add v_Ld_inputs) objs
+
+ case mods of
[] -> throwDyn (UsageError "no input files")
[mod] -> do state <- cmInit Batch
cmLoadModule state mod
#else
beginInteractive fileish_args
= do minus_ls <- readIORef v_Cmdline_libraries
- let is_libraryish nm
- = let nmr = map toLower (reverse nm)
- in take 2 nmr == "o."
- libs = map Left (filter is_libraryish fileish_args)
- ++ map Right minus_ls
- mods = filter (not.is_libraryish) fileish_args
- mod = case mods of
- [] -> Nothing
- [mod] -> Just mod
- _ -> throwDyn (UsageError
- "only one module allowed with --interactive")
+
+ let (objs, mods) = partition objish_file fileish_args
+ libs = map Left objs ++ map Right minus_ls
+
state <- cmInit Interactive
- interactiveUI state mod libs
+ case mods of
+ [] -> interactiveUI state Nothing libs
+ [mod] -> interactiveUI state (Just mod) libs
+ _ -> throwDyn (UsageError
+ "only one module allowed with --interactive")
#endif