Completely separated all parser code into Parser.cpp and Parser.h.

This commit is contained in:
Alexander Huddleston 2015-11-03 15:12:29 -06:00
parent 68f3b9514a
commit c807d75e14
9 changed files with 191 additions and 119 deletions

108
Board.cpp
View file

@ -123,36 +123,6 @@ vector<Piece*> Board::getTypePieces(char type) const{
return pieces; return pieces;
} }
} }
moves Board::parse(string input){
input = myToUpper(input);
int temp1;
int temp2;
string temp3;
temp2 = input[0] - 'A';
temp1 = input[1] - '0';
if (input[3] == 'L')
{
temp3 = "LEFT";
}
else if (input[3] == 'R')
{
temp3 = "RIGHT";
}
else
{
temp3 = "FWD";
}
moves output(temp1, temp2, temp3);
return output;
}
bool Board::isGameOver(){ bool Board::isGameOver(){
for (int i = 0; i < xpieces.size(); ++i){ for (int i = 0; i < xpieces.size(); ++i){
@ -247,53 +217,12 @@ string Board::boardToString(){
return output; return output;
} }
int Board::charToIntColumn(char input){
int kolumn;
switch (input)
{
case 'A': kolumn = 0; break;
case 'B': kolumn = 1; break;
case 'C': kolumn = 2; break;
case 'D': kolumn = 3; break;
case 'E': kolumn = 4; break;
case 'F': kolumn = 5; break;
case 'G': kolumn = 6; break;
case 'H': kolumn = 7; break;
}
return kolumn;
}
char Board::intToCharColumn(int input){
char kolumn;
switch (input)
{
case 1: kolumn = 'A'; break;
case 2: kolumn = 'B'; break;
case 3: kolumn = 'C'; break;
case 4: kolumn = 'D'; break;
case 5: kolumn = 'E'; break;
case 6: kolumn = 'F'; break;
case 7: kolumn = 'G'; break;
case 8: kolumn = 'H'; break;
}
return kolumn;
}
void Board::move(string inputMove){
moves m = parse(inputMove);
move(m);
}
Board Board::move(moves m){ Board Board::move(moves m){
int row = 8 - (m.row); int row = m.row;
int column = m.column; int column = m.column;
//cout << "INSIDE MOVE: " << row << " " << column << " " << m.moveType << "\n\n"; cout << "INSIDE MOVE: " << row << " " << column << " " << m.moveType << "\n\n";
if (row > 8 || row < 0 || column > 8 || column < 0) { if (row > 8 || row < 0 || column > 8 || column < 0) {
cout<<"ERROR: index out of bound."<<endl; cout<<"ERROR: index out of bound."<<endl;
@ -461,19 +390,19 @@ vector<moves> Board::viewPossibleMoves(){
c = xpieces[i]->getY(); c = xpieces[i]->getY();
if (isThisMovePossible(r, c, "FWD")) if (isThisMovePossible(r, c, "FWD"))
{ {
moves temp(8-r,c, "FWD"); moves temp(r,c, "FWD");
output.push_back(temp); output.push_back(temp);
} }
if (isThisMovePossible(r,c,"LEFT")) if (isThisMovePossible(r,c,"LEFT"))
{ {
moves temp(8-r,c, "LEFT"); moves temp(r,c, "LEFT");
output.push_back(temp); output.push_back(temp);
} }
if (isThisMovePossible(r,c,"RIGHT")) if (isThisMovePossible(r,c,"RIGHT"))
{ {
moves temp(8-r,c, "RIGHT"); moves temp(r,c, "RIGHT");
output.push_back(temp); output.push_back(temp);
} }
} }
@ -485,19 +414,19 @@ vector<moves> Board::viewPossibleMoves(){
c = opieces[i]->getY(); c = opieces[i]->getY();
if (isThisMovePossible(r, c, "FWD")) if (isThisMovePossible(r, c, "FWD"))
{ {
moves temp(8-r,c, "FWD"); moves temp(r,c, "FWD");
output.push_back(temp); output.push_back(temp);
} }
if (isThisMovePossible(r,c,"LEFT")) if (isThisMovePossible(r,c,"LEFT"))
{ {
moves temp(8-r,c, "LEFT"); moves temp(r,c, "LEFT");
output.push_back(temp); output.push_back(temp);
} }
if (isThisMovePossible(r,c,"RIGHT")) if (isThisMovePossible(r,c,"RIGHT"))
{ {
moves temp(8-r,c, "RIGHT"); moves temp(r,c, "RIGHT");
output.push_back(temp); output.push_back(temp);
} }
} }
@ -542,27 +471,6 @@ void Board::undo(Board& tablero){
} }
} }
void Board::interpret(string input, Board& tablero){
vector<Board> record;
input = myToUpper(input);
if (input == "UNDO"){
cout << "TEST";
undo(tablero);
}
else if (input == "DISPLAYRECORD"){
cout<<"record: "<<endl;
cout<<record.size();
for (int i = 0; i < record.size(); ++i){
record[i].displayBoard();
}
}
else tablero.move(input);
}
void Board::snapshot(vector<Board>& inputVec, Board inputBoard){ void Board::snapshot(vector<Board>& inputVec, Board inputBoard){
if (inputVec.size() == 10){ if (inputVec.size() == 10){
inputVec.erase(inputVec.begin()); inputVec.erase(inputVec.begin());

View file

@ -44,22 +44,17 @@ public:
vector<Piece*> getPieces() const { return pieces; } vector<Piece*> getPieces() const { return pieces; }
vector<Piece*> getTypePieces(char type) const; vector<Piece*> getTypePieces(char type) const;
char getTurn() const { return turn; } char getTurn() const { return turn; }
moves parse(string input);
bool isGameOver(); bool isGameOver();
char whoWon(); char whoWon();
void changeTurns(); void changeTurns();
void resetTaken(); void resetTaken();
void displayBoard(); void displayBoard();
string boardToString(); string boardToString();
int charToIntColumn(char input);
char intToCharColumn(int input);
void move(string inputMove);
Board move(moves m); Board move(moves m);
bool isThisMovePossible(int r, int c, string moveType); bool isThisMovePossible(int r, int c, string moveType);
vector<moves> viewPossibleMoves(); vector<moves> viewPossibleMoves();
string myToUpper(string input); string myToUpper(string input);
void undo(Board& tablero); void undo(Board& tablero);
void interpret(string input, Board& tablero);
void snapshot(vector<Board>& inputVec, Board inputBoard); void snapshot(vector<Board>& inputVec, Board inputBoard);
int evaluate(char max, char min); int evaluate(char max, char min);
}; };

View file

@ -246,6 +246,33 @@ public class Client {
boardoutput += "" + r + "" + c; boardoutput += "" + r + "" + c;
} }
public static String parseOutput(String move) {
String output = "";
int tempa = move.charAt(0) - '0';
int tempb = move.charAt(1) - '0';
int tempc = move.charAt(2) - '0';
int tempd = move.charAt(3) - '0';
if(tempa == (tempc + 1)) {
//cout << "\nTest\n";
if(tempb == tempd) {
output = ((char)('A' + tempb)) + "" + (8 - tempa) + " FWD";
}
else if(tempb == (tempd + 1)) {
output = ((char)('A' + tempb)) + "" + (8 - tempa) + " LEFT";
}
else if(tempb == (tempd - 1)) {
output = ((char)('A' + tempb)) + "" + (8 - tempa) + " RIGHT";
}
}
else {
return "Invalid";
}
//Debugging
System.out.println("Output: " + output);
return output;
}
public static void main (String[] args) throws InterruptedException { public static void main (String[] args) throws InterruptedException {
Scanner keyboard = new Scanner(System.in); Scanner keyboard = new Scanner(System.in);
String hostname = args[0]; String hostname = args[0];
@ -299,6 +326,7 @@ public class Client {
} }
} }
output.println(userInput); output.println(userInput);
String out = "";
while(!end) { while(!end) {
char[] buffer = new char[256]; char[] buffer = new char[256];
@ -318,9 +346,17 @@ public class Client {
output.flush(); output.flush();
undoString = ""; undoString = "";
} }
if(boardoutput.length() == 4) {
out = parseOutput(boardoutput);
if(out == "Invalid") {
out = "";
boardoutput = "";
System.out.println("Invalid move.");
}
}
} }
System.out.println(boardoutput); System.out.println(out);
output.println(boardoutput); output.println(out);
output.flush(); output.flush();
boardoutput = ""; boardoutput = "";
} }

