-
Notifications
You must be signed in to change notification settings - Fork 0
/
RollDiceAction.cpp
54 lines (39 loc) · 1.54 KB
/
RollDiceAction.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#include "RollDiceAction.h"
#include "Grid.h"
#include "Player.h"
#include <time.h> // used to in srand to generate random numbers with different seed
RollDiceAction::RollDiceAction(ApplicationManager *pApp) : Action(pApp)
{
}
void RollDiceAction::ReadActionParameters()
{
// no parameters to read from user
}
void RollDiceAction::Execute()
{
Grid* pGrid = pManager->GetGrid();
Output* pOut = pGrid->GetOutput();
///TODO: Implement this function as mentioned in the guideline steps (numbered below) below
// == Here are some guideline steps (numbered below) to implement this function ==
// 1- Check if the Game is ended (Use the GetEndGame() function of pGrid), if yes, make the appropriate action
if (!pGrid->GetEndGame())
{
// -- If not ended, do the following --:
// 2- Generate a random number from 1 to 6 --> This step is done for you
srand((int)time(NULL)); // time is for different seed each run
int diceNumber = 1 + rand() % 6; // from 1 to 6 --> should change seed
pOut->PrintMessage("Dice rolled ! you got : " + to_string(diceNumber));
// 3- Get the "current" player from pGrid
Player* pPlayer = pGrid->GetCurrentPlayer();
// 4- Move the currentPlayer using function Move of class player
pPlayer->Move(pGrid, diceNumber);
// 5- Advance the current player number of pGrid
pGrid->AdvanceCurrentPlayer();
// NOTE: the above guidelines are the main ones but not a complete set (You may need to add more steps).
}
else
pOut->PrintMessage("Can not roll dice game is finished");
}
RollDiceAction::~RollDiceAction()
{
}