|
|
|
|
@@ -12,22 +12,22 @@ struct stack *cursor_stack(struct cursor *cursor) {
|
|
|
|
|
|
|
|
|
|
if (cursor->y == CURSOR_STARTING_Y) {
|
|
|
|
|
switch (cursor->x) {
|
|
|
|
|
case CURSOR_STOCK_X: cursor_stack = deck->stock;
|
|
|
|
|
case CURSOR_WASTE_PILE_X: cursor_stack = deck->waste_pile;
|
|
|
|
|
case CURSOR_FOUNDATION_0_X: cursor_stack = deck->foundation_0;
|
|
|
|
|
case CURSOR_FOUNDATION_1_X: cursor_stack = deck->foundation_1;
|
|
|
|
|
case CURSOR_FOUNDATION_2_X: cursor_stack = deck->foundation_2;
|
|
|
|
|
case CURSOR_FOUNDATION_3_X: cursor_stack = deck->foundation_3;
|
|
|
|
|
case CURSOR_STOCK_X: cursor_stack = deck->stock; break;
|
|
|
|
|
case CURSOR_WASTE_PILE_X: cursor_stack = deck->waste_pile; break;
|
|
|
|
|
case CURSOR_FOUNDATION_0_X: cursor_stack = deck->foundation_0; break;
|
|
|
|
|
case CURSOR_FOUNDATION_1_X: cursor_stack = deck->foundation_1; break;
|
|
|
|
|
case CURSOR_FOUNDATION_2_X: cursor_stack = deck->foundation_2; break;
|
|
|
|
|
case CURSOR_FOUNDATION_3_X: cursor_stack = deck->foundation_3; break;
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
switch (cursor->x) {
|
|
|
|
|
case CURSOR_MANEUVRE_0_X: cursor_stack = deck->maneuvre_0;
|
|
|
|
|
case CURSOR_MANEUVRE_1_X: cursor_stack = deck->maneuvre_1;
|
|
|
|
|
case CURSOR_MANEUVRE_2_X: cursor_stack = deck->maneuvre_2;
|
|
|
|
|
case CURSOR_MANEUVRE_3_X: cursor_stack = deck->maneuvre_3;
|
|
|
|
|
case CURSOR_MANEUVRE_4_X: cursor_stack = deck->maneuvre_4;
|
|
|
|
|
case CURSOR_MANEUVRE_5_X: cursor_stack = deck->maneuvre_5;
|
|
|
|
|
case CURSOR_MANEUVRE_6_X: cursor_stack = deck->maneuvre_6;
|
|
|
|
|
case CURSOR_MANEUVRE_0_X: cursor_stack = deck->maneuvre_0; break;
|
|
|
|
|
case CURSOR_MANEUVRE_1_X: cursor_stack = deck->maneuvre_1; break;
|
|
|
|
|
case CURSOR_MANEUVRE_2_X: cursor_stack = deck->maneuvre_2; break;
|
|
|
|
|
case CURSOR_MANEUVRE_3_X: cursor_stack = deck->maneuvre_3; break;
|
|
|
|
|
case CURSOR_MANEUVRE_4_X: cursor_stack = deck->maneuvre_4; break;
|
|
|
|
|
case CURSOR_MANEUVRE_5_X: cursor_stack = deck->maneuvre_5; break;
|
|
|
|
|
case CURSOR_MANEUVRE_6_X: cursor_stack = deck->maneuvre_6; break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@@ -38,6 +38,10 @@ bool cursor_on_stack(struct cursor *cursor, struct stack *stack) {
|
|
|
|
|
return(cursor_stack(cursor) == stack);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool cursor_on_invalid_spot(struct cursor *cursor) {
|
|
|
|
|
return(cursor->x == CURSOR_INVALID_SPOT_X &&
|
|
|
|
|
cursor->y == CURSOR_INVALID_SPOT_Y);
|
|
|
|
|
}
|
|
|
|
|
void handle_stock_event() {
|
|
|
|
|
if (!empty(deck->stock)) {
|
|
|
|
|
/* erase the stack before emptying it */
|
|
|
|
|
@@ -61,6 +65,12 @@ void handle_card_movement(struct cursor *cursor) {
|
|
|
|
|
mark_origin(cursor);
|
|
|
|
|
origin = cursor_stack(cursor);
|
|
|
|
|
|
|
|
|
|
/* trying to move cards from the space between the waste pile and the
|
|
|
|
|
* foundations */
|
|
|
|
|
if (cursor_on_invalid_spot(cursor)) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
while (1) {
|
|
|
|
|
switch (option = getch()) {
|
|
|
|
|
case 'h':
|
|
|
|
|
@@ -80,7 +90,9 @@ void handle_card_movement(struct cursor *cursor) {
|
|
|
|
|
move_cursor(cursor, RIGHT);
|
|
|
|
|
break;
|
|
|
|
|
case KEY_SPACEBAR:
|
|
|
|
|
if (!cursor_on_stock(cursor) && !cursor_on_stack(cursor, origin)) {
|
|
|
|
|
if (!cursor_on_invalid_spot(cursor) &&
|
|
|
|
|
!cursor_on_stock(cursor) &&
|
|
|
|
|
!cursor_on_stack(cursor, origin)) {
|
|
|
|
|
destination = cursor_stack(cursor);
|
|
|
|
|
move_card(&origin, &destination);
|
|
|
|
|
draw_stack(origin);
|
|
|
|
|
|