File: MkTuple.hs

package info (click to toggle)
haskell-tuple 0.3.0.2-6
  • links: PTS
  • area: main
  • in suites: forky, sid, trixie
  • size: 368 kB
  • sloc: haskell: 1,350; makefile: 23
file content (88 lines) | stat: -rw-r--r-- 3,086 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
{-# LANGUAGE PatternGuards #-}
module Main where
import Data.List
import System.Environment

main :: IO ()
main = do
    args <- getArgs
    case args of
        [w, sn] | Just gen <- lookup w gens, [(n,"")] <- reads sn -> do
	    putStrLn "--snip-----------------"
	    putStrLn "---- Machine generated code below, see Tools/MkTuple.hs"
	    putStrLn $ "---- " ++ unwords ("mkTuple" : args)
            gen n
	_ -> error $ "Usage: MkTuple generator number\n"

gens :: [(String, Int -> IO ())]
gens = [("select", generateSel),
        ("sequence", generateSeq),
        ("curry", generateCurry),
        ("update", generateUpd)
       ]

---------

generateSel :: Int -> IO ()
generateSel n = mapM_ (generateSelN n) [1..n]

generateSelN :: Int -> Int -> IO ()
generateSelN n i = do
    putStrLn $ "class Sel" ++ show i ++ " a b | a -> b where sel" ++ show i ++ " :: a -> b"
    mapM_ (generateSelNinst i) [i..n]
    putStrLn ""

generateSelNinst :: Int -> Int -> IO ()
generateSelNinst 1 1 = return ()
generateSelNinst j i = do
    putStrLn $ "instance Sel" ++ show j ++ " (" ++ intercalate "," ["a" ++ show l | l <- [1..i]] ++ ") a" ++
               show j ++ " where sel" ++ show j ++ " (" ++ 
               intercalate "," [if l == j then "x" else "_" | l <- [1..i]] ++ ") = x"

---------

generateSeq :: Int -> IO ()
generateSeq n = mapM_ generateSeqN [2..n]

generateSeqN :: Int -> IO ()
generateSeqN i =
    putStrLn $ "instance (Monad m) => SequenceT (" ++
               intercalate "," ["m a" ++ show j | j <- [1..i]] ++ ") (m (" ++
               intercalate "," ["a" ++ show j | j <- [1..i]] ++ ")) where sequenceT (" ++
               intercalate "," ["a" ++ show j | j <- [1..i]] ++ ") = return (" ++ replicate (i-1) ',' ++ ") `ap` " ++
               intercalate " `ap` " ["a" ++ show j | j <- [1..i]]

---------

generateCurry :: Int -> IO ()
generateCurry n = mapM_ generateCurryN [2..n]

generateCurryN :: Int -> IO ()
generateCurryN i =
    putStrLn $ "instance Curry (" ++ tup ++ " -> r) (" ++
               intercalate "->" vars ++ " -> r) where\n" ++
               "    curryN f " ++ varsp ++ " = f " ++ tup ++ "\n" ++
	       "    uncurryN f ~" ++ tup ++ " = f " ++ varsp
  where vars = ["a" ++ show j | j <- [1..i]]
        tup = "(" ++ intercalate "," vars ++ ")"
        varsp = unwords vars

---------

generateUpd :: Int -> IO ()
generateUpd n = mapM_ (generateUpdN n) [1..n]

generateUpdN :: Int -> Int -> IO ()
generateUpdN n i = do
    putStrLn $ "class Upd" ++ show i ++ " a b c | a b -> c , b c -> a where upd" ++ show i ++ " :: a -> b -> c"
    mapM_ (generateUpdNinst i) [i..n]
    putStrLn ""

generateUpdNinst :: Int -> Int -> IO ()
generateUpdNinst 1 1 = return ()
generateUpdNinst j i = do
    putStrLn $ "instance Upd" ++ show j ++ " b (" ++ intercalate "," ["a" ++ show l | l <- [1..i]] ++ ") " ++
               res ++ " where upd" ++ show j ++ " b (" ++ 
               intercalate "," [ "a" ++ show l | l <- [1..i]] ++ ") = " ++ res
 where res =
        "(" ++ intercalate "," [ if l == j then "b" else "a" ++ show l | l <- [1..i]] ++ ")"