Merge pull request 'cleanup' (#4) from cleanup into main

Reviewed-on: #4
This commit is contained in:
Rasmus Rasmussen 2025-03-19 10:48:15 +00:00
commit b285704ae1
11 changed files with 53 additions and 59 deletions

View File

@ -3,11 +3,11 @@
class FileHelper { class FileHelper {
public: public:
FileHelper(); FileHelper() = default;
~FileHelper(); ~FileHelper() = default;
static bool FileExists(char *path); static bool fileExists(char *path);
}; };
#endif #endif

View File

@ -4,13 +4,15 @@
#include <string> #include <string>
#include <vector> #include <vector>
using namespace std;
class FileReader { class FileReader {
public: public:
FileReader(); FileReader() = default;
~FileReader(); ~FileReader() = default;
static std::string GetFile(char *path); static string getFile(char *path);
}; };
#endif #endif

View File

@ -8,11 +8,12 @@ using namespace std;
class NumberHelper { class NumberHelper {
public: public:
NumberHelper(); NumberHelper() = default;
~NumberHelper(); ~NumberHelper() = default;
static vector<int> GetNumbers(string csv); static vector<int> getRolls(string csv);
}; };
#endif #endif

View File

@ -7,12 +7,12 @@ using namespace std;
class PrintFrames { class PrintFrames {
public: public:
PrintFrames(); PrintFrames() = default;
~PrintFrames(); ~PrintFrames() = default;
static void PrintHeader(vector<int> rolls); static void printHeader(vector<int> rolls);
static void PrintValue(vector<int> rolls); static void printValue(vector<int> rolls);
}; };
#endif #endif

View File

@ -8,11 +8,11 @@ using namespace std;
class ScoreCalculator { class ScoreCalculator {
public: public:
ScoreCalculator(); ScoreCalculator() = default;
~ScoreCalculator(); ~ScoreCalculator() = default;
static int GetScore(vector<int> rolls); static int getScore(vector<int> rolls);
}; };
#endif #endif

View File

@ -1,10 +1,7 @@
#include "../include/FileHelper.h" #include "../include/FileHelper.h"
#include <sys/stat.h> #include <sys/stat.h>
FileHelper::FileHelper() {}; bool FileHelper::fileExists(char *path){
FileHelper::~FileHelper() {};
bool FileHelper::FileExists(char *path){
struct stat s; struct stat s;
// Check if file exists, and if it isn't a folder. // Check if file exists, and if it isn't a folder.

View File

@ -2,15 +2,12 @@
#include <string> #include <string>
#include <fstream> #include <fstream>
FileReader::FileReader() {}; string FileReader::getFile(char *path){
FileReader::~FileReader() {}; ifstream file(path);
std::string FileReader::GetFile(char *path){
std::ifstream file(path);
std::string line; string line;
std::getline(file, line); getline(file, line);
file.close(); file.close();

View File

@ -3,16 +3,14 @@
#include <sstream> #include <sstream>
#include <vector> #include <vector>
NumberHelper::NumberHelper() {}; vector<int> NumberHelper::getRolls(string csv){
NumberHelper::~NumberHelper() {}; vector<int> rolls;
stringstream ss(csv);
std::vector<int> NumberHelper::GetNumbers(std::string csv){ string number;
std::vector<int> rolls;
std::stringstream ss(csv);
std::string number;
while (std::getline(ss, number, ',')) { // Get number from the CSV file, split by comma, and convert to int.
rolls.push_back(std::stoi(number)); while (getline(ss, number, ',')) {
rolls.push_back(stoi(number));
} }
return rolls; return rolls;

View File

@ -1,10 +1,7 @@
#include "../include/PrintFrames.h" #include "../include/PrintFrames.h"
#include <iostream> #include <iostream>
PrintFrames::PrintFrames() {}; void PrintFrames::printHeader(vector<int> rolls){
PrintFrames::~PrintFrames() {};
void PrintFrames::PrintHeader(vector<int> rolls){
int frame = 0; int frame = 0;
int i = 1; int i = 1;
@ -13,7 +10,7 @@ void PrintFrames::PrintHeader(vector<int> rolls){
// Strike // Strike
if (rolls[frame] == 10) { if (rolls[frame] == 10) {
// If we're on our last frame, and roll a 10. // If we're on our last frame, and roll a strike, we're given two bonus rolls.
if (frame + 3 == rolls.size() && rolls[frame - 3] == 10) { if (frame + 3 == rolls.size() && rolls[frame - 3] == 10) {
cout << " f" << i << " |" << endl; cout << " f" << i << " |" << endl;
break; break;
@ -25,6 +22,7 @@ void PrintFrames::PrintHeader(vector<int> rolls){
// Spare // Spare
else if (rolls[frame] + rolls[frame + 1] == 10) { else if (rolls[frame] + rolls[frame + 1] == 10) {
// If we're on our last frame, and roll a spare, we're given a bonus roll.
if (frame + 3 == rolls.size() && rolls[frame] + rolls[frame + 1] == 10) if (frame + 3 == rolls.size() && rolls[frame] + rolls[frame + 1] == 10)
{ {
cout << " f" << i << " |" << endl; cout << " f" << i << " |" << endl;
@ -43,6 +41,7 @@ void PrintFrames::PrintHeader(vector<int> rolls){
++i; ++i;
// No more frames
if (frame == rolls.size()) { if (frame == rolls.size()) {
cout << "|" << endl; cout << "|" << endl;
break; break;
@ -50,7 +49,7 @@ void PrintFrames::PrintHeader(vector<int> rolls){
} }
} }
void PrintFrames::PrintValue(vector<int> rolls){ void PrintFrames::printValue(vector<int> rolls){
int frame = 0; int frame = 0;
while (true) { while (true) {
@ -58,7 +57,7 @@ void PrintFrames::PrintValue(vector<int> rolls){
// Strike // Strike
if (rolls[frame] == 10) { if (rolls[frame] == 10) {
// If we're on our last frame, and roll a 10. // If we're on our last frame, and roll a strike, we're given two bonus rolls.
if (frame + 3 == rolls.size() && rolls[frame - 3] == 10) { if (frame + 3 == rolls.size() && rolls[frame - 3] == 10) {
if (rolls[frame + 1] == 10 && rolls[frame + 2] == 10) { if (rolls[frame + 1] == 10 && rolls[frame + 2] == 10) {
cout << "X, X, X|" << endl; cout << "X, X, X|" << endl;
@ -85,6 +84,7 @@ void PrintFrames::PrintValue(vector<int> rolls){
// Spare // Spare
else if (rolls[frame] + rolls[frame + 1] == 10) { else if (rolls[frame] + rolls[frame + 1] == 10) {
// If we're on our last frame, and roll a spare, we're given a bonus roll.
if (frame + 3 == rolls.size() && rolls[frame] + rolls[frame + 1] == 10) if (frame + 3 == rolls.size() && rolls[frame] + rolls[frame + 1] == 10)
{ {
cout << rolls[frame] << ", /" << ", " << rolls[frame + 1] << "|" << endl; cout << rolls[frame] << ", /" << ", " << rolls[frame + 1] << "|" << endl;

View File

@ -1,16 +1,13 @@
#include "../include/ScoreCalculator.h" #include "../include/ScoreCalculator.h"
ScoreCalculator::ScoreCalculator() {}; int ScoreCalculator::getScore(vector<int> rolls) {
ScoreCalculator::~ScoreCalculator() {};
int ScoreCalculator::GetScore(vector<int> rolls) {
int score = 0; int score = 0;
int frame = 0; int frame = 0;
while (true) { while (true) {
// Strike // Strike
if (rolls[frame] == 10) { if (rolls[frame] == 10) {
// If we're on our last frame, and roll a 10. // If we're on our last frame, and roll a strike, we're given two bonus rolls.
if (frame + 3 == rolls.size() && rolls[frame - 3] == 10) { if (frame + 3 == rolls.size() && rolls[frame - 3] == 10) {
score += 10 + rolls[frame + 1] + rolls[frame + 2]; score += 10 + rolls[frame + 1] + rolls[frame + 2];
break; break;
@ -18,11 +15,11 @@ int ScoreCalculator::GetScore(vector<int> rolls) {
score += 10 + rolls[frame + 1] + rolls[frame + 2]; score += 10 + rolls[frame + 1] + rolls[frame + 2];
frame += 1; frame += 1;
continue;
} }
// Spare // Spare
if (rolls[frame] + rolls[frame + 1] == 10) { else if (rolls[frame] + rolls[frame + 1] == 10) {
// If we're on our last frame, and roll a spare, we're given a bonus roll.
if (frame + 3 == rolls.size() && rolls[frame] + rolls[frame + 1] == 10) if (frame + 3 == rolls.size() && rolls[frame] + rolls[frame + 1] == 10)
{ {
score += 10 + rolls[frame + 1]; score += 10 + rolls[frame + 1];
@ -31,13 +28,15 @@ int ScoreCalculator::GetScore(vector<int> rolls) {
score += 10 + rolls[frame + 2]; score += 10 + rolls[frame + 2];
frame += 2; frame += 2;
continue;
} }
// Open Frame // Open Frame
score += rolls[frame] + rolls[frame + 1]; else {
frame += 2; score += rolls[frame] + rolls[frame + 1];
frame += 2;
}
// No more frames
if (frame == rolls.size()) { if (frame == rolls.size()) {
break; break;
} }

View File

@ -14,18 +14,18 @@ int main(int argc, char *argv[]) {
return 0; return 0;
} }
if (!FileHelper::FileExists(argv[1])) { if (!FileHelper::fileExists(argv[1])) {
cerr << "Filepath: " << argv[1] << " doesn't exist."; cerr << "Filepath: " << argv[1] << " doesn't exist.";
return 0; return 0;
} }
string file = FileReader::GetFile(argv[1]); string file = FileReader::getFile(argv[1]);
vector<int> rolls = NumberHelper::GetNumbers(file); vector<int> rolls = NumberHelper::getRolls(file);
PrintFrames::PrintHeader(rolls); PrintFrames::printHeader(rolls);
PrintFrames::PrintValue(rolls); PrintFrames::printValue(rolls);
int score = ScoreCalculator::GetScore(rolls); int score = ScoreCalculator::getScore(rolls);
cout << "Score: " << score << endl; cout << "Score: " << score << endl;
return 0; return 0;