[project @ 1997-05-26 01:17:20 by sof]
[ghc-hetmet.git] / ghc / compiler / utils / Argv.lhs
1 %
2 % (c) The AQUA Project, Glasgow University, 1996
3 %
4 \section[Argv]{@Argv@: direct (non-standard) access to command-line arguments}
5
6 \begin{code}
7 #include "HsVersions.h"
8
9 module Argv ( argv ) where
10
11 #if defined(__GLASGOW_HASKELL__) && __GLASGOW_HASKELL__ <= 200
12 import PreludeGlaST     ( indexAddrOffAddr )
13 #endif
14
15 CHK_Ubiq() -- debugging consistency check
16
17 #if __GLASGOW_HASKELL__ == 201
18 # define ADDR       GHCbase.Addr
19 # define PACK_STR   packCString
20 #elif __GLASGOW_HASKELL__ >= 202
21 # define ADDR       GlaExts.Addr
22 # define PACK_STR   mkFastCharString
23 #else
24 # define ADDR       _Addr
25 # define PACK_STR   mkFastCharString
26 /*
27 # define ADDR       _Addr
28 # define PACK_STR   _packCString
29 */
30 #endif
31
32 argv :: [FAST_STRING]
33 argv = unpackArgv ``prog_argv'' (``prog_argc''::Int)
34
35 unpackArgv :: ADDR -> Int -> [FAST_STRING] -- argv[1 .. argc-1]
36
37 unpackArgv argv argc = unpack 1
38   where
39     unpack :: Int -> [FAST_STRING]
40     unpack n
41       = if (n >= argc)
42         then ([] :: [FAST_STRING])
43         else case (indexAddrOffAddr argv n) of { item ->
44              PACK_STR item : unpack (n + 1)
45              }
46 \end{code}