]> git.cworth.org Git - ttt/blobdiff - src/test-board.c
Add a dependency of ttt-client.c on ttt-lex.h to fix the build.
[ttt] / src / test-board.c
index 104395ef39748fc5f335e8fe3d093a6146e19523..0ec4e24275565ff3c2cdec05b229d7914db0a9f2 100644 (file)
@@ -7,27 +7,42 @@ main (void)
 {
     ttt_board_t board;
     int m, i, newline;
-    
+    ttt_cell_t winner, move_result;
+
     ttt_board_init (&board);
     
+
     i = 0; while (i < 9)
     {
        ttt_board_write (&board, stdout);
        printf ("\n");    
        
-       printf ("Make a move ");
+       printf ("Make a move: ");
        m = getchar();
+       if (m == EOF)
+       {
+           printf ("\nGoodbye.\n");
+           exit (1);
+       }
        newline = getchar();
-       m = m - '0';
-       if (ttt_board_make_move (&board, m) == TTT_ERROR_NOT_VALID_MOVE)
+       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;
-       ttt_board_is_won (&board);
-       if (ttt_board_is_won (&board) == TTT_CELL_X)
+       
+       winner = ttt_board_is_won (&board);
+       if (winner == TTT_CELL_X)
        {
            printf ("X's Win! ");
            break;
        }
-       else if (ttt_board_is_won (&board) == TTT_CELL_O)
+       else if (winner == TTT_CELL_O)
        {
            printf ("O's Win! ");
            break;
@@ -41,6 +56,7 @@ main (void)
     }
     
     ttt_board_write (&board, stdout);
-    printf ("\n");    
+    printf ("\n");
+
     return 0;
 }