projects
/
rocksndiamonds.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
rnd-19981021-1
[rocksndiamonds.git]
/
src
/
events.c
diff --git
a/src/events.c
b/src/events.c
index 71d03604c22eb6081e1632232d3ffb852a5c9e41..976974ac58891e6b9c8db2bab1c9057e876dac75 100644
(file)
--- a/
src/events.c
+++ b/
src/events.c
@@
-62,6
+62,21
@@
void EventLoop(void)
break;
}
}
break;
}
}
+
+ HandleNoXEvent();
+
+ /* don't use all CPU time when idle; the main loop while playing
+ has its own synchronization and is CPU friendly, too */
+
+ if (game_status != PLAYING)
+ {
+ XSync(display, FALSE);
+ Delay(10);
+ }
+
+
+
+#if 0
else /* got no event, but don't be lazy... */
{
HandleNoXEvent();
else /* got no event, but don't be lazy... */
{
HandleNoXEvent();
@@
-75,6
+90,9
@@
void EventLoop(void)
Delay(10);
}
}
Delay(10);
}
}
+#endif
+
+
if (game_status == EXITGAME)
return;
if (game_status == EXITGAME)
return;
@@
-118,7
+136,7
@@
void ClearEventQueue()
void SleepWhileUnmapped()
{
void SleepWhileUnmapped()
{
-
BOOL
window_unmapped = TRUE;
+
boolean
window_unmapped = TRUE;
XAutoRepeatOn(display);
XAutoRepeatOn(display);
@@
-159,7
+177,7
@@
void HandleExposeEvent(XExposeEvent *event)
int x = event->x, y = event->y;
int width = event->width, height = event->height;
int x = event->x, y = event->y;
int width = event->width, height = event->height;
- if (direct_draw_on && game_status==PLAYING)
+ if (
setup.
direct_draw_on && game_status==PLAYING)
{
int xx,yy;
int x1 = (x-SX)/TILEX, y1 = (y-SY)/TILEY;
{
int xx,yy;
int x1 = (x-SX)/TILEX, y1 = (y-SY)/TILEY;
@@
-176,7
+194,7
@@
void HandleExposeEvent(XExposeEvent *event)
SetDrawtoField(DRAW_DIRECT);
}
SetDrawtoField(DRAW_DIRECT);
}
- if (soft_scrolling_on && game_status == PLAYING)
+ if (s
etup.s
oft_scrolling_on && game_status == PLAYING)
{
int fx = FX, fy = FY;
{
int fx = FX, fy = FY;
@@
-245,7
+263,7
@@
void HandleClientMessageEvent(XClientMessageEvent *event)
{
if ((event->window == window) &&
(event->data.l[0] == XInternAtom(display, "WM_DELETE_WINDOW", FALSE)))
{
if ((event->window == window) &&
(event->data.l[0] == XInternAtom(display, "WM_DELETE_WINDOW", FALSE)))
-
game_status = EXITGAME
;
+
CloseAllAndExit(0)
;
}
void HandleButton(int mx, int my, int button)
}
void HandleButton(int mx, int my, int button)
@@
-314,7
+332,13
@@
void HandleButton(int mx, int my, int button)
HandleSetupScreen(mx,my,0,0,button);
break;
case PLAYING:
HandleSetupScreen(mx,my,0,0,button);
break;
case PLAYING:
+
+ /* --> NoXEvent() will follow */
+
+ /*
HandleGameActions(0);
HandleGameActions(0);
+ */
+
break;
default:
break;
break;
default:
break;
@@
-648,7
+672,7
@@
void HandleKey(KeySym key, int key_status)
}
*/
}
*/
- printf("direct_draw_on == %d\n", direct_draw_on);
+ printf("direct_draw_on == %d\n",
setup.
direct_draw_on);
break;
break;
@@
-702,7
+726,8
@@
void HandleNoXEvent()
return;
}
return;
}
- HandleNetworking();
+ if (options.network)
+ HandleNetworking();
switch(game_status)
{
switch(game_status)
{
@@
-730,11
+755,6
@@
void HandleJoystick()
{
int joystick = Joystick();
int keyboard = key_joystick_mapping;
{
int joystick = Joystick();
int keyboard = key_joystick_mapping;
-
- /*
- int joy = (tape.playing ? TapePlayAction() : (joystick | keyboard));
- */
-
int joy = (joystick | keyboard);
int left = joy & JOY_LEFT;
int right = joy & JOY_RIGHT;
int joy = (joystick | keyboard);
int left = joy & JOY_LEFT;
int right = joy & JOY_RIGHT;
@@
-753,7
+773,7
@@
void HandleJoystick()
{
static long joystickmove_delay = 0;
{
static long joystickmove_delay = 0;
- if (joystick && !button && !DelayReached(&joystickmove_delay,15))
+ if (joystick && !button && !DelayReached(&joystickmove_delay,15
0
))
newbutton = dx = dy = 0;
if (game_status==MAINMENU)
newbutton = dx = dy = 0;
if (game_status==MAINMENU)
@@
-788,11
+808,6
@@
void HandleJoystick()
if (tape.pausing || AllPlayersGone)
joy = 0;
if (tape.pausing || AllPlayersGone)
joy = 0;
- /*
- if (!network_player_action_stored)
- SendToServer_MovePlayer(joy, 0);
- */
-
HandleGameActions((byte)joy);
break;
HandleGameActions((byte)joy);
break;