2022-08-15 07:42:57 +00:00
|
|
|
#include "th01/common.h"
|
|
|
|
|
2021-12-25 15:18:17 +00:00
|
|
|
typedef enum {
|
|
|
|
ROUTE_MAKAI,
|
|
|
|
ROUTE_JIGOKU,
|
|
|
|
ROUTE_COUNT,
|
2022-08-14 05:41:03 +00:00
|
|
|
|
|
|
|
_route_t_FORCE_INT16 = 0x7FFF
|
2021-12-25 15:18:17 +00:00
|
|
|
} route_t;
|
|
|
|
|
2022-05-29 23:45:47 +00:00
|
|
|
enum end_sequence_t {
|
|
|
|
ES_NONE,
|
|
|
|
ES_MAKAI,
|
|
|
|
ES_JIGOKU,
|
|
|
|
};
|
|
|
|
|
2021-12-25 15:18:17 +00:00
|
|
|
enum debug_mode_t {
|
|
|
|
DM_OFF = 0,
|
|
|
|
DM_TEST = 1,
|
2022-08-14 05:41:03 +00:00
|
|
|
DM_FULL = 3,
|
|
|
|
|
|
|
|
_debug_mode_t_FORCE_INT16 = 0x7FFF
|
2021-12-25 15:18:17 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// Much like subpixels, pellet speeds are stored pre-multiplied by 40 to allow
|
|
|
|
// an effective resolution of 0.025 pixels to be losslessly stored in an
|
|
|
|
// integer. This pre-multiplication is reverted by the pellet spawning
|
|
|
|
// functions.
|
|
|
|
typedef int pellet_speed_t;
|
|
|
|
|
|
|
|
static const pellet_speed_t PELLET_SPEED_MULTIPLIER = 40;
|
|
|
|
|
|
|
|
#define to_pellet_speed(pixel_v) \
|
|
|
|
static_cast<pellet_speed_t>(pixel_v * PELLET_SPEED_MULTIPLIER)
|
|
|
|
|
|
|
|
#define RES_ID "ReiidenConfig"
|
|
|
|
typedef struct {
|
|
|
|
char id[sizeof(RES_ID)];
|
2022-08-14 05:41:03 +00:00
|
|
|
int8_t rank;
|
|
|
|
int8_t bgm_mode; // 0 = off, 1 = FM
|
|
|
|
int8_t bombs;
|
|
|
|
int8_t start_lives_extra; // Add 2 for the actual number of lives
|
2022-05-29 23:45:47 +00:00
|
|
|
end_sequence_t end_flag; /* ZUN symbol [Strings] */
|
2022-08-14 05:41:03 +00:00
|
|
|
int8_t unused_1;
|
|
|
|
int8_t route; // ACTUAL TYPE: route_t
|
|
|
|
int8_t rem_lives;
|
|
|
|
int8_t snd_need_init; // ACTUAL TYPE: bool
|
|
|
|
int8_t unused_2;
|
|
|
|
int8_t debug_mode; // ACTUAL TYPE: debug_mode_t
|
2021-12-25 15:18:17 +00:00
|
|
|
pellet_speed_t pellet_speed;
|
2022-08-14 05:41:03 +00:00
|
|
|
unsigned long rand;
|
|
|
|
int32_t score;
|
2022-08-11 00:02:09 +00:00
|
|
|
|
|
|
|
// ZUN bloat: Never actually read from. Even FUUIN.EXE, who does care
|
|
|
|
// about this value, manually derives it from [continues_per_scene].
|
2021-12-25 15:18:17 +00:00
|
|
|
long continues_total;
|
2022-08-11 00:02:09 +00:00
|
|
|
|
2021-12-25 15:18:17 +00:00
|
|
|
unsigned int continues_per_scene[SCENE_COUNT];
|
|
|
|
|
|
|
|
// of the current scene, without the boss stage
|
|
|
|
long bonus_per_stage[STAGES_PER_SCENE - 1];
|
|
|
|
|
2022-08-12 14:41:02 +00:00
|
|
|
unsigned int stage_id;
|
2021-12-25 15:18:17 +00:00
|
|
|
unsigned long hiscore;
|
|
|
|
long score_highest; // among all continues
|
|
|
|
uint16_t point_value;
|
|
|
|
} resident_t;
|
|
|
|
|
2022-08-11 19:33:36 +00:00
|
|
|
extern long continues_total;
|
|
|
|
|
2022-08-14 05:41:03 +00:00
|
|
|
extern int8_t route; // ACTUAL TYPE: route_t
|
2022-08-10 16:01:03 +00:00
|
|
|
extern resident_t far *resident;
|
2022-08-12 14:41:02 +00:00
|
|
|
|
|
|
|
inline void resident_continue_use(void) {
|
|
|
|
resident->continues_total++;
|
|
|
|
continues_total++;
|
|
|
|
resident->continues_per_scene[resident->stage_id / STAGES_PER_SCENE]++;
|
|
|
|
}
|