1
0
Fork 0
mirror of https://github.com/TerryCavanagh/VVVVVV.git synced 2025-01-11 03:19:46 +01:00

Switch over to using SDL_GetTicks64()

SDL_GetTicks64() is a function that got added in SDL 2.0.18, which is
just an SDL_GetTicks() without a value that wraps every ~49 days,
instead wrapping after the sun explodes and kills us all. Oh sorry,
didn't mean to get existential.

For now, put this behind an SDL_VERSION_ATLEAST guard, which will be
removed when SDL 2.0.18 officially releases and we can update to it.
This commit is contained in:
Misa 2021-10-25 18:16:47 -07:00 committed by Misa Elizabeth Kai
parent 75e031cef0
commit 0c1f756af8
2 changed files with 28 additions and 7 deletions

View file

@ -3087,7 +3087,12 @@ void scriptclass::hardreset(void)
{ {
const bool version2_2 = GlitchrunnerMode_less_than_or_equal(Glitchrunner2_2); const bool version2_2 = GlitchrunnerMode_less_than_or_equal(Glitchrunner2_2);
#if SDL_VERSION_ATLEAST(2, 0, 17)
/* The RNG is 32-bit. We don't _really_ need 64-bit... */
xoshiro_seed((Uint32) SDL_GetTicks64());
#else
xoshiro_seed(SDL_GetTicks()); xoshiro_seed(SDL_GetTicks());
#endif
//Game: //Game:
game.hascontrol = true; game.hascontrol = true;

View file

@ -59,13 +59,13 @@ static std::string playassets;
static std::string playtestname; static std::string playtestname;
static volatile Uint32 time_ = 0; static volatile Uint64 time_ = 0;
static volatile Uint32 timePrev = 0; static volatile Uint64 timePrev = 0;
static volatile Uint32 accumulator = 0; static volatile Uint32 accumulator = 0;
#ifndef __EMSCRIPTEN__ #ifndef __EMSCRIPTEN__
static volatile Uint32 f_time = 0; static volatile Uint64 f_time = 0;
static volatile Uint32 f_timePrev = 0; static volatile Uint64 f_timePrev = 0;
#endif #endif
enum FuncType enum FuncType
@ -358,7 +358,11 @@ static void cleanup(void);
static void emscriptenloop(void) static void emscriptenloop(void)
{ {
timePrev = time_; timePrev = time_;
#if SDL_VERSION_ATLEAST(2, 0, 17)
time_ = SDL_GetTicks64();
#else
time_ = SDL_GetTicks(); time_ = SDL_GetTicks();
#endif
deltaloop(); deltaloop();
} }
#endif #endif
@ -670,20 +674,32 @@ int main(int argc, char *argv[])
#else #else
while (true) while (true)
{ {
#if SDL_VERSION_ATLEAST(2, 0, 17)
f_time = SDL_GetTicks64();
#else
f_time = SDL_GetTicks(); f_time = SDL_GetTicks();
#endif
const Uint32 f_timetaken = f_time - f_timePrev; const Uint64 f_timetaken = f_time - f_timePrev;
if (!game.over30mode && f_timetaken < 34) if (!game.over30mode && f_timetaken < 34)
{ {
const volatile Uint32 f_delay = 34 - f_timetaken; const volatile Uint64 f_delay = 34 - f_timetaken;
SDL_Delay(f_delay); SDL_Delay((Uint32) f_delay);
#if SDL_VERSION_ATLEAST(2, 0, 17)
f_time = SDL_GetTicks64();
#else
f_time = SDL_GetTicks(); f_time = SDL_GetTicks();
#endif
} }
f_timePrev = f_time; f_timePrev = f_time;
timePrev = time_; timePrev = time_;
#if SDL_VERSION_ATLEAST(2, 0, 17)
time_ = SDL_GetTicks64();
#else
time_ = SDL_GetTicks(); time_ = SDL_GetTicks();
#endif
deltaloop(); deltaloop();
} }