about summary refs log tree commit diff
path: root/sol.c
diff options
context:
space:
mode:
authorJune McEnroe <june@causal.agency>2019-03-22 15:53:22 -0400
committerJune McEnroe <june@causal.agency>2019-03-22 15:53:22 -0400
commitd976c2a3e37f90aa6b34d6edaecd9b99de70260a (patch)
tree59b387cfa6535ff867956459ea414feae415c5ff /sol.c
parentImplement the game (diff)
downloadcards-d976c2a3e37f90aa6b34d6edaecd9b99de70260a.tar.gz
cards-d976c2a3e37f90aa6b34d6edaecd9b99de70260a.zip
Add F2 and b temporary key
Diffstat (limited to 'sol.c')
-rw-r--r--sol.c19
1 files changed, 16 insertions, 3 deletions
diff --git a/sol.c b/sol.c
index ed5981d..cde7b2b 100644
--- a/sol.c
+++ b/sol.c
@@ -307,6 +307,20 @@ static void layoutTableau(void) {
 	}
 }
 
+static bool keyDown(SDL_KeyboardEvent key) {
+	switch (key.keysym.sym) {
+		case SDLK_F2: gameDeal(); return true;
+		case SDLK_b: {
+			layout.backTexture -= Cards_Back1;
+			layout.backTexture += 1;
+			layout.backTexture %= 12;
+			layout.backTexture += Cards_Back1;
+			return true;
+		}
+		default: return false;
+	}
+}
+
 static bool mouseButtonDown(SDL_MouseButtonEvent button) {
 	struct SDL_Point point = { button.x, button.y };
 	if (SDL_PointInRect(&point, &layout.stacks[Stock])) {
@@ -408,9 +422,6 @@ int main(void) {
 
 	gameDeal();
 
-	// FIXME: Use a portable random.
-	layout.backTexture = Cards_Back1 + arc4random_uniform(12);
-
 	for (;;) {
 		layoutClear();
 		layoutStock();
@@ -430,6 +441,8 @@ int main(void) {
 			SDL_WaitEvent(&event);
 			if (event.type == SDL_QUIT) {
 				goto quit;
+			} else if (event.type == SDL_KEYDOWN) {
+				if (keyDown(event.key)) break;
 			} else if (event.type == SDL_MOUSEBUTTONDOWN) {
 				if (mouseButtonDown(event.button)) break;
 			} else if (event.type == SDL_MOUSEBUTTONUP) {