enum {
KT_left, KT_right, KT_rotright, KT_rotleft, KT_drop, KT_down,
- KT_faster, KT_pause, KT_redraw, KT_quit, KT_numKeys
+ KT_faster, KT_pause, KT_redraw, KT_say, KT_quit, KT_numKeys
};
static char *keyNames[KT_numKeys+1] = {
"Left", "Right", "RotRight", "RotLeft", "Drop", "Down",
- "Faster", "Pause", "Redraw", "Quit", NULL
+ "Faster", "Pause", "Redraw", "Say", "Quit", NULL
};
_Sets Sets = {7, 0, 1, 1, 1};
return;
} //key in chat mode
- if (key == 13) {
+ if (!(p = strchr(keyTable, tolower(key)))) return;
+ key = p - keyTable;
+
+ // global actions (always possible, even if not playing)
+ switch (key) {
+ case KT_redraw:
+ clear();
+ InitFields();
+// ScheduleFullRedraw();
+ refresh();
+ break;
+ case KT_say:
chatMode = 1;
Messagetype(key, strlen(chatText) - 1, chatText);
+ break;
+ case KT_quit:
+ ShowPause(me);
+ refresh();
+ gameStatus = 0;
+ break;
}
- if (!(p = strchr(keyTable, tolower(key)))) return;
- key = p - keyTable;
- if (Players[me].alive <= 0 && key != KT_quit) return;
- if (paused && key < KT_pause) return;
+ if (Players[me].alive <= 0) return;
+ // actions available while in game
+ switch (key) {
+ case KT_pause:
+ Players[me].flags ^= SCF_paused;
+ if (Game.started > 1)
+ Message(Players[me].flags & SCF_paused
+ ? "You paused the game" : "You unpaused the game");
+ else
+ Message(Players[me].flags & SCF_paused
+ ? "You are not ready" : "You are ready");
+ checkPaused();
+ if (game == GT_classicTwo)
+ SendPacket(me, NP_pause, 0, NULL);
+ ShowPause(me);
+ changed = 1;
+ break;
+ }
+
+ if (paused) return;
+ // actions only available while actually playing
switch (key) {
case KT_left:
if (MovePiece(me, 0, -1) && spied) SendPacket(me, NP_left, 0, NULL);
ShowScore(me, Players[me].score);
changed = 1;
break;
- case KT_pause:
- Players[me].flags ^= SCF_paused;
- if (Game.started > 1)
- Message(Players[me].flags & SCF_paused
- ? "You paused the game" : "You unpaused the game");
- else
- Message(Players[me].flags & SCF_paused
- ? "You are not ready" : "You are ready");
- checkPaused();
- if (game == GT_classicTwo)
- SendPacket(me, NP_pause, 0, NULL);
- ShowPause(me);
- changed = 1;
- break;
- case KT_redraw:
- clear();
- InitFields();
-// ScheduleFullRedraw();
- refresh();
- break;
- case KT_quit:
- ShowPause(me);
- refresh();
- gameStatus = 0;
- break;
- } //E_key
+ }
+
if (dropMode && DropPiece(me) > 0) {
SetITimer(Game.speed, Game.speed);
if (spied) SendPacket(me, NP_drop, 0, NULL);