2 % (c) The GRASP/AQUA Project, Glasgow University, 1992-1998
4 \section[PrelMods]{Definitions of prelude modules}
6 The strings identify built-in prelude modules. They are
7 defined here so as to avod
9 [oh dear, looks like the recursive module monster caught up with
10 and gobbled whoever was writing the above :-) -- SOF ]
15 mkTupNameStr, mkUbxTupNameStr,
17 pREL_GHC, pRELUDE, mONAD, rATIO, iX, mAIN, pREL_MAIN, pREL_ERR,
18 pREL_BASE, pREL_NUM, pREL_LIST, pREL_TUP, pREL_ADDR, pREL_READ,
19 pREL_PACK, pREL_CONC, pREL_IO_BASE, pREL_ST, pREL_ARR, pREL_FOREIGN,
24 #include "HsVersions.h"
26 import OccName ( Module, mkModule )
27 import Util ( nOfThem )
28 import Panic ( panic )
32 pREL_GHC, pRELUDE, mONAD, rATIO, iX, mAIN, pREL_MAIN, pREL_ERR :: Module
33 pREL_BASE, pREL_NUM, pREL_LIST, pREL_TUP, pREL_ADDR, pREL_READ :: Module
34 pREL_PACK, pREL_CONC, pREL_IO_BASE, pREL_ST, pREL_ARR, pREL_FOREIGN :: Module
37 pRELUDE = mkModule "Prelude"
38 pREL_GHC = mkModule "PrelGHC" -- Primitive types and values
39 pREL_BASE = mkModule "PrelBase"
40 pREL_READ = mkModule "PrelRead"
41 pREL_NUM = mkModule "PrelNum"
42 pREL_LIST = mkModule "PrelList"
43 pREL_TUP = mkModule "PrelTup"
44 pREL_PACK = mkModule "PrelPack"
45 pREL_CONC = mkModule "PrelConc"
46 pREL_IO_BASE = mkModule "PrelIOBase"
47 pREL_ST = mkModule "PrelST"
48 pREL_ARR = mkModule "PrelArr"
49 pREL_FOREIGN = mkModule "PrelForeign"
50 pREL_ADDR = mkModule "PrelAddr"
51 pREL_ERR = mkModule "PrelErr"
53 mONAD = mkModule "Monad"
54 rATIO = mkModule "Ratio"
57 pREL_MAIN = mkModule "PrelMain"
58 mAIN = mkModule "Main"
63 wORD = mkModule "Word"
67 %************************************************************************
69 \subsection{Constructing the names of tuples
71 %************************************************************************
74 mkTupNameStr, mkUbxTupNameStr :: Int -> (Module, FAST_STRING)
76 mkTupNameStr 0 = (pREL_BASE, SLIT("()"))
77 mkTupNameStr 1 = panic "Name.mkTupNameStr: 1 ???"
78 mkTupNameStr 2 = (pREL_TUP, _PK_ "(,)") -- not strictly necessary
79 mkTupNameStr 3 = (pREL_TUP, _PK_ "(,,)") -- ditto
80 mkTupNameStr 4 = (pREL_TUP, _PK_ "(,,,)") -- ditto
81 mkTupNameStr n = (pREL_TUP, _PK_ ("(" ++ nOfThem (n-1) ',' ++ ")"))
83 mkUbxTupNameStr 0 = panic "Name.mkUbxTupNameStr: 0 ???"
84 mkUbxTupNameStr 1 = (pREL_GHC, _PK_ "(# #)") -- 1 and 0 both make sense!!!
85 mkUbxTupNameStr 2 = (pREL_GHC, _PK_ "(#,#)")
86 mkUbxTupNameStr 3 = (pREL_GHC, _PK_ "(#,,#)")
87 mkUbxTupNameStr 4 = (pREL_GHC, _PK_ "(#,,,#)")
88 mkUbxTupNameStr n = (pREL_GHC, _PK_ ("(#" ++ nOfThem (n-1) ',' ++ "#)"))