[project @ 2000-10-27 09:17:20 by sewardj]
[ghc-hetmet.git] / ghc / compiler / utils / Argv.lhs
index 821a806..0d6262a 100644 (file)
@@ -1,37 +1,34 @@
 %
-% (c) The AQUA Project, Glasgow University, 1996
+% (c) The AQUA Project, Glasgow University, 1996-1998
 %
 \section[Argv]{@Argv@: direct (non-standard) access to command-line arguments}
 
 \begin{code}
-#include "HsVersions.h"
-
 module Argv ( argv ) where
 
-import PreludeGlaST    ( indexAddrOffAddr )
+#include "HsVersions.h"
 
-CHK_Ubiq() -- debugging consistency check
+import FastString
 
-#if __GLASGOW_HASKELL__ >= 200
-# define ADDR      GHCbase.Addr
-# define PACK_STR   packCString
+#if __GLASGOW_HASKELL__ <= 302
+import GlaExts         ( Addr )
+import ByteArray       ( indexAddrOffAddr )
 #else
-# define ADDR      _Addr
-# define PACK_STR   _packCString
+import Addr            ( Addr, indexAddrOffAddr )
 #endif
 
 argv :: [FAST_STRING]
 argv = unpackArgv ``prog_argv'' (``prog_argc''::Int)
 
-unpackArgv :: ADDR -> Int -> [FAST_STRING] -- argv[1 .. argc-1]
+unpackArgv :: Addr -> Int -> [FAST_STRING] -- argv[1 .. argc-1]
 
 unpackArgv argv argc = unpack 1
   where
     unpack :: Int -> [FAST_STRING]
     unpack n
-      = if (n >= argc)
-       then ([] :: [FAST_STRING])
-       else case (indexAddrOffAddr argv n) of { item ->
-            PACK_STR item : unpack (n + 1)
-            }
+      | n >= argc = []
+      | otherwise =
+        case (indexAddrOffAddr argv n) of 
+          item -> mkFastCharString item : unpack (n + 1)
+
 \end{code}