2019-09-14 14:41:16 +00:00
|
|
|
/* ReC98
|
|
|
|
* -----
|
2019-09-18 16:33:38 +00:00
|
|
|
* 2nd part of code segment #1 of TH05's MAIN.EXE
|
2019-09-14 14:41:16 +00:00
|
|
|
*/
|
|
|
|
|
2019-09-18 16:33:38 +00:00
|
|
|
#pragma codeseg main_01_TEXT
|
|
|
|
|
2019-09-15 17:36:17 +00:00
|
|
|
extern "C" {
|
|
|
|
#include "th05/th05.hpp"
|
2019-09-14 14:41:16 +00:00
|
|
|
|
[Decompilation] [th05] Stage setup
"Yeah, let's do this real quick, how can this possibly be hard, it's
just MOVs and a few function calls"…
…except that these MOVs access quite a lot of data, which we now all
have to declare in the C world, hooray.
Once it came to midbosses and bosses, I just turned them into C structs
after all. Despite what I said in 260edd8… after all, the ASM world
doesn't care about the representation in the C world, so they don't
necessarily have to be the same.
Since these structs can't contain everything related to midbosses and
bosses (really, why did all those variables have to be spread out like
this, ZUN?), it also made for a nice occasion to continue the "stuff"
naming scheme, describing "an obviously incomplete collection of
variables related to a thing", first seen in 160d4eb.
Also, PROCDESC apparently is the only syntactically correct option to
declare an extern near proc?
Also, that `boss_phase_timed_out` variable only needs to be here
already because TCC enforces word alignment for the .data segment…
yeah, it's technically not related to this commit, but why waste time
working around it if we can just include that one variable.
Completes P0030, funded by zorg.
2019-09-15 18:14:00 +00:00
|
|
|
void pascal far nullsub_1(void);
|
|
|
|
void pascal near nullfunc_near(void);
|
|
|
|
|
|
|
|
void pascal near playfield_fillm_32_0_320_192(void);
|
|
|
|
void pascal near playfield_fillm_0_0_384_192__2(void);
|
|
|
|
void pascal near playfield_fillm_0_205_384_163(void);
|
|
|
|
void pascal near playfield_fillm_64_56_256_256(void);
|
|
|
|
void pascal near playfield_fillm_0_0_384_192__1(void);
|
|
|
|
void pascal near playfield_fillm_0_104_384_192(void);
|
|
|
|
|
2020-04-05 14:17:33 +00:00
|
|
|
#include "th04/main/boss/reset.cpp"
|
2019-09-16 11:01:53 +00:00
|
|
|
#include "th04/formats/bb_stage.c"
|
2020-04-05 14:17:33 +00:00
|
|
|
#include "th05/main/stage/setup.cpp"
|
[Decompilation] [th05] Stage setup
"Yeah, let's do this real quick, how can this possibly be hard, it's
just MOVs and a few function calls"…
…except that these MOVs access quite a lot of data, which we now all
have to declare in the C world, hooray.
Once it came to midbosses and bosses, I just turned them into C structs
after all. Despite what I said in 260edd8… after all, the ASM world
doesn't care about the representation in the C world, so they don't
necessarily have to be the same.
Since these structs can't contain everything related to midbosses and
bosses (really, why did all those variables have to be spread out like
this, ZUN?), it also made for a nice occasion to continue the "stuff"
naming scheme, describing "an obviously incomplete collection of
variables related to a thing", first seen in 160d4eb.
Also, PROCDESC apparently is the only syntactically correct option to
declare an extern near proc?
Also, that `boss_phase_timed_out` variable only needs to be here
already because TCC enforces word alignment for the .data segment…
yeah, it's technically not related to this commit, but why waste time
working around it if we can just include that one variable.
Completes P0030, funded by zorg.
2019-09-15 18:14:00 +00:00
|
|
|
|
2019-09-14 14:41:16 +00:00
|
|
|
// Adds the entire score delta at once to the current score.
|
|
|
|
void pascal score_delta_commit(void)
|
|
|
|
{
|
|
|
|
while(score_delta > 0) {
|
|
|
|
score_update_and_render();
|
|
|
|
}
|
|
|
|
}
|
2019-09-15 17:36:17 +00:00
|
|
|
|
2019-09-16 11:01:53 +00:00
|
|
|
static int unused_6CAC[3];
|
|
|
|
|
2019-09-15 17:36:17 +00:00
|
|
|
}
|