rayzor

annotate src/dosemu/dosemu.c @ 12:d94a69933a71

lots of stuff, can't remember
author John Tsiombikas <nuclear@member.fsf.org>
date Sat, 12 Apr 2014 23:28:24 +0300
parents 70e332156d02
children a9a948809c6f
rev   line source
nuclear@5 1 /* This file implements all calls made to dos-specific code using SDL */
nuclear@5 2 #include <stdlib.h>
nuclear@5 3 #include <assert.h>
nuclear@5 4 #include <SDL/SDL.h>
nuclear@5 5 #ifdef DOSEMU_CAPTURE
nuclear@5 6 #include <imago2.h>
nuclear@5 7 #endif
nuclear@5 8 #include "gfx.h"
nuclear@5 9 #include "mouse.h"
nuclear@5 10 #include "keyb.h"
nuclear@5 11 #include "timer.h"
nuclear@5 12
nuclear@9 13 static void cleanup(void);
nuclear@5 14 static void proc_events(void);
nuclear@12 15 static int translate_sdlkey(int sym);
nuclear@12 16 static void update_modkeys(void);
nuclear@5 17 static void capture_frame(unsigned char *frame);
nuclear@5 18
nuclear@9 19 static void init_sdl(void)
nuclear@5 20 {
nuclear@5 21 const SDL_version *ver;
nuclear@5 22
nuclear@5 23 if(!SDL_WasInit(SDL_INIT_EVERYTHING)) {
nuclear@5 24 SDL_Init(SDL_INIT_VIDEO | SDL_INIT_TIMER);
nuclear@5 25
nuclear@5 26 if((ver = SDL_Linked_Version())) {
nuclear@5 27 printf("SDL %d.%d.%d initialized\n", ver->major, ver->minor, ver->patch);
nuclear@5 28 }
nuclear@9 29 atexit(cleanup);
nuclear@5 30 }
nuclear@5 31 }
nuclear@5 32
nuclear@9 33 static void cleanup(void)
nuclear@9 34 {
nuclear@9 35 SDL_Quit();
nuclear@9 36 }
nuclear@9 37
nuclear@5 38 /* ----- graphics (gfx.c (vbe) implementation) ----- */
nuclear@5 39 static SDL_Surface *fbsurf;
nuclear@5 40 static int scale = 1;
nuclear@5 41 static int frames_to_capture;
nuclear@5 42
nuclear@5 43 static struct {
nuclear@5 44 unsigned char r, g, b;
nuclear@5 45 } palette[256];
nuclear@5 46
nuclear@5 47
nuclear@5 48 void *set_video_mode(int xsz, int ysz, int bpp)
nuclear@5 49 {
nuclear@5 50 unsigned int sdl_flags = bpp <= 8 ? SDL_HWPALETTE : 0;
nuclear@5 51 char *env;
nuclear@5 52
nuclear@5 53 if(getenv("DOSEMU_DOUBLESIZE")) {
nuclear@5 54 scale = 2;
nuclear@5 55 }
nuclear@5 56
nuclear@5 57 if((env = getenv("DOSEMU_SCALE"))) {
nuclear@5 58 int n = atoi(env);
nuclear@5 59 if(n > 0) {
nuclear@5 60 scale = n;
nuclear@5 61 }
nuclear@5 62 }
nuclear@5 63 xsz *= scale;
nuclear@5 64 ysz *= scale;
nuclear@5 65
nuclear@5 66 if(getenv("DOSEMU_FULLSCREEN")) {
nuclear@5 67 sdl_flags |= SDL_FULLSCREEN;
nuclear@5 68 }
nuclear@5 69
nuclear@5 70 init_sdl();
nuclear@5 71
nuclear@5 72 if(!(fbsurf = SDL_SetVideoMode(xsz, ysz, bpp, sdl_flags))) {
nuclear@5 73 fprintf(stderr, "failed to set video mode\n");
nuclear@5 74 abort();
nuclear@5 75 }
nuclear@5 76 SDL_WM_SetCaption("Rayzor", 0);
nuclear@5 77 /*SDL_ShowCursor(0);*/
nuclear@5 78
nuclear@5 79 return fbsurf->pixels;
nuclear@5 80 }
nuclear@5 81
nuclear@5 82 int set_text_mode(void)
nuclear@5 83 {
nuclear@5 84 SDL_ShowCursor(1);
nuclear@5 85 SDL_EnableKeyRepeat(0, 0);
nuclear@5 86 return 0;
nuclear@5 87 }
nuclear@5 88
nuclear@5 89 int get_color_depth(void)
nuclear@5 90 {
nuclear@5 91 return fbsurf->format->BitsPerPixel;
nuclear@5 92 }
nuclear@5 93
nuclear@5 94 static int count_bits(unsigned int x)
nuclear@5 95 {
nuclear@5 96 int i, count = 0;
nuclear@5 97 for(i=0; i<32; i++) {
nuclear@5 98 if(x & 1) {
nuclear@5 99 count++;
nuclear@5 100 }
nuclear@5 101 x >>= 1;
nuclear@5 102 }
nuclear@5 103 return count;
nuclear@5 104 }
nuclear@5 105
nuclear@5 106 int get_color_bits(int *rbits, int *gbits, int *bbits)
nuclear@5 107 {
nuclear@5 108 *rbits = count_bits(fbsurf->format->Rmask);
nuclear@5 109 *gbits = count_bits(fbsurf->format->Gmask);
nuclear@5 110 *bbits = count_bits(fbsurf->format->Bmask);
nuclear@5 111 return *rbits + *gbits + *bbits;
nuclear@5 112 }
nuclear@5 113
nuclear@5 114 int get_color_shift(int *rshift, int *gshift, int *bshift)
nuclear@5 115 {
nuclear@5 116 *rshift = fbsurf->format->Rshift;
nuclear@5 117 *gshift = fbsurf->format->Gshift;
nuclear@5 118 *bshift = fbsurf->format->Bshift;
nuclear@5 119 return 0;
nuclear@5 120 }
nuclear@5 121
nuclear@5 122 int get_color_mask(unsigned int *rmask, unsigned int *gmask, unsigned int *bmask)
nuclear@5 123 {
nuclear@5 124 *rmask = fbsurf->format->Rmask;
nuclear@5 125 *gmask = fbsurf->format->Gmask;
nuclear@5 126 *bmask = fbsurf->format->Bmask;
nuclear@5 127 return 0;
nuclear@5 128 }
nuclear@5 129
nuclear@5 130
nuclear@5 131 void set_palette(int idx, int r, int g, int b)
nuclear@5 132 {
nuclear@5 133 SDL_Color col;
nuclear@5 134 col.r = r;
nuclear@5 135 col.g = g;
nuclear@5 136 col.b = b;
nuclear@5 137
nuclear@5 138 if(SDL_SetPalette(fbsurf, SDL_LOGPAL | SDL_PHYSPAL, &col, idx, 1) != 1) {
nuclear@5 139 fprintf(stderr, "set_palette failed to set the required color\n");
nuclear@5 140 }
nuclear@5 141
nuclear@5 142 palette[idx].r = r;
nuclear@5 143 palette[idx].g = g;
nuclear@5 144 palette[idx].b = b;
nuclear@5 145 }
nuclear@5 146
nuclear@5 147 static int copy_frame_called;
nuclear@5 148
nuclear@5 149 void copy_frame(void *pixels)
nuclear@5 150 {
nuclear@5 151 unsigned char *frame = (unsigned char*)pixels;
nuclear@5 152 copy_frame_called = 1;
nuclear@5 153
nuclear@5 154 if(SDL_MUSTLOCK(fbsurf)) {
nuclear@5 155 SDL_LockSurface(fbsurf);
nuclear@5 156 }
nuclear@5 157
nuclear@5 158 if(pixels) {
nuclear@5 159 if(scale > 1) {
nuclear@5 160 int i, j, xsz, ysz;
nuclear@5 161 unsigned char *dest = fbsurf->pixels;
nuclear@5 162
nuclear@5 163 xsz = fbsurf->w * scale;
nuclear@5 164 ysz = fbsurf->h * scale;
nuclear@5 165
nuclear@5 166 for(i=0; i<ysz; i++) {
nuclear@5 167 for(j=0; j<xsz; j++) {
nuclear@5 168 *dest++ = frame[(i / scale) * fbsurf->w + (j / scale)];
nuclear@5 169 }
nuclear@5 170 }
nuclear@5 171 } else {
nuclear@5 172 int num_pixels = fbsurf->w * fbsurf->h;
nuclear@5 173 memcpy(fbsurf->pixels, frame, num_pixels * fbsurf->format->BytesPerPixel);
nuclear@5 174 }
nuclear@5 175 }
nuclear@5 176
nuclear@5 177 if(SDL_MUSTLOCK(fbsurf)) {
nuclear@5 178 SDL_UnlockSurface(fbsurf);
nuclear@5 179 }
nuclear@5 180
nuclear@5 181 SDL_Flip(fbsurf);
nuclear@5 182
nuclear@5 183 if(frames_to_capture > 0) {
nuclear@5 184 capture_frame(pixels);
nuclear@5 185 --frames_to_capture;
nuclear@5 186 }
nuclear@5 187
nuclear@5 188 /* also print fps every second ... */
nuclear@9 189 /*{
nuclear@5 190 static long prev_fps, num_frames;
nuclear@5 191 long msec, dt;
nuclear@5 192
nuclear@5 193 msec = get_msec();
nuclear@5 194 dt = msec - prev_fps;
nuclear@5 195 if(dt >= 1000) {
nuclear@5 196 float fps = (float)num_frames / ((float)dt / 1000.0f);
nuclear@5 197 printf("framerate: %.1f \r", fps);
nuclear@5 198 fflush(stdout);
nuclear@5 199 num_frames = 0;
nuclear@5 200 prev_fps = msec;
nuclear@5 201 } else {
nuclear@5 202 num_frames++;
nuclear@5 203 }
nuclear@9 204 }*/
nuclear@5 205 }
nuclear@5 206
nuclear@5 207 #define spin_delay(ms) \
nuclear@5 208 do { \
nuclear@5 209 unsigned int end = SDL_GetTicks() + ms; \
nuclear@5 210 while((prev_msec = SDL_GetTicks()) < end); \
nuclear@5 211 } while(0)
nuclear@5 212
nuclear@5 213 #define FRAME_INTERVAL (1000/70)
nuclear@5 214
nuclear@5 215 void wait_vsync(void)
nuclear@5 216 {
nuclear@9 217 /*static int prev_msec;
nuclear@9 218 int msec, dt, tleft;*/
nuclear@5 219
nuclear@5 220 if(!copy_frame_called) {
nuclear@5 221 copy_frame(0);
nuclear@5 222 copy_frame_called = 0;
nuclear@5 223 }
nuclear@5 224
nuclear@9 225 /*
nuclear@5 226 msec = SDL_GetTicks();
nuclear@5 227
nuclear@5 228 dt = msec - prev_msec;
nuclear@5 229
nuclear@5 230 tleft = FRAME_INTERVAL - dt;
nuclear@5 231 if(tleft > 0) {
nuclear@5 232 int coarse = tleft & 0xfffffff8;
nuclear@5 233 tleft = tleft & 7;
nuclear@5 234
nuclear@5 235 if(coarse) {
nuclear@5 236 SDL_Delay(coarse);
nuclear@5 237 }
nuclear@5 238 if(tleft) {
nuclear@5 239 spin_delay(tleft);
nuclear@5 240 } else {
nuclear@5 241 prev_msec = SDL_GetTicks();
nuclear@5 242 }
nuclear@5 243 } else {
nuclear@5 244 prev_msec = msec;
nuclear@5 245 }
nuclear@9 246 */
nuclear@5 247 }
nuclear@5 248
nuclear@5 249 static int cap_count = 0;
nuclear@5 250 void begin_capture(int frames)
nuclear@5 251 {
nuclear@5 252 frames_to_capture = frames;
nuclear@5 253 }
nuclear@5 254
nuclear@5 255 void end_capture(void)
nuclear@5 256 {
nuclear@5 257 cap_count = 0;
nuclear@5 258 frames_to_capture = 0;
nuclear@5 259 }
nuclear@5 260
nuclear@5 261 #define NUMPIX (fbsurf->w * fbsurf->h)
nuclear@5 262 static void capture_frame(unsigned char *frame)
nuclear@5 263 {
nuclear@5 264 #ifdef DOSEMU_CAPTURE
nuclear@5 265 static unsigned char rgbpix[NUMPIX * 4];
nuclear@5 266 char fname[32];
nuclear@5 267 int i;
nuclear@5 268 unsigned char *src, *dest;
nuclear@5 269
nuclear@5 270 sprintf(fname, "frame%04d.png", cap_count++);
nuclear@5 271
nuclear@5 272 src = frame;
nuclear@5 273 dest = rgbpix;
nuclear@5 274
nuclear@5 275 for(i=0; i<NUMPIX; i++) {
nuclear@5 276 unsigned char c = *src++;
nuclear@5 277 *dest++ = palette[c].r;
nuclear@5 278 *dest++ = palette[c].g;
nuclear@5 279 *dest++ = palette[c].b;
nuclear@5 280 *dest++ = 255;
nuclear@5 281 }
nuclear@5 282
nuclear@5 283 img_save_pixels(fname, rgbpix, fbsurf->w, fbsurf->h, IMG_FMT_RGBA32);
nuclear@5 284 #endif
nuclear@5 285 }
nuclear@5 286
nuclear@5 287
nuclear@5 288 /* ----- event handling (conio.h) ----- */
nuclear@5 289 static SDL_Event *keybev;
nuclear@5 290 static int mousex, mousey, bnmask;
nuclear@5 291
nuclear@5 292 static int keystate[256];
nuclear@5 293 static int num_pressed;
nuclear@5 294
nuclear@5 295 int kbhit(void)
nuclear@5 296 {
nuclear@5 297 if(!keybev) {
nuclear@5 298 proc_events();
nuclear@5 299 }
nuclear@5 300 return keybev != 0;
nuclear@5 301 }
nuclear@5 302
nuclear@5 303 int getch(void)
nuclear@5 304 {
nuclear@5 305 int res;
nuclear@5 306
nuclear@5 307 while(!keybev) {
nuclear@5 308 SDL_Event ev;
nuclear@5 309 SDL_WaitEvent(&ev);
nuclear@5 310 SDL_PushEvent(&ev);
nuclear@5 311 proc_events();
nuclear@5 312 }
nuclear@5 313 res = keybev->key.keysym.sym;
nuclear@5 314 keybev = 0;
nuclear@5 315 return res;
nuclear@5 316 }
nuclear@5 317
nuclear@5 318 /* ----- improved event handling (keyb.h) ---- */
nuclear@12 319 static char sdlkey_tbl[SDLK_LAST];
nuclear@5 320
nuclear@5 321 int kb_init(int bufsz)
nuclear@5 322 {
nuclear@12 323 int i;
nuclear@5 324 init_sdl();
nuclear@5 325
nuclear@12 326 /* construct the SDL key translation table */
nuclear@12 327 for(i=0; i<256; i++) {
nuclear@12 328 sdlkey_tbl[i] = i; /* start from an identity mapping for the first 256 */
nuclear@12 329 }
nuclear@12 330 /* then change the special keys */
nuclear@12 331 sdlkey_tbl[SDLK_LALT] = KB_LALT;
nuclear@12 332 sdlkey_tbl[SDLK_RALT] = KB_RALT;
nuclear@12 333 sdlkey_tbl[SDLK_LCTRL] = KB_LCTRL;
nuclear@12 334 sdlkey_tbl[SDLK_RCTRL] = KB_RCTRL;
nuclear@12 335 sdlkey_tbl[SDLK_LSHIFT] = KB_LSHIFT;
nuclear@12 336 for(i=0; i<12; i++) {
nuclear@12 337 sdlkey_tbl[SDLK_F1 + i] = KB_F1 + i;
nuclear@12 338 }
nuclear@12 339 sdlkey_tbl[SDLK_CAPSLOCK] = KB_CAPSLK;
nuclear@12 340 sdlkey_tbl[SDLK_NUMLOCK] = KB_NUMLK;
nuclear@12 341 sdlkey_tbl[SDLK_SCROLLOCK] = KB_SCRLK;
nuclear@12 342 sdlkey_tbl[SDLK_SYSREQ] = KB_SYSRQ;
nuclear@12 343 sdlkey_tbl[SDLK_ESCAPE] = KB_ESC;
nuclear@12 344 sdlkey_tbl[SDLK_INSERT] = KB_INSERT;
nuclear@12 345 sdlkey_tbl[SDLK_DELETE] = KB_DEL;
nuclear@12 346 sdlkey_tbl[SDLK_HOME] = KB_HOME;
nuclear@12 347 sdlkey_tbl[SDLK_END] = KB_END;
nuclear@12 348 sdlkey_tbl[SDLK_PAGEUP] = KB_PGUP;
nuclear@12 349 sdlkey_tbl[SDLK_PAGEDOWN] = KB_PGDN;
nuclear@12 350 sdlkey_tbl[SDLK_LEFT] = KB_LEFT;
nuclear@12 351 sdlkey_tbl[SDLK_RIGHT] = KB_RIGHT;
nuclear@12 352 sdlkey_tbl[SDLK_UP] = KB_UP;
nuclear@12 353 sdlkey_tbl[SDLK_DOWN] = KB_DOWN;
nuclear@12 354 sdlkey_tbl[SDLK_KP_PERIOD] = KB_NUM_DOT;
nuclear@12 355 sdlkey_tbl[SDLK_KP_ENTER] = KB_NUM_ENTER;
nuclear@12 356 sdlkey_tbl[SDLK_KP_PLUS] = KB_NUM_PLUS;
nuclear@12 357 sdlkey_tbl[SDLK_KP_MINUS] = KB_NUM_MINUS;
nuclear@12 358 sdlkey_tbl[SDLK_KP_MULTIPLY] = KB_NUM_MUL;
nuclear@12 359 sdlkey_tbl[SDLK_KP_DIVIDE] = KB_NUM_DIV;
nuclear@12 360 /* TODO missing numeric keypad numbers */
nuclear@12 361 sdlkey_tbl[SDLK_BACKSPACE] = KB_BACKSP;
nuclear@12 362
nuclear@12 363
nuclear@5 364 return 0;
nuclear@5 365 }
nuclear@5 366
nuclear@5 367 void kb_shutdown(void)
nuclear@5 368 {
nuclear@5 369 }
nuclear@5 370
nuclear@5 371 int kb_getkey(void)
nuclear@5 372 {
nuclear@5 373 int res = -1;
nuclear@5 374
nuclear@5 375 proc_events();
nuclear@5 376 if(keybev) {
nuclear@12 377 res = translate_sdlkey(keybev->key.keysym.sym);
nuclear@5 378 keybev = 0;
nuclear@5 379 }
nuclear@5 380 return res;
nuclear@5 381 }
nuclear@5 382
nuclear@5 383 int kb_isdown(int key)
nuclear@5 384 {
nuclear@12 385 switch(key) {
nuclear@12 386 case KB_ANY:
nuclear@5 387 return num_pressed;
nuclear@12 388
nuclear@12 389 case KB_ALT:
nuclear@12 390 return keystate[KB_LALT] + keystate[KB_RALT];
nuclear@12 391
nuclear@12 392 case KB_CTRL:
nuclear@12 393 return keystate[KB_LCTRL] + keystate[KB_RCTRL];
nuclear@5 394 }
nuclear@5 395 return keystate[key];
nuclear@5 396 }
nuclear@5 397
nuclear@5 398 /* mouse handling (mouse.c implementation) */
nuclear@5 399 static unsigned long last_mouse_hide_time;
nuclear@5 400
nuclear@5 401 int have_mouse(void)
nuclear@5 402 {
nuclear@5 403 return 1;
nuclear@5 404 }
nuclear@5 405
nuclear@8 406 void set_mouse_limits(int xmin, int ymin, int xmax, int ymax)
nuclear@8 407 {
nuclear@8 408 }
nuclear@8 409
nuclear@5 410 void set_mouse(int x, int y)
nuclear@5 411 {
nuclear@5 412 SDL_ShowCursor(0);
nuclear@5 413 last_mouse_hide_time = get_msec();
nuclear@5 414
nuclear@5 415 SDL_WarpMouse(x * scale, y * scale);
nuclear@5 416 mousex = x;
nuclear@5 417 mousey = y;
nuclear@5 418 }
nuclear@5 419
nuclear@5 420 int read_mouse(int *xp, int *yp)
nuclear@5 421 {
nuclear@5 422 if(xp) *xp = mousex;
nuclear@5 423 if(yp) *yp = mousey;
nuclear@5 424 return bnmask;
nuclear@5 425 }
nuclear@5 426
nuclear@5 427 static void proc_events(void)
nuclear@5 428 {
nuclear@5 429 static SDL_Event ev;
nuclear@5 430
nuclear@5 431 if(last_mouse_hide_time > 0 && get_msec() - last_mouse_hide_time > 3000) {
nuclear@5 432 last_mouse_hide_time = 0;
nuclear@5 433 SDL_ShowCursor(1);
nuclear@5 434 }
nuclear@5 435
nuclear@5 436 while(SDL_PollEvent(&ev)) {
nuclear@5 437 switch(ev.type) {
nuclear@5 438 case SDL_KEYDOWN:
nuclear@5 439 {
nuclear@12 440 int key = translate_sdlkey(ev.key.keysym.sym);
nuclear@5 441
nuclear@5 442 if(!keybev) {
nuclear@5 443 keybev = &ev;
nuclear@5 444 }
nuclear@5 445
nuclear@5 446 if(!keystate[key]) {
nuclear@5 447 keystate[key] = 1;
nuclear@5 448 num_pressed++;
nuclear@5 449 }
nuclear@12 450
nuclear@12 451 update_modkeys();
nuclear@5 452 }
nuclear@5 453 break;
nuclear@5 454
nuclear@5 455 case SDL_KEYUP:
nuclear@5 456 {
nuclear@12 457 int key = translate_sdlkey(ev.key.keysym.sym);
nuclear@5 458
nuclear@5 459 if(keystate[key]) {
nuclear@5 460 keystate[key] = 0;
nuclear@5 461 if(--num_pressed < 0) {
nuclear@5 462 num_pressed = 0;
nuclear@5 463 }
nuclear@5 464 }
nuclear@12 465
nuclear@12 466 update_modkeys();
nuclear@5 467 }
nuclear@5 468 break;
nuclear@5 469
nuclear@5 470 case SDL_MOUSEMOTION:
nuclear@5 471 mousex = ev.motion.x / scale;
nuclear@5 472 mousey = ev.motion.y / scale;
nuclear@5 473 break;
nuclear@5 474
nuclear@5 475 case SDL_MOUSEBUTTONDOWN:
nuclear@5 476 case SDL_MOUSEBUTTONUP:
nuclear@5 477 {
nuclear@5 478 int mask = 0;
nuclear@5 479 switch(ev.button.button) {
nuclear@5 480 case SDL_BUTTON_LEFT:
nuclear@5 481 mask = MOUSE_LEFT;
nuclear@5 482 break;
nuclear@5 483 case SDL_BUTTON_MIDDLE:
nuclear@5 484 mask = MOUSE_MIDDLE;
nuclear@5 485 break;
nuclear@5 486 case SDL_BUTTON_RIGHT:
nuclear@5 487 mask = MOUSE_RIGHT;
nuclear@5 488 default:
nuclear@5 489 break;
nuclear@5 490 }
nuclear@5 491 if(!mask) {
nuclear@5 492 break;
nuclear@5 493 }
nuclear@5 494
nuclear@5 495 if(ev.button.state == SDL_PRESSED) {
nuclear@5 496 bnmask |= mask;
nuclear@5 497 } else {
nuclear@5 498 bnmask &= ~mask;
nuclear@5 499 }
nuclear@5 500 }
nuclear@5 501 break;
nuclear@5 502
nuclear@5 503 default:
nuclear@5 504 break;
nuclear@5 505 }
nuclear@5 506 }
nuclear@5 507 }
nuclear@5 508
nuclear@12 509 static int translate_sdlkey(int sym)
nuclear@12 510 {
nuclear@12 511 if(sym >= 0 && sym < 256) {
nuclear@12 512 return sdlkey_tbl[sym];
nuclear@12 513 }
nuclear@12 514 return sym;
nuclear@12 515 }
nuclear@12 516
nuclear@12 517 static void update_modkeys(void)
nuclear@12 518 {
nuclear@12 519 unsigned int mod = SDL_GetModState();
nuclear@12 520
nuclear@12 521 keystate[KB_LALT] = mod & KMOD_LALT;
nuclear@12 522 keystate[KB_RALT] = mod & KMOD_RALT;
nuclear@12 523 keystate[KB_LCTRL] = mod & KMOD_LCTRL;
nuclear@12 524 keystate[KB_RCTRL] = mod & KMOD_RCTRL;
nuclear@12 525 keystate[KB_LSHIFT] = mod & KMOD_LSHIFT;
nuclear@12 526 keystate[KB_RSHIFT] = mod & KMOD_RSHIFT;
nuclear@12 527 }
nuclear@12 528
nuclear@5 529 /* ---- timer.c implementation ---- */
nuclear@5 530 static Uint32 start_time;
nuclear@5 531
nuclear@5 532 void init_timer(int res_hz)
nuclear@5 533 {
nuclear@5 534 init_sdl();
nuclear@5 535 reset_timer();
nuclear@5 536 }
nuclear@5 537
nuclear@5 538 void reset_timer(void)
nuclear@5 539 {
nuclear@5 540 start_time = SDL_GetTicks();
nuclear@5 541 printf("resetting timer: %u, %lu\n", start_time, get_msec());
nuclear@5 542 }
nuclear@5 543
nuclear@5 544 unsigned long get_msec(void)
nuclear@5 545 {
nuclear@5 546 Uint32 ticks = SDL_GetTicks();
nuclear@5 547 return (unsigned long)(ticks - start_time);
nuclear@5 548 }