From 80cb833594587750b78e449de461d84961ed7b13 Mon Sep 17 00:00:00 2001 From: Drew Stratford Date: Tue, 30 Jul 2019 03:46:21 +1200 Subject: [PATCH] Minesweeper: refactor on_square_clicked and flood_mark Both on_square_clicked and flood_mark were very similar so I've introduced the on_square_clicked_impl function which is now called by on_square_clicked and flood_fill. --- Games/Minesweeper/Field.cpp | 36 +++++++++++------------------------- Games/Minesweeper/Field.h | 2 +- 2 files changed, 12 insertions(+), 26 deletions(-) diff --git a/Games/Minesweeper/Field.cpp b/Games/Minesweeper/Field.cpp index fd8b7ddc3e4..13c7ded0ce4 100644 --- a/Games/Minesweeper/Field.cpp +++ b/Games/Minesweeper/Field.cpp @@ -272,39 +272,20 @@ void Field::reset() set_updates_enabled(true); } -void Field::flood_mark(Square& square) -{ - if (square.is_swept) - return; - if (square.has_flag) - return; - if (square.is_considering) - return; - update(); - square.is_swept = true; - square.button->set_visible(false); - square.label->set_visible(true); - - --m_unswept_empties; - - if (!m_unswept_empties) - win(); -} - void Field::flood_fill(Square& square) { Queue queue; queue.enqueue(&square); - while(!queue.is_empty()) { - Square *s = queue.dequeue(); + while (!queue.is_empty()) { + Square* s = queue.dequeue(); s->for_each_neighbor([this, &queue](Square& neighbor) { if (!neighbor.is_swept && !neighbor.has_mine && neighbor.number == 0) { - flood_mark(neighbor); + on_square_clicked_impl(neighbor, false); queue.enqueue(&neighbor); } if (!neighbor.has_mine && neighbor.number) - flood_mark(neighbor); + on_square_clicked_impl(neighbor, false); }); } } @@ -330,7 +311,7 @@ void Field::paint_event(GPaintEvent& event) } } -void Field::on_square_clicked(Square& square) +void Field::on_square_clicked_impl(Square& square, bool should_flood_fill) { if (m_first_click) { while (square.has_mine) { @@ -358,13 +339,18 @@ void Field::on_square_clicked(Square& square) } --m_unswept_empties; - if (square.number == 0) + if (should_flood_fill && square.number == 0) flood_fill(square); if (!m_unswept_empties) win(); } +void Field::on_square_clicked(Square& square) +{ + on_square_clicked_impl(square, true); +} + void Field::on_square_chorded(Square& square) { if (!square.is_swept) diff --git a/Games/Minesweeper/Field.h b/Games/Minesweeper/Field.h index dec6a445121..0c01a02572b 100644 --- a/Games/Minesweeper/Field.h +++ b/Games/Minesweeper/Field.h @@ -67,7 +67,7 @@ private: const Square& square(int row, int column) const { return *m_squares[row * columns() + column]; } void flood_fill(Square&); - void flood_mark(Square&); + void on_square_clicked_impl(Square&, bool); template void for_each_square(Callback);