-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathoshw.h
392 lines (332 loc) · 13.5 KB
/
oshw.h
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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
/* oshw.h: Platform-specific functions that talk with the OS/hardware.
*
* Copyright (C) 2001-2017 by Brian Raiter, Madhav Shanbhag, and Eric Schmidt
* under the GNU General Public License. No warranty. See COPYING for details.
*/
#ifndef HEADER_oshw_h_
#define HEADER_oshw_h_
#include <stdarg.h>
#include "gen.h"
struct gamestate;
struct gameseries;
#ifdef __cplusplus
#define OSHW_EXTERN extern "C"
#else
#define OSHW_EXTERN extern
#endif
/* This is the declaration of the top layer's main function. It is
* called directly from the real main() inside the OS/hardware layer.
*/
OSHW_EXTERN int tworld(int argc, char *argv[]);
/* Initialize the OS/hardware interface. This function must be called
* before any others in the oshw library. If silence is TRUE, the
* sound system will be disabled, as if no soundcard was present. If
* showhistogram is TRUE, then during shutdown the timer module will
* send a histogram to stdout describing the amount of time the
* program explicitly yielded to other processes. (This feature is for
* debugging purposes.) soundbufsize is a number between 0 and 3 which
* is used to scale the size of the sound buffer. A larger number is
* more efficient, but pushes the sound effects farther out of
* synchronization with the video.
*/
OSHW_EXTERN int oshwinitialize(int silence, int soundbufsize,
int showhistogram, int fullscreen);
/*
* Timer functions.
*/
/* Control the timer depending on the value of action. A negative
* value turns off the timer if it is running and resets the counter
* to zero. A zero value turns off the timer but does not reset the
* counter. A positive value starts (or resumes) the timer.
*/
OSHW_EXTERN void settimer(int action);
/* Set the length (in real time) of a second of game time. A value of
* zero selects the default of 1000 milliseconds.
*/
OSHW_EXTERN void settimersecond(int ms);
/* Return the number of ticks since the timer was last reset.
*/
OSHW_EXTERN int gettickcount(void);
/* Put the program to sleep until the next timer tick.
*/
OSHW_EXTERN int waitfortick(void);
/* Force the timer to advance to the next tick.
*/
OSHW_EXTERN int advancetick(void);
/*
* Keyboard input functions.
*/
/* Turn keyboard repeat on or off. If enable is TRUE, the keys other
* than the direction keys will repeat at the standard rate.
*/
OSHW_EXTERN int setkeyboardrepeat(int enable);
/* Alter the behavior of the keys used to indicate movement in the
* game. If enable is TRUE, the direction keys repeat whenever the
* program polls the keyboard. Otherwise, the direction keys do not
* repeat until the program polls the keyboard three times.
*/
OSHW_EXTERN int setkeyboardarrowsrepeat(int enable);
/* Turn input mode on or off. In input mode, only the arrow and letter
* keys are recognized.
*/
OSHW_EXTERN int setkeyboardinputmode(int enable);
/* Return the latest/current keystroke. If wait is TRUE and no
* keystrokes are pending, the function blocks until a keystroke
* arrives.
*/
OSHW_EXTERN int input(int wait);
/* Wait for a key to be pressed (any key, not just one recognized by
* the program). The return value is FALSE if the key pressed is a
* "quit" key.
*/
OSHW_EXTERN int anykey(void);
/* Return a table suitable for displaying a help screen on the
* available keyboard commands for the given context.
*/
OSHW_EXTERN tablespec const *keyboardhelp(int context);
/* Symbolic values for requesting a specific help table.
*/
enum {
KEYHELP_INGAME,
KEYHELP_TWIXTGAMES,
KEYHELP_FILELIST,
KEYHELP_SCORELIST,
KEYHELP_TWPLUSPLUS
};
/*
* Resource-loading functions.
*/
/* Extract the font stored in the given file and make it the current
* font. FALSE is returned if the attempt was unsuccessful. If
* complain is FALSE, no error messages will be displayed.
*/
OSHW_EXTERN int loadfontfromfile(char const *filename, int complain);
/* Free all memory associated with the current font.
*/
OSHW_EXTERN void freefont(void);
/* Extract the tile images stored in the given file and use them as
* the current tile set. FALSE is returned if the attempt was
* unsuccessful. If complain is FALSE, no error messages will be
* displayed.
*/
OSHW_EXTERN int loadtileset(char const *filename, int complain);
/* Free all memory associated with the current tile images.
*/
OSHW_EXTERN void freetileset(void);
/* The font provides special monospaced digit characters at 144-153.
*/
#ifndef TWPLUSPLUS
enum { CHAR_MZERO = 144 };
#else
enum { CHAR_MZERO = '0' };
#endif
/*
* Video output functions.
*/
/* Create a display surface appropriate to the requirements of the
* game (e.g., sized according to the tiles and the font). FALSE is
* returned on error.
*/
OSHW_EXTERN int creategamedisplay(void);
/* Select the colors used for drawing the display background, normal
* text, bold (highlighted) text, and dim (grayed) text. The color
* values are of the form 0x00RRGGBB.
*/
OSHW_EXTERN void setcolors(long bkgnd, long text, long bold, long dim);
/* Fill the display with the background color.
*/
OSHW_EXTERN void cleardisplay(void);
/* Display the current game state. timeleft and besttime provide the
* current time on the clock and the best time recorded for the level,
* measured in seconds.
*/
OSHW_EXTERN int displaygame(struct gamestate const *state,
int timeleft, int besttime, int showinitstate);
/* Display a short message appropriate to the end of a level's game
* play. If the level was completed successfully, completed is TRUE,
* and the other three arguments define the base score and time bonus
* for the level, and the user's total score for the series; these
* scores will be displayed to the user. If the return value is CmdNone,
* the program will wait for subsequent user input, otherwise the
* command returned will be used as the next action.
*/
OSHW_EXTERN int displayendmessage(int basescore, int timescore,
long totalscore, int completed);
/* Display a (very short) message for the given number of
* milliseconds. bold indicates the number of milliseconds the
* message is with highlighting. After that (if the message is
* still visible) it is rendered as normal text.
*/
OSHW_EXTERN int setdisplaymsg(char const *msg, int msecs, int bold);
/* Types of lists that can be displayed.
*/
typedef enum {
LIST_MAPFILES,
LIST_SERIES,
LIST_SCORES,
LIST_SOLUTIONFILES,
LIST_HELP
} DisplayListType;
/* Display a scrollable table. title provides a title to display. The
* table's first row provides a set of column headers which will not
* scroll. index points to the index of the item to be initially
* selected; upon return, the value will hold the current selection.
* Either listtype or inputcallback must be used to tailor the UI.
* listtype specifies the type of list being displayed.
* inputcallback points to a function that is called to retrieve
* input. The function is passed a pointer to an integer. If the
* callback returns TRUE, this integer should be set to either a new
* index value or one of the following enum values. This value will
* then cause the selection to be changed, whereupon the display will
* be updated before the callback is called again. If the callback
* returns FALSE, the table is removed from the display, and the value
* stored in the integer will become displaylist()'s return value.
*/
OSHW_EXTERN int displaylist(char const *title, tablespec const *table,
int *index, DisplayListType listtype,
int (*inputcallback)(int*));
/* Symbolic values for requesting relative movement of the selection.
*/
enum {
SCROLL_NOP = -1,
SCROLL_UP = -2,
SCROLL_DN = -3,
SCROLL_PAGE_UP = -4,
SCROLL_PAGE_DN = -5,
SCROLL_HALFPAGE_UP = -6,
SCROLL_HALFPAGE_DN = -7,
SCROLL_ALLTHEWAY_UP = -8,
SCROLL_ALLTHEWAY_DN = -9
};
/* Types of input prompts.
*/
typedef enum {
INPUT_YESNO, // Yes or No question
INPUT_ALPHA // Alphabets only (lowercase folded to uppercase)
} InputPromptType;
/* Display an input prompt to the user. prompt supplies the prompt to
* display, and input points to a buffer to hold the user's input.
* maxlen sets a maximum length to the input that will be accepted.
* Either inputtype or inputcallback must be used to validate input.
* inputtype indicates the type of input desired.
* The supplied callback function is called repeatedly to obtain
* input. If the callback function returns a printable ASCII
* character, the function will automatically append it to the string
* stored in input. If '\b' is returned, the function will erase the
* last character in input, if any. If '\f' is returned the function
* will set input to "". If '\n' is returned, the input prompt is
* erased and displayinputprompt() returns TRUE. If a negative value
* is returned, the input prompt is erased and displayinputprompt()
* returns FALSE. All other return values from the callback are
* ignored.
*/
OSHW_EXTERN int displayinputprompt(char const *prompt, char *input, int maxlen,
InputPromptType inputtype, int (*inputcallback)(void));
/*
* Sound functions.
*/
/* Activate or deactivate the sound system. The return value is TRUE
* if the sound system is (or already was) active.
*/
OSHW_EXTERN int setaudiosystem(int active);
/* Load a wave file into memory. index indicates which sound effect to
* associate the sound with. FALSE is returned if an error occurs.
*/
OSHW_EXTERN int loadsfxfromfile(int index, char const *filename);
/* Specify the sounds effects to be played at this time. sfx is the
* bitwise-or of any number of sound effects. If a non-continuous
* sound effect in sfx is already playing, it will be restarted. Any
* continuous sound effects that are currently playing that are not
* set in sfx will stop playing.
*/
OSHW_EXTERN void playsoundeffects(unsigned long sfx);
/* Control sound-effect production depending on the value of action.
* A negative value turns off all sound effects that are playing. A
* zero value temporarily suspends the playing of sound effects. A
* positive value continues the sound effects at the point at which
* they were suspended.
*/
OSHW_EXTERN void setsoundeffects(int action);
/* Set the current volume level. Volume ranges from 0 (silence) to 10
* (the default). Setting the sound to zero causes sound effects to be
* displayed as textual onomatopoeia. If display is TRUE, the new
* volume level will be displayed to the user. FALSE is returned if
* the sound system is not currently active.
*/
OSHW_EXTERN int setvolume(int volume, int display);
/* Alters the current volume level by delta.
*/
OSHW_EXTERN int changevolume(int delta, int display);
/* Release all memory used for the given sound effect's wave data.
*/
OSHW_EXTERN void freesfx(int index);
/*
* Miscellaneous functions.
*/
/* Ring the bell.
*/
OSHW_EXTERN void ding(void);
/* Set the program's subtitle. A NULL subtitle is equivalent to the
* empty string. The subtitle is displayed in the window dressing (if
* any).
*/
OSHW_EXTERN void setsubtitle(char const *subtitle);
/* Display a message to the user. cfile and lineno can be NULL and 0
* respectively; otherwise, they identify the source code location
* where this function was called from. prefix is an optional string
* that is displayed before and/or apart from the body of the message.
* fmt and args define the formatted text of the message body. action
* indicates how the message should be presented. NOTIFY_LOG causes
* the message to be displayed in a way that does not interfere with
* the program's other activities. NOTIFY_ERR presents the message as
* an error condition. NOTIFY_DIE should indicate to the user that the
* program is about to shut down.
*/
OSHW_EXTERN void usermessage(int action, char const *prefix,
char const *cfile, unsigned long lineno,
char const *fmt, va_list args);
/* Values used for the first argument of usermessage().
*/
enum { NOTIFY_DIE, NOTIFY_ERR, NOTIFY_LOG };
/* Structure used to define text with illustrations.
*/
typedef struct tiletablerow {
int isfloor; /* TRUE if the images are floor tiles */
int item1; /* first illustration */
int item2; /* second illustration */
char const *desc; /* text */
} tiletablerow;
/* Displays a screenful of (hopefully) helpful information which
* includes tile images. title provides the title of the display. rows
* points to an array of tiletablerow structures. count specifies the
* size of this array. The text of each row is displayed alongside one
* or two tile images. completed controls the prompt that the user
* sees at the bottom of the display. A positive value will indicate
* that more text follows. A negative value will indicate that leaving
* this screen will return to the prior display. A value of zero will
* indicate that the current display is the end of a sequence.
*/
OSHW_EXTERN int displaytiletable(char const *title, tiletablerow const *rows,
int count, int completed);
/* Displays a screenful of (hopefully) helpful information. title
* provides the title of the display. table points to a table that
* contains the body of the text. completed controls the prompt that
* the user sees at the bottom of the display; see the description of
* displaytiletable() for details.
*/
OSHW_EXTERN int displaytable(char const *title, tablespec const *table,
int completed);
/* Get the selected ruleset.
*/
OSHW_EXTERN int getselectedruleset(void);
/* Read any additional data for the series.
*/
OSHW_EXTERN void readextensions(struct gameseries *series);
/* Get number of seconds to skip at start of playback.
*/
OSHW_EXTERN int getreplaysecondstoskip(void);
/* Copy text to clipboard.
*/
OSHW_EXTERN void copytoclipboard(char const *text);
#undef OSHW_EXTERN
#endif