git @ Cat's Eye Technologies The-Platform / a7adad4
Begin developing 0.4 on a dedicated branch. Begin by editing README. Chris Pressey 7 years ago
1 changed file(s) with 45 addition(s) and 64 deletion(s). Raw diff Collapse all Expand all
22
33 Hey, if Haskell can have a Platform, why can't we? It's only fair.
44
5 The Cat's Eye Technologies Platform is a [NetBSD][]-based,
6 [toolshelf][]-powered, [Funicular][]-built "distro" containing almost all of
7 [Cat's Eye Technologies][]' software distributions. It is an anthology of
8 our work in a "stand-alone" format, a bootable disk image.
9
10 **If you want to download a pre-built disk image of The Platform**,
11 open this torrent in your torrent client:
12
13 * [The-Cats-Eye-Technologies-Platform-0.3.torrent][]
14
15 **If you already have a copy of the pre-built disk image**,
16 and you want to know how to use it, see this document:
17
18 * [USAGE.markdown](USAGE.markdown)
19
20 **If you wish to build a disk image of The Platform from source files**,
21 or if you simply want to know more about its internals, read on.
22
23 [The-Cats-Eye-Technologies-Platform-0.3.torrent]: https://raw.githubusercontent.com/catseye/The-Platform/master/torrent/The-Cats-Eye-Technologies-Platform-0.3.torrent
24
25 Motivation
26 ----------
27
28 If pressed, I could come up with a serious rationalization for this. Picking
29 a fixed version of an operating system means that, once the versions of the
30 supporting software and the versions of our software have been picked, it
31 will all build and work consistently (and, we can only hope, correctly.)
32 Since it is not intended to be connected to a network, the need for upgrades
33 due to security, hardware support, and "new hawtness" is diminished.
34
35 Or: establishing a platform is to bitrot what canning food is to spoilage.
36
37 It also provides answers to the question "What is a minimal set of software
38 that'd be needed to run almost everything from Cat's Eye Technologies?"
39
40 As I said, I *could* come up with a serious rationalization for this.
41 But mainly, it's fun. A certain awful flavour of fun, maybe, but still fun.
42
43 Version
44 -------
45
46 Each version of The Cat's Eye Technologies Platform can be thought of as a
47 "versionset" on a collection of software distributions, "frozen" at points
48 in their development where they are all mutually compatible.
5 This is version 0.4 of _The Cat's Eye Technologies Platform_, a
6 [NetBSD][]-based, [shelf][]-powered, [Funicular][]-built "distro"
7 containing almost all of [Cat's Eye Technologies][]' software
8 distributions. It is an anthology of our work in a "stand-alone"
9 format, a bootable disk image.
10
11 Version 0.4 is currently under development; no binary distribution
12 is available yet.
4913
5014 The current released version of The Cat's Eye Technologies Platform is
5115 version **0.3**. It can be built with Funicular version 0.3 and
5317 Its source code can be found at the tag `0.3` in the repository, for
5418 example [on Github here](https://github.com/catseye/The-Platform/tree/0.3).
5519
20 Background
21 ----------
22
23 Each version of The Cat's Eye Technologies Platform can be thought of as a
24 "versionset" on a collection of software distributions, "frozen" at points
25 in their development where they are all mutually compatible.
26
27 Picking a fixed version of an operating system means that, once the
28 versions of the supporting software and the versions of our software
29 have been picked, it will all build and work consistently (and, we
30 can only hope, correctly.)
31
32 Since it is not intended to be connected to a network, the need for upgrades
33 due to security, hardware support, and "new hawtness" is diminished.
34 Establishing a platform in this way is to bitrot what canning food is to
35 spoilage. It also answers the question "What is a minimal set of software
36 that'd be needed to run almost everything from Cat's Eye Technologies?"
37
5638 All of the pieces of software that make up The Platform are interoperable;
5739 that is, every piece builds successfully on NetBSD 6.1.5, and those with
5840 test suites pass all of their relevant automated tests. The pieces are
5941 not, however, thoroughly tested manually.
6042
61 Quick Start
62 -----------
63
64 You can download a pre-built disk image of The Platform via the torrent
65 link given above. Or, if you are on a Unix-like operating system, you
66 can build your own image from source by following the following steps.
67 Either way, the disk image is roughly 3.6G in size, so make sure you have
68 some free space.
69
70 * Install [Funicular][] 0.3 (via [toolshelf][], we would suggest,
43 Building
44 --------
45
46 If you are on a Unix-like operating system, you can build your own disk
47 image with the following steps. It is roughly 3.6G in size, so make sure
48 you have some free space.
49
50 * Install [Funicular][] 0.4 (via [shelf][], we would suggest,
7151 although this is not strictly necessary)
7252 * Put a copy of (or a symbolic link to) the
7353 [NetBSD 6.1.5](http://www.netbsd.org/releases/formal-6/NetBSD-6.1.5.html)
7757 by some other method.
7858 * In this repo's directory, run
7959
80 funicular init 3600
60 IMAGE_SIZE=3686400 funicular init system
8161 funicular install
62 funicular init setup
8263 funicular setup
8364
8465 and follow the instructions given to you at each step.
8566
8667 [NetBSD]: http://netbsd.org/
87 [toolshelf]: https://github.com/catseye/toolshelf/
68 [shelf]: https://github.com/catseye/shelf/
8869 [Funicular]: https://github.com/catseye/Funicular/
8970 [Cat's Eye Technologies]: http://catseye.tc/
71
72 *things below this line need review*
9073
9174 What's Included?
9275 ----------------
10083 `skel` directory for more accurate, machine-readable version numbers.
10184
10285 The Platform can be thought of as being constructed in stages, with each
103 stage building upon the previous. The first stage (the "NetBSD Gondola" stage,
104 although this is something of a misnomer now) consists of:
86 stage building upon the previous. The first stage consists of:
10587
10688 * NetBSD 6.1.5 (minimal install + compiler tools) ♡ + ♢
10789 * Lua 5.1.4 (note that this is already a part of NetBSD 6.1.5) ♡
90 * toolshelf 0.1-2016.0315 ♡
91
92 The second stage, "Infrastructure", consists of:
93
94 * GNU Make 3.82 ♢
10895 * cPython 2.7.8 ♦¹
109 * toolshelf 0.1-2016.0315 ♡
110
111 The second stage, "Infrastructure", consists of:
112
113 * GNU Make 3.82 ♢
114 * Mercurial 1.9.3 ♢
11596 * Perl 5.20.1 ♦²
11697 * Hugs98-plus Sep2006 ♡
11798 * Erlang/OTP R16B03-1 (stripped down, e.g. no megaco, etc.) ♦³