#include "foreach.h"
/*
* Type: Direction
* ---------------
* This enumerated type is used to represent the four compass directions.
*/
enum Direction { NORTH, EAST, SOUTH, WEST };
/*
* Function: leftFrom
* Usage: Direction newdir = leftFrom(dir);
* ----------------------------------------
* Returns the direction that is to the left of the argument.
*/
Direction leftFrom(Direction dir);
/*
* Function: rightFrom
* Usage: Direction newdir = rightFrom(dir);
* -----------------------------------------
* Returns the direction that is to the right of the argument.
*/
Direction rightFrom(Direction dir);
/*
* Function: opposite
* Usage: Direction newdir = opposite(dir);
* ----------------------------------------
* Returns the direction that is opposite to the argument.
*/
Direction opposite(Direction dir);
/*
* Function: directionToString
* Usage: string str = directionToString(dir);
* -------------------------------------------
* Returns the name of the direction as a string.
*/
std::string directionToString(Direction dir);
/*
* Operator: <<
* Usage: os << dir;
* -----------------
* Overloads the << operator so that it is able
* to display Direction values.
*/
std::ostream & operator<<(std::ostream & os, const Direction & dir);
/*
* Operator: >>
* Usage: is >> dir;
* -----------------
* Overloads the >> operator so that it is able
* to read Direction values.
*/
std::istream & operator>>(std::istream & os, Direction & dir);
/*
* Operator: ++
* Usage: dir++
* ------------
* Overloads the suffix version of the ++ operator to
* work with Direction values. The sole purpose of this
* definition is to support the idiom
*
*
* for (Direction dir = NORTH; dir <= WEST; dir++) ...
*
*/
Direction operator++(Direction & dir, int);
#endif