Resource gathering + programming game
Go to file
Brent Yorgey fb7d2eaeb9
0.4 release blog post (#1444)
Blog post highlighting cool features in the newest release.

Also fix the version number in the .cabal file from 0.4 to 0.4.0.0. It's too late for the release (it always reports there is a new version available since 0.4.0.0 does not match 0.4) but oh well.
2023-08-22 12:35:05 -05:00
.github Update to support GHC 9.6, mtl-2.3, and bump upper bounds (#1363) 2023-07-11 19:05:14 -05:00
app CLI option to set initial speed (#1255) 2023-05-14 04:00:14 +00:00
bench World description DSL (#1376) 2023-08-17 11:08:42 +00:00
data combustion (#1432) 2023-08-21 02:23:52 +00:00
docs/blog 0.4 release blog post (#1444) 2023-08-22 12:35:05 -05:00
editors combustion (#1432) 2023-08-21 02:23:52 +00:00
example Key input handler (#1214) 2023-04-25 16:39:59 +00:00
images 0.4 release blog post (#1444) 2023-08-22 12:35:05 -05:00
scripts Render markdown in entity descriptions (#1413) 2023-08-12 11:42:12 +00:00
src various documentation improvements (#1439) 2023-08-21 19:55:26 +00:00
test combustion (#1432) 2023-08-21 02:23:52 +00:00
.gitignore Boolean expressions of objective prerequisites (#927) 2023-01-25 04:07:00 +00:00
.hlint.yaml prefer dots over dollars (#1190) 2023-04-02 20:24:03 +00:00
.mergify.yml Update to support GHC 9.6, mtl-2.3, and bump upper bounds (#1363) 2023-07-11 19:05:14 -05:00
.restyled.yaml Fourmolu fixup (#1326) 2023-07-12 18:00:23 +00:00
.stan.toml exclude some stan observations 2021-09-15 06:39:21 -05:00
cabal.haskell-ci Update to support GHC 9.6, mtl-2.3, and bump upper bounds (#1363) 2023-07-11 19:05:14 -05:00
CHANGELOG.md 0.4 release (#1321) 2023-08-18 02:35:43 +00:00
CODE_OF_CONDUCT.md Adopt the Contributor Covenant Code of Conduct 2021-09-19 13:38:33 -05:00
COMMUNITY.md some updates to README and COMMUNITY 2022-10-05 17:52:52 -05:00
CONTRIBUTING.md Fourmolu fixup (#1326) 2023-07-12 18:00:23 +00:00
DESIGN.md More minor edits (#693) 2022-09-18 12:04:33 +00:00
feedback.yaml Records (#1148) 2023-03-25 11:58:34 +00:00
fourmolu.yaml World description DSL (#1376) 2023-08-17 11:08:42 +00:00
hie.yaml.stack Add cabal to HLS configuration (#131) 2021-10-03 21:14:04 +00:00
LICENSE Update editors (#581) 2022-07-25 00:16:23 +02:00
NOTICE Use a new opaque type for robots instead of strings (#303) 2022-03-02 03:00:44 +00:00
pull_request_template.md Add a pull request template (#1434) 2023-08-20 19:43:27 +00:00
README.md add note to installation section warning about #1000 (#1161) 2023-03-17 08:22:59 +00:00
scenarios Documentation for scenario file format (#612) 2022-07-30 08:02:11 -04:00
stack.yaml Update to LTS-21, GHC 9.4.5, brick-1.9 (#1351) 2023-06-26 17:51:52 +00:00
swarm.cabal 0.4 release blog post (#1444) 2023-08-22 12:35:05 -05:00

Swarm

Build Status GitHub release (latest by date) Swarm release on Hackage Contributor Covenant ircchat GitHub Contributors

Swarm is a 2D programming and resource gathering game. Program your robots to explore the world and collect resources, which in turn allows you to build upgraded robots that can run more interesting and complex programs. Check out the installation instructions below, join the IRC channel, take a look at the wiki, or see how you can contribute!

World 0 after scanning a tree and making a log.

Features include:

  • Practically infinite 2D procedurally generated worlds
  • Simple yet powerful programming language based on the polymorphic lambda calculus + recursion, with a command monad for describing first-class imperative actions
  • Editor support with LSP and highlighting
  • In-game tutorial
  • Multiple game modes:
    • In Classic mode, you start with the ability to produce only very basic, limited robots; collecting resources allows you to bootstrap your way into programming more sophisticated robots that can explore more of the world, collect more resources, etc.
    • Creative mode places no restrictions: program robots to your heart's content using whatever language features you want, without worrying about collecting resources.
    • There are also challenge scenarios where you attempt to program robots in order to solve pre-designed puzzles or challenges.

Installing

NOTE: Compiling Swarm with GHC 9.2.5 and optimizations enabled seems to result in very long freezes/delays (tens of seconds) when starting Swarm (see #1000). We recommend either building Swarm with a different version of GHC (e.g. 9.4.x), or building with optimizations turned off (which does not seem to affect the game performance very much).

NOTE: Swarm requires a POSIX-style terminal environment that supports terminfo. Linux and MacOS should work out of the box. On Windows, you will need to use Windows Subsystem for Linux; you should then be able to follow instructions for installing on Linux.

It is recommended that you use a relatively large terminal window (e.g. 170 columns x 40 rows or larger). To find out the size of your terminal, you can type stty size at a command prompt. If it's not big enough, try decreasing the font size. You can read about and/or share recommended terminal settings in this GitHub issue.

Installing via binaries

Currently we have one binary release built on Ubuntu Bionic; it will probably work on any GNU/Linux. We hope to add MacOS binaries in the near future.

You can download the swarm binary and compressed data directory from the latest release. If you want to run the binary simply as swarm, you have to put it in one of the directories in your PATH:

chmod +x ./swarm          # make it executable
echo $PATH | tr ':' '\n'  # choose one of the listed directories
mv ./swarm /my/chosen/bin/directory/

You will also need to extract the data to your local Swarm folder so the executable can find it:

mkdir -p ~/.local/share/swarm/
unzip swarm-data.zip -d ~/.local/share/swarm

Installing from Hackage

If you can't use the provided binaries, or prefer installing from Hackage, you should be able to install with

cabal install swarm

If you don't already have the cabal tool, first install ghcup, then run ghcup install cabal (if cabal was not automatically downloaded as part of ghcup's installation).

You may need to add ~/.cabal/bin to your PATH; alternatively, you can install with cabal install --installdir=<DIR> swarm to have cabal install the swarm executable in a <DIR> of your choosing.

Installing from source

If you want the latest unreleased bleeding-edge features, or want to contribute to Swarm development, you can build from source.

  1. Clone the Swarm repository, e.g.

    git clone https://github.com/swarm-game/swarm.git
    
  2. If you don't already have the stack tool:

    1. Get the ghcup tool, a handy one-stop utility for managing all the different pieces of a Haskell toolchain.

    2. Use ghcup to install stack:

      ghcup install stack
      
  3. Now use stack to build and run Swarm:

    cd /path/to/the/swarm/repo
    stack run
    
  4. Go get a snack while stack downloads a Haskell compiler and all of Swarm's dependencies.

Configuring your editor

Although you can write commands and definitions directly in the Swarm REPL, once you get beyond the basics you'll probably want to use an external editor for writing Swarm programs. Swarm has support for external editors with highlighting and LSP integration:

Editor with problem popup

See the editors folder for details on how to configure your editor. Currently, emacs and VS Code are officially supported, but more can be added.

Community

Check out the COMMUNITY page for ways to connect with others in the community.

If you want to contribute, you're most welcome! There are lots of ways to contribute, regardless of your Haskell background. For example, even someone with no Haskell experience whatsoever could still help with e.g. game design, playtesting, and creating challenges and scenarios. Check out the CONTRIBUTING file for more specific information about how to contribute.