ReC98/th02/th02.h

185 lines
4.4 KiB
C
Raw Normal View History

/* ReC98
* -----
* Include file for TH02
*/
#include "ReC98.h"
#include "th01/ranks.h"
#undef grcg_off
// Formats
// -------
typedef struct {
char magic[4]; // = "MPTN"
char count;
char unused;
} mptn_header_t;
#define MPTN_SIZE (8 * 16)
extern char mptn_show_palette_on_load;
extern unsigned char mptn_count;
extern int *mptn_buffer;
extern char mptn_palette[16 * 3];
int pascal mptn_load(const char *fn);
void pascal mptn_palette_show(void);
void pascal mptn_free(void);
2015-03-16 21:35:52 +00:00
// "東方封魔.録" in Shift-JIS
#define PF_FN "\x93\x8C\x95\xFB\x95\x95\x96\x82\x2E\x98\x5E"
#define PF_KEY 0x12
// -------
// Hardware
// -------
#define graph_clear_both() \
graph_accesspage(1); graph_clear(); \
graph_accesspage(0); graph_clear(); \
graph_accesspage(0); graph_showpage(0);
#include "th01/hardware/grppsafx.h"
2015-03-16 21:35:52 +00:00
void pascal graph_copy_rect_1_to_0(int x, int y, int w, int h);
// -------
typedef enum {
INPUT_UP = 0x1,
INPUT_DOWN = 0x2,
INPUT_LEFT = 0x4,
INPUT_RIGHT = 0x8,
INPUT_SHOT = 0x10,
INPUT_BOMB = 0x20,
INPUT_CANCEL = 0x40,
INPUT_OK = 0x80,
INPUT_Q = 0x100,
INPUT_UP_LEFT = 0x1000,
INPUT_UP_RIGHT = 0x2000,
INPUT_DOWN_LEFT = 0x4000,
INPUT_DOWN_RIGHT = 0x8000
} input_t;
#define INPUT_MOVEMENT_ALIGNED \
(INPUT_UP | INPUT_DOWN | INPUT_LEFT | INPUT_RIGHT)
#define INPUT_MOVEMENT_DIAGONAL \
(INPUT_UP_LEFT | INPUT_UP_RIGHT | INPUT_DOWN_LEFT | INPUT_DOWN_RIGHT)
extern input_t key_det; /* ZUN symbol [MAGNet2010] */
void input_sense(void);
void pascal frame_delay(int frames);
void pascal frame_delay_2(int frames);
void key_delay(void);
// Music Room
#define MUSIC_CMT_FILE "MUSIC.TXT"
#define MUSIC_CMT_LINE_LEN 42
#define MUSIC_CMT_LINE_COUNT 20
// Resident structure
2015-03-16 21:35:52 +00:00
// ------------------
#define RES_ID "MIKOConfig"
typedef struct {
char id[11]; // = RES_ID
char stage;
char debug;
int8_t padding_1;
long score;
int continues_used;
char rem_bombs;
char rem_lives;
char rank;
char start_power;
char bgm_mode;
char start_bombs;
char start_lives;
int8_t padding_2;
long frame;
int unused_1;
char unused_2;
2015-03-16 21:35:52 +00:00
unsigned char op_main_retval;
unsigned char perf;
char unused_3;
char shottype;
char demo_num;
int skill;
int unused_4;
long score_highest;
} resident_t;
extern resident_t *resident;
extern char unused_op_2_3; // Maybe debug mode?
2015-03-16 21:35:52 +00:00
extern char rank;
extern char lives;
extern char bombs;
// ------------------
2015-03-16 21:35:52 +00:00
#define SHOTTYPE_COUNT 3
// Highscores
// ----------
#define SCOREDAT_PLACES 10
#define SCOREDAT_NAME_LEN 6 /* excluding the terminating 0 */
#define EXTRA_CLEAR_FLAGS {1, 2, 4}
#define GAME_CLEAR_CONSTANTS {318, 118, 218}
#define STAGE_ALL 127
typedef struct {
/* For ranks (and therefore, structure instances) #0, #1 and #2 (Easy,
* Normal and Hard), this is either GAME_CLEAR_CONSTANTS[rank] or 0,
* and indicates whether the main 5 stages have been cleared with the
* *shot type* associated with the rank's index, in any difficulty.
* Yes, ZUN uses a field in a rank-specific structure to store a
* shot type-specific value.
*
* For rank #3, this is instead interpreted as a bit field using the
* EXTRA_CLEAR_FLAGS to indicate whether the Extra Stage has been
* cleared with the respective shot type.
* Yes, ZUN stores what is technically information about the Extra
* rank in the structure of the Lunatic rank.
*
* For rank #4, this field is unused.
*/
int16_t cleared;
int32_t points[SCOREDAT_PLACES];
int32_t points_sum;
unsigned char g_name[SCOREDAT_PLACES][SCOREDAT_NAME_LEN + 1];
unsigned char g_name_first_sum;
unsigned char stage[SCOREDAT_PLACES];
unsigned char stage_sum;
struct date date[SCOREDAT_PLACES];
unsigned char shottype[SCOREDAT_PLACES];
} scoredat_t;
typedef struct {
scoredat_t score;
int32_t score_sum; // Sum of all bytes in [score], pre-encraption
} scoredat_section_t;
extern char cleared_game_with[SHOTTYPE_COUNT];
extern char cleared_extra_with[SHOTTYPE_COUNT];
int pascal scoredat_cleared_load(void);
// ----------
2015-03-16 21:35:52 +00:00
// Debugging
// ---------
// Calls ZUN's interrupt vector set up in ZUNINIT.COM to display an error
// message.
typedef enum {
ERROR_FILE_NOT_FOUND = 2,
ERROR_OUT_OF_MEMORY = 3,
ERROR_MISSING_DRIVER = 4,
ERROR_SCOREDAT_CORRUPT = 5,
_zun_error_t_FORCE_INT = 0xFFFF
} zun_error_t;
void pascal zun_error(zun_error_t err);
// ---------