From f6969ae59f768147f4f2f2175be9a965a8a65f5d Mon Sep 17 00:00:00 2001 From: Greg Haerr Date: Fri, 15 Sep 2023 12:41:58 -0700 Subject: [PATCH 1/2] [cmds] Add accurate train timing to sl --- elkscmd/tui/sl.c | 28 +++++++++++++++++++++++++++- 1 file changed, 27 insertions(+), 1 deletion(-) diff --git a/elkscmd/tui/sl.c b/elkscmd/tui/sl.c index b0e7f035a..0d66c31c6 100644 --- a/elkscmd/tui/sl.c +++ b/elkscmd/tui/sl.c @@ -41,6 +41,8 @@ #include "curses.h" #include #include +#include +#include #include "sl.h" void add_smoke(int y, int x); @@ -56,6 +58,7 @@ int LOGO = 0; int FLY = 0; int C51 = 0; int SLOW = 0; +int FAST = 0; int my_mvaddstr(int y, int x, char *str) { @@ -84,11 +87,29 @@ void option(char *str) case 'l': LOGO = 1; break; case 'c': C51 = 1; break; case 's': SLOW = 1; break; + case 'f': FAST = 1; break; default: break; } } } +void cycle(unsigned long usecs) +{ + long elapsed; + struct timeval now; + static long start; + + if (usecs == 0) { + gettimeofday(&now, NULL); + start = now.tv_sec * 1000000L + now.tv_usec; + return; + } + gettimeofday(&now, NULL); + elapsed = now.tv_sec * 1000000L + now.tv_usec - start; + if (elapsed < usecs) + usleep(usecs - elapsed); +} + int main(int argc, char *argv[]) { int x, i; @@ -107,6 +128,9 @@ int main(int argc, char *argv[]) scrollok(stdscr, FALSE); for (x = COLS - 1; ; --x) { + if (!FAST && !SLOW) { + cycle(0); + } if (LOGO == 1) { if (add_sl(x) == ERR) break; } @@ -117,7 +141,9 @@ int main(int argc, char *argv[]) if (add_D51(x) == ERR) break; } refresh(); - //usleep(40000); + if (!FAST && !SLOW) { + cycle(40000); + } } mvcur(0, COLS - 1, LINES - 2, 0); endwin(); From e9e2c06c6723c095eac6d79aa61103d006ecd0aa Mon Sep 17 00:00:00 2001 From: Greg Haerr Date: Fri, 15 Sep 2023 13:00:59 -0700 Subject: [PATCH 2/2] cleanup --- elkscmd/tui/sl.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/elkscmd/tui/sl.c b/elkscmd/tui/sl.c index 0d66c31c6..ddba89441 100644 --- a/elkscmd/tui/sl.c +++ b/elkscmd/tui/sl.c @@ -95,7 +95,7 @@ void option(char *str) void cycle(unsigned long usecs) { - long elapsed; + unsigned long elapsed; struct timeval now; static long start;