The objective of this assignment is to implement a FP-inspired Tafl game.
Please consult the assignment specification for the game rules and submission's functional requirements.
The project build is managed using Cabal, which was introduced in Week 8 during lectures.
For more information for using Cabal please consult:
https://www.haskell.org/cabal/users-guide/index.html
Here we provide some quick instructions for how to build and test the project.
Please remember to update the Cabal file with your information, including any extra dependencies your project requires.
To initialise the project:
$ cabal configure --user
It is good practise to develop our projects in a sandbox. Fortunately, Cabal has this functionality built in.
We initialise the sandbox as follows:
$ cabal sandbox init
Then we install the project's specified dependencies into the sandbox:
$ cabal install --dependencies-only
If you add a dependency to your project, then please call this command again.
The sandbox can be destroyed using:
$ cabal sandbox delete
Once the project has been initialised we can use the following commands to interact with our project.
$ cabal build
This will generate an executable within a folder in .cabal-sandbox/...
. The precise path is determined by your version of GHC, Computer Architecture, and Cabal used.
$ cabal clean
To run all the black-box tests, this is the sequence I go through ...
$ cabal sandbox init
$ cabal install --only-dependencies
$ cabal install --only-dependences --enable-tests
$ cabal build
$ cabal install
$ cabal test
If you wish to install the game into your system, you can use the command:
$ cabal install
This will install the executable into Cabal's bin
directory.
On Linux/BSD machines this will be: $HOME/.caba/bin/
On Windows machines this will be %APPDATA%\cabal/bin/
For those using Git, GitHub publishes a useful .gitignore
file suitable for Haskell:
https://github.com/github/gitignore/blob/master/Haskell.gitignore
For those that use Mercurial, the same ignore file can be adapted for your Haskell project.