-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPreviewProgram.hs
103 lines (92 loc) · 2.36 KB
/
PreviewProgram.hs
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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
module PreviewProgram (indent, mainProgram) where
import Data.Char
import Data.List
import Data.Maybe
indent :: String
indent = " "
esc :: Char -> String
esc '\"' = "\\\""
esc '\\' = "\\\\"
-- GROM doesn't contain underscore, and title looks better with spaces anyway
esc '_' = " "
esc x
| ord x > 127 || ord x < 32 = "?"
| otherwise = [x]
escape :: String -> String
escape = concatMap esc
printCentered :: Int -> Int -> String -> String
printCentered y color str =
let x = (20 - length str) `div` 2
pos = y * 20 + max x 0
in indent ++ "PRINT AT " ++ show pos ++ " COLOR " ++ show color ++ ", \"" ++ escape str ++ "\""
splitWords :: Int -> [String] -> ([String], [String])
splitWords _ [] = ([], [])
splitWords width (wrd:wrds) =
let len = length wrd
in if len <= width
then let (x, y) = splitWords (width - len - 1) wrds
in (wrd : x, y)
else ([], wrd : wrds)
wordwrap :: Int -> [String] -> [String]
wordwrap _ [] = []
wordwrap width wrds =
let (now, later) = case splitWords width wrds of
([], (x:y)) -> ([x], y)
(x, y) -> (x, y)
in unwords now : wordwrap width later
titleToLines :: String -> [String]
titleToLines = wordwrap 20 . words . map f
where f '_' = ' '
f x = x
titleLine :: Int -> [String] -> [String]
titleLine _ [] = []
titleLine y (ln:lns)
| y >= 12 = []
| otherwise =
let len = fromIntegral $ length ln
h = ceiling (len / 20)
y' = y + h
ln' = take (20 * (12 - y)) ln
code = printCentered y 7 ln'
in code : titleLine y' lns
titleToCode :: String -> [String]
titleToCode title = titleLine 6 $ titleToLines title
mainProgram :: String -> String -> [String]
mainProgram title label =
[ i "CLS"
, i "MODE 0, 1, 1, 1, 1"
, i "BORDER 1"
, i "WAIT"
, ""
, "RESTART:"
, printCentered 3 5 "Press any button"
, printCentered 4 5 "to play"
] ++ titleToCode title ++
[ ""
, i "WHILE CONT = 0"
, i $ i "WAIT"
, i "WEND"
, ""
, i "FOR I = 60 TO 99"
, i $ i "#BACKTAB(I) = 0"
, i "NEXT I"
, ""
, i "WHILE CONT <> 0"
, i $ i "WAIT"
, i "WEND"
, ""
, i "PLAY FULL"
, i $ "PLAY " ++ label
, ""
, i "WHILE MUSIC.PLAYING"
, i $ i "WAIT"
, i "WEND"
, ""
, i "GOTO RESTART"
, ""
, i $ "ASM CFGVAR \"name\" = \"" ++ escape title ++ "\""
, ""
, i $ "ASM ORG $A000"
, ""
]
where i = (indent ++)