View file

@ -45,16 +45,19 @@ void Engine::userGame(int difficulty){
bool gameOver = false; bool gameOver = false;
vector<Board> record; vector<Board> record;
b->snapshot(record, *b); b->snapshot(record, *b);
cin.ignore();
cin.clear();
while (gameOver != true){ while (gameOver != true){
gameOver = b->isGameOver(); gameOver = b->isGameOver();
while(b->getTurn() == 'O' && !b->isValid()){ while(b->getTurn() == 'O' && !b->isValid()){
b->displayBoard(); b->displayBoard();
cout<<"\nEnter command: "; cout<<"\nEnter command: ";
cin>>move; cin.clear();
getline(cin, move);
cout << "\n"; cout << "\n";
b->interpret(move, *b); parse(move, *b);
if(b->isValid()){ if(b->isValid()){
b->changeTurns(); b->changeTurns();
@ -138,8 +141,8 @@ void Engine::createMMTree(MNode* node, int depth, int alt){
if (depth >= 0){ if (depth >= 0){
for (int i = 0; i < listOfMoves.size(); ++i){ for (int i = 0; i < listOfMoves.size(); ++i){
if(current.getPiece(8 - listOfMoves[i].row, listOfMoves[i].column)->getType() == if(current.getPiece(listOfMoves[i].row, listOfMoves[i].column)->getType() ==
current.getTurn() && current.isThisMovePossible(8 - listOfMoves[i].row, current.getTurn() && current.isThisMovePossible(listOfMoves[i].row,
listOfMoves[i].column, listOfMoves[i].column,
listOfMoves[i].moveType)){ listOfMoves[i].moveType)){
if (cond){ if (cond){

View file

@ -2,6 +2,7 @@
#include "Board.h" #include "Board.h"
#include "MNode.h" #include "MNode.h"
#include "Parser.h"
using namespace std; using namespace std;

116
Parser.cpp Executable file
View file

@ -0,0 +1,116 @@
/* A more robust parser for the game. */
#include <string>
#include <iostream>
#include <sstream>
#include <stdlib.h>
#include <unistd.h>
#include <vector>
#include "Parser.h"
using namespace std;
string myToUpper(string input) {
string output;
for (int i = 0 ; i < input.size(); ++i)
{
int numeric;
if ((input[i] - 0 >= 97) && (input[i] - 0 <= 122))
{
numeric = input[i] - 32;
output.push_back((char)numeric);
}
else output.push_back(input[i]);
}
return output;
}
void parseMove(vector<string> tokens, Board& board) {
//Debugging
cout << "Piece at: " << tokens[0] << " Move: " << tokens[1] << "\n\n";
int col;
int row;
if(tokens[0].size() == 2) {
if(tokens[1].size() >= 3 && tokens[1].size() <= 5) {
if(tokens[0][0] - 'A' < 0 || tokens[0][0] - 'A' > 7) {
cout << "Error. Invalid move location. (1st coord.)\n\n";
cout << tokens[0][0] << " " << (tokens[0][0] - 'A') << "\n\n";
return;
}
else if(tokens[0][1] - '0' < 0 || tokens[0][1] - '0' > 7) {
cout << "Error. Invalid move location. (1st coord.)\n\n";
return;
}
else {
col = tokens[0][0] - 'A';
row = 8 - (tokens[0][1] - '0');
cout << "row: " << row << "col: " << col << "\n\n";
}
if(tokens[1] == "LEFT" || tokens[1] == "RIGHT" || tokens[1] == "FWD") {
moves m(row, col, tokens[1]);
board.move(m);
}
else {
cout << "Error. Invalid moveType. (type)\n\n";
return;
}
}
else {
cout << "Error. Invalid moveType. (size)\n\n";
return;
}
}
else {
cout << "Error. Invalid move location. (size)\n\n";
return;
}
}
void parseCmd(vector<string> tokens, Board& board) {
if(tokens[0] == "UNDO") {
//Debugging
cout << "Testing UNDO.\n\n";
//Change when you fix undo.
board.undo(board);
}
else if(tokens[0] == "DISPLAYRECORD") {
//Debugging
cout << "Testing DISPLAYRECORD.\n\n";
/*Fix record, uncomment this.
cout << "recordsize: " << board->getRecord.size();
for(int i = 0; i < record.size(); ++i) {
record[i].displayBoard();
}
*/
}
else {
parseMove(tokens, board);
}
}
void parse(string in, Board& board) {
string input = myToUpper(in);
stringstream ss(input);
vector<string> tokens;
string temp;
while(ss >> temp) {
tokens.push_back(temp);
cout << temp << "\n";
}
//Debugging
//
for(int i = 0; i < tokens.size(); ++i) {
cout << "tokens[i]: " << tokens[i] << "\n";
}
//
parseCmd(tokens, board);
}

11
Parser.h Executable file
View file

@ -0,0 +1,11 @@
#pragma once
#include "Engine.h"
#include "Board.h"
//using namespace std;
string myToUpper(string input);
void parseMove(vector<string> tokens, Board& board);
void parseCmd(vector<string> tokens, Board& board);
void parse(string input, Board& board);

View file

@ -19,6 +19,7 @@ void error(const char *msg)
perror(msg); perror(msg);
exit(1); exit(1);
} }
/*
string tempParse(string move) { string tempParse(string move) {
string output = ""; string output = "";
int tempa = move[0] - '0'; int tempa = move[0] - '0';
@ -55,6 +56,7 @@ string tempParse(string move) {
cout << "Debugging: " << output << "\n\n"; cout << "Debugging: " << output << "\n\n";
return output; return output;
} }
*/
int main(int argc, char *argv[]) int main(int argc, char *argv[])
{ {
@ -147,8 +149,8 @@ int main(int argc, char *argv[])
move = buffer; move = buffer;
bzero(buffer,256); bzero(buffer,256);
//cout << move << "\n\n"; //cout << move << "\n\n";
move = tempParse(move); //move = tempParse(move);
e.getBoard()->interpret(move,(*e.getBoard())); parse(move,(*e.getBoard()));
if(e.getBoard()->isValid()) { if(e.getBoard()->isValid()) {
e.getBoard()->changeTurns(); e.getBoard()->changeTurns();

View file

@ -3,16 +3,16 @@
all: test server Client.class all: test server Client.class
server: Server.o server: Server.o
g++ -std=c++11 -o server Server.o Engine.o Piece.o Board.o MNode.o g++ -std=c++11 -o server Server.o Engine.o Piece.o Board.o MNode.o Parser.o
Server.o: Server.cpp Engine.cpp Board.cpp Piece.cpp MNode.cpp Server.o: Server.cpp Engine.cpp Board.cpp Piece.cpp MNode.cpp Parser.cpp
g++ -std=c++11 -c -g Server.cpp Engine.cpp Board.cpp Piece.cpp MNode.cpp g++ -std=c++11 -c -g Server.cpp Engine.cpp Board.cpp Piece.cpp MNode.cpp Parser.cpp
test: test.o test: test.o
g++ -std=c++11 -o test test.o Engine.o Piece.o Board.o MNode.o g++ -std=c++11 -o test test.o Engine.o Piece.o Board.o MNode.o Parser.o
test.o: test.cpp Engine.cpp Board.cpp Piece.cpp MNode.cpp test.o: test.cpp Engine.cpp Board.cpp Piece.cpp MNode.cpp
g++ -std=c++11 -c -g test.cpp Engine.cpp Board.cpp Piece.cpp MNode.cpp g++ -std=c++11 -c -g test.cpp Engine.cpp Board.cpp Piece.cpp MNode.cpp Parser.cpp
Client.class: Client.java Client.class: Client.java
javac -g Client.java javac -g Client.java