File: README.md

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (28 lines) | stat: -rw-r--r-- 964 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
# Game Of Life

Conway's "Game of Life", implemented as a build system.

This is an example of how llbuild can be used to perform arbitrary computations.

## Usage

To run the example, run:

```shell
$ swift run
```

This will display a sequence of Game of Life frames in the console. You can
adjust the starting state by modifying
[`Sources/game-of-life/main.swift`](Sources/game-of-life/main.swift).

The animation is created by asking llbuild to "build" each frame. The frame
itself is built by expressing a dependency on each cell in the frame, and each
cell depends on the adjacent neighbors from the previous frame.

This is not an efficient way to compute the Game of Life, but it *is* an easy
way to visualize moderately large build graphs.

This approach also allows some interesting techniques; for example, you can
easily change it to print the frames in reverse order, something a traditional
stateful Game of Life simulation wouldn't naively support.