-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathREADME.txt
325 lines (220 loc) · 9.92 KB
/
README.txt
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
+=============================+
| `leopard.sh` and `tiger.sh` |
+=============================+
Package managers for PowerPC Macs running OS X Leopard (10.5) and Tiger (10.4),
written in Bash!
Github repo: https://github.com/cellularmitosis/leopard.sh
In a nutshell:
--------------
$ curl -O http://leopard.sh/leopard.sh
$ chmod +x leopard.sh
$ ./leopard.sh quake.app-1.1
$ open "/Applications/GLQuake 1.1"
or:
$ curl -O http://leopard.sh/tiger.sh
$ chmod +x tiger.sh
$ ./tiger.sh quake.app-1.1
$ open "/Applications/GLQuake 1.1"
Binary package support:
-----------------------
I build pre-compiled binary packages optimized for the following platforms:
+---------+-----+-----+-----+-------+-------+
| | G3 | G4 | G4e | G5/32 | G5/64 |
|---------|-----|-----|-----|-------|-------|
| Leopard | - | - | X | X | X |
|---------|-----|-----|-----|-------|-------|
| Tiger | X | X | X | X | X |
+---------+-----+-----+-----+-------+-------+
The above processors can be understood as the following gcc flags:
- G3: `-mcpu=750`
- G4: `-mcpu=7400`
- G4e: `-mcpu=7450`
- G5/32: `-mcpu=970 -m32`
- G5/64: `-mcpu=970 -m64`
Optimization flags used:
+---------+-----+-----+-----+-------+-------+
| | G3 | G4 | G4e | G5/32 | G5/64 |
|---------|-----|-----|-----|-------|-------|
| Leopard | | | -O2 | -O2 | -O2 |
|---------|-----|-----|-----|-------|-------|
| Tiger | -Os | -Os | -O2 | -O2 | -O2 |
+---------+-----+-----+-----+-------+-------+
Installation:
-------------
On your Mac, open up Terminal.app.
Download the `leopard.sh` Bash script:
$ curl -O http://leopard.sh/leopard.sh
or, for Tiger users:
$ curl -O http://leopard.sh/tiger.sh
Now make it executable:
$ chmod +x leopard.sh
Now run it:
$ ./leopard.sh
During the first run, some setup will be performed, e.g. creating /opt,
downloading a few dependencies, etc. You'll be prompted for your password,
because a few of these commands need root access.
Also, you'll be prompted to visit https://leopard.sh/md5 to verify that the
script wasn't tampered with during download. Because the version of Safari
which shipped with Leopard and Tiger doesn't support modern SSL, this step has
to be performed on either a modern PC or on your smartphone.
List the available packages:
----------------------------
Fetch the list of the available packages:
$ ./leopard.sh
Available packages:
adium.app-1.3.10
clisp-2.39.20210628
coreutils-9.0
gcc-4.9.4
gettext-0.20
gmp-4.3.2
gzip-1.11
handbrake.app-0.9.1
...
These names, e.g. `gzip-1.11` are called "pkgspecs".
You'll also notice that there are two kinds of pkgspecs supported:
- Unix software, e.g. gzip-1.11
- Mac applications, e.g. adium.app-1.3.10
Note that the pkgspecs are printed to stdout, while the "Available packages:"
header is printed to stderr. This means we can pipe `leopard.sh` into `grep`:
$ leopard.sh | grep gzip
Available packages:
gzip-1.11
We could also use `grep` to list just the Mac applications:
$ leopard.sh | grep .app
Available packages:
adium.app-1.3.10
chicken.app-2.2b2
clozure-cl.app-1.4
handbrake.app-0.9.1
interwebppc.app-rr1
quake.app-1.1
textwrangler.app-3.1
vlc.app-0.9.10
xbench.app-1.3
...
The Unix geeks will note that technically we should grep for '\.app', not .app.
Install a package:
------------------
To install a package, call `leopard.sh` with a pkgspec:
$ leopard.sh gzip-1.11
Note: currently, you have to use the full pkgspec, i.e. you can't do something
like "leopard.sh gzip". I'll implement some sort of pkgspec aliases soon, but
in the mean time you could use a subshell as a work-around:
$ leopard.sh $(leopard.sh | grep gzip)
The above command will fetch and run
http://leopard.sh/leopardsh/scripts/install-gzip-1.11.sh.
That script will look for a pre-compiled binary package (a "binpkg") which
matches your CPU type, e.g. a Mac with a G5 would try to fetch
https://leopard.sh/leopardsh/binpkgs/gzip-1.11.leopard.g5.tar.gz and unpack it
into /opt/gzip-1.11, and create symlinks in /usr/local/bin.
If for some reason a binpkg is unavailable, the script will instead attempt to
compile gzip-1.11 from source. (However, I currently build binpkgs for every
supported OS / CPU combo, so I'm the only one who will ever see this step).
Some pkgspecs depend on other pkgspecs, i.e.
https://leopard.sh/leopardsh/scripts/install-gcc-4.9.4.sh
In that case, the script will call `leopard.sh` to install each of its
dependencies, and so on, recursively.
Remove a package:
-----------------
To remove a package, first clean up its symlinks from `/usr/local/bin`:
$ leopard.sh --unlink gzip-1.11
and then delete it from `/opt`:
$ rm -rf /opt/gzip-1.11
That's right: you remove packages from `/opt` manually. Note that `leopard.sh`
does not maintain any sort of database or state tracking about what's currently
installed (it simply checks if /opt/foo-1.0 exists), so in general you are
free to muck with /opt in any way you see fit. That is, `leopard.sh` does not
*own* /opt, it is a *citizen* of /opt.
If you had previously unlinked a package but hadn't actually deleted it, and
now you'd like to re-link it, just run:
$ leopard.sh --link gzip-1.11
Project goals:
--------------
- Performance
It should be snappier than homebrew, even on a slow G3.
- Full binary package availability.
Every pkgspec should have a pre-compiled binary package available for every
OS / CPU combo. Users should never wait on compilation.
- Simplicity / hackability / conceptual flatness.
The problem with most package managers is that they have a very steep learning
curve for contributing / hacking.
`leopard.sh` and `tiger.sh` will take the opposite approach: the installation
of a package shall be encompassed entirely by two Bash scripts:
- the orchestrator script: `leopard.sh` or `tiger.sh`
- the package-specific script: e.g. `install-gzip-1.11.sh`
`leopard.sh` and `tiger.sh` are spritual brethren to the 'Linux From Scratch'
project (see https://www.linuxfromscratch.org/).
Would you like to hack on some of the installer scripts yourself? It is as
simple as:
$ cd
$ curl -L https://github.com/cellularmitosis/leopard.sh/archive/refs/heads/main.tar.gz | gunzip | tar x
$ export LEOPARDSH_MIRROR=file://$HOME/leopard.sh-main
$ # or, for tiger:
$ export TIGERSH_MIRROR=file://$HOME/leopard.sh-main
Bam, you're now running entirely from your self-contained copy of the project.
In fact, as long as you drop any needed source tarballs into `~/Downloads`
before running `leopard.sh`, you're now also completely offline-capable.
Project non-goals:
------------------
- Supporting Intel Macs ;p
Other options:
--------------
If `leopard.sh` and `tiger.sh` aren't for you, checkout these other package managers:
- MacPorts: https://www.macports.org/
- Tigerbrew: https://github.com/mistydemeo/tigerbrew
- Fink: https://www.finkproject.org/ (looks like they only support 10.6 and up these days)
Mirroring
---------
The http://leopard.sh server now runs rsyncd!
List the available directories via:
rsync leopard.sh::
The only exposed directory is 'html' (as in '/var/www/html'), so you can create
a mirror via:
rsync -av leopard.sh::html .
But in practice this would look something more like:
rsync -av --delete leopard.sh::html /var/www/html/mirrors/leopard.sh/
Support for mirrors which force HTTPS
-------------------------------------
Where appropriate, leopard.sh will use plain-HTTP URLs for a small performance
boost (or in the case of a slow G3, not so small!).
However, some mirrors automatically redirect all plain-HTTP traffic to HTTPS.
This defeats the point of using plain-HTTP, as you not only suffer the
performance hit of using HTTPS, but on top of that an additional redirect from
HTTP to HTTPS. It would have been better to use HTTPS to begin with!
In this case, you can 'export LEOPARDSH_MIRROR_NO_HTTP=1' (or 'export TIGERSH_MIRROR_NO_HTTP=1')
to inform leopard.sh that it should not use plain-HTTP URLs.
Note that if you set LEOPARDSH_MIRROR_NO_HTTP and use an HTTPS-only mirror when
intially installing `leopard.sh`, it will be unable to download download its
dependencies, as /usr/bin/curl does not support modern HTTPS.
In this case, you can download https://leopard.sh/binpkgs/tigersh-deps-0.1.tiger.g3.tar.gz
using another computer, then place it in /tmp and run leopard.sh again.
### Support for mirrors which don't allow HEAD
The HTTP HEAD operation can be used to fetch only the HTTP headers without
downloading the contents of the URL.
leopard.sh uses HEAD to fetch the Content-Length of files before downloading
them, and hands that size to 'pv' to make its progress bar more informative.
However, some mirrors do not support the HEAD operation, causing spurious
failures.
In this case, you can 'export LEOPARDSH_MIRROR_NO_HEAD=1' (or 'export TIGERSH_MIRROR_NO_HEAD=1')
to inform leopard.sh that it should not attempt to fetch the size of files before downloading them.
Useful links for OS X PowerPC users:
------------------------------------
- 'Last versions of applications for Mac OS X on PowerPC' http://matejhorvat.si/en/mac/osxppcsw/
- 'The Tiger Thread (Mac OS X 10.4)' https://forums.macrumors.com/threads/the-tiger-thread-mac-os-x-10-4.2134451/
- 'The Leopard Thread' https://forums.macrumors.com/threads/the-leopard-thread.2120703/
- FrogFind! http://frogfind.com/
- https://video.2yxa.mobi/ (YouTube transcoding proxy)
Vintage Mac content:
--------------------
- https://www.youtube.com/@ActionRetro
- https://www.youtube.com/@ThisDoesNotCompute
- https://www.youtube.com/@65scribe
- https://www.youtube.com/@ItsMyNaturalColour
- https://www.youtube.com/@MacintoshLibrarian
- https://www.youtube.com/@Mac84
- https://www.youtube.com/@ComputerClan
- https://www.youtube.com/@HrutkayMods
- https://www.youtube.com/@Druaga1
- https://www.youtube.com/@themacintoshmuseum
- https://www.reddit.com/r/VintageApple