]> git.cworth.org Git - ttt/blobdiff - src/test-board.c
2006-01-14 Carl Worth <cworth@cworth.org>
[ttt] / src / test-board.c
index d4abb29be4df89d64f40ac86f1a5c71dee8e342f..0ec4e24275565ff3c2cdec05b229d7914db0a9f2 100644 (file)
@@ -6,21 +6,57 @@ int
 main (void)
 {
     ttt_board_t board;
-    int m;
-    
+    int m, i, newline;
+    ttt_cell_t winner, move_result;
+
     ttt_board_init (&board);
     
-    printf ("This is the board \"");
-    ttt_board_write (&board, stdout);
-    printf ("\"\n");
-    
-    printf ("Make a move");
-    m = getchar() - '0';
-    ttt_board_make_move (&board, m);
 
-    printf ("This is the board \"");
+    i = 0; while (i < 9)
+    {
+       ttt_board_write (&board, stdout);
+       printf ("\n");    
+       
+       printf ("Make a move: ");
+       m = getchar();
+       if (m == EOF)
+       {
+           printf ("\nGoodbye.\n");
+           exit (1);
+       }
+       newline = getchar();
+       m -= '0';
+       move_result = ttt_board_make_move (&board, m);
+       if (move_result == TTT_ERROR_NOT_GRID)
+       {
+           printf ("Sorry, %c is an invalid move.\n"
+                   "Please enter a number between 0 & 8.", m + '0');
+           continue;
+       }
+       if (move_result == TTT_ERROR_NOT_VALID_MOVE)
+           continue;
+       
+       winner = ttt_board_is_won (&board);
+       if (winner == TTT_CELL_X)
+       {
+           printf ("X's Win! ");
+           break;
+       }
+       else if (winner == TTT_CELL_O)
+       {
+           printf ("O's Win! ");
+           break;
+       }
+       else if (i == 8)
+       {
+           printf ("Cat's Game!");
+           break;
+       }
+       i++;
+    }
+    
     ttt_board_write (&board, stdout);
-    printf ("\"\n");
+    printf ("\n");
 
     return 0;
 }