Getting Started with Haskell and Cabal
======================================
Installing the Haskell toolchain
--------------------------------
To install the Haskell toolchain follow the `ghcup instructions
`__ if you're using Linux or Mac, or follow
`this guide `__ if you're
using Windows.
Creating a new application
--------------------------
Let's start by creating a simple Haskell application from scratch where we'll
learn about a Haskell package's directory structure, how to run the executable,
and how to add external dependencies.
Initializing the application
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Start by creating a ``myfirstapp`` directory to hold the project files, these
instructions work in unix shells and PowerShell (if you're on Windows).
.. code-block:: console
$ mkdir myfirstapp
$ cd myfirstapp
Once you have an empty directory we can initialize our package:
.. code-block:: console
$ cabal init --cabal-version=2.4 --license=NONE -p myfirstapp
This will generate the following files:
.. code-block:: console
$ ls
CHANGELOG.md
Main.hs
myfirstapp.cabal
Setup.hs
``Main.hs`` is where your package's code lives. By default ``cabal init``
creates an executable with the same name as the package ``myfirstapp`` in this
case, you can instruct ``cabal init`` to generate just a library (with
``--lib``) or both a library and executable with (``--libandexe``); for the full
set of options see ``cabal init --help``.
``myfirstapp.cabal`` is Cabal's metadata file which describes your package and
its dependencies. We'll be updating this file in a little bit when we add an
external dependency to our package.
Running the application
^^^^^^^^^^^^^^^^^^^^^^^
As mentioned above, ``cabal init`` with no arguments generates a package with a
single executable that prints ``"Hello, Haskell!"`` to the terminal. To run the
executable enter the following command:
``cabal run :myfirstapp``
You should see the following output in the terminal:
.. code-block:: console
$ cabal run :myfirstapp
...
Hello, Haskell!
.. note:: The ``:`` prefix in ``:myfirstapp`` signifies that the
``myfirstapp`` target is part of the current package.
Notice that we didn't need to run a `build` command before ``cabal run``, this
is because ``cabal run`` first determines if the code needs to be re-built
before running the executable. If you just want to build a target you can do so
with ``cabal build``:
``cabal build :myfirstapp``
Adding dependencies
^^^^^^^^^^^^^^^^^^^
Next we'll add an external dependency to our application. `Hackage
`__ is the Haskell community's central `package`
archive of open source software.
In our application, we'll use a package called `haskell-say
`__ to print text to the
terminal with some embellishment.
.. TIP::
If you installed ``cabal`` a while ago but haven't used it recently you may
need to update the package index, you can do this by running ``cabal
update``.
In our ``myfirstapp.cabal`` file we'll update the ``build-depends`` attribute of
the ``executable myfirstapp`` section to include ``haskell-say``:
.. code-block:: cabal
executable myfirstapp
main-is: Main.hs
build-depends:
base >=4.11 && <4.12,
haskell-say ^>=1.0.0.0
.. NOTE::
``^>=1.0.0.0`` means use version 1.0.0.0 of the library or any more recent
minor release with the same major version.
Next we'll update ``Main.hs`` to use the ``HaskellSay`` library:
.. code-block:: haskell
module Main where
import HaskellSay (haskellSay)
main :: IO ()
main =
haskellSay "Hello, Haskell! You're using a function from another package!"
``import HaskellSay (haskellSay)`` brings the ``haskellSay`` function from the
module named ``HaskellSay`` into scope. The ``HaskellSay`` module is defined in
the ``haskell-say`` packages that we added a dependency on above.
Now you can build and re-run your code to see the new output:
.. code-block:: console
$ cabal run
________________________________________________________
/ \
| Hello, Haskell! You're using a function from another |
| package! |
\____ _____________________________________________/
\ /
\ /
\/
_____ _____
\ \ \ \
\ \ \ \
\ \ \ \
\ \ \ \ \-----------|
\ \ \ \ \ |
\ \ \ \ \---------|
/ / / \
/ / / \ \-------|
/ / / ^ \ \ |
/ / / / \ \ \ ----|
/ / / / \ \
/____/ /____/ \____\
What Next?
----------
Now that you know how to set up a simple Haskell package using Cabal, check out
some of thee resources on the Haskell website's `documentation page
`__ or read more about packages and
Cabal on the `introduction `__ page.