10 Commits

Author SHA1 Message Date
T. Joseph Carter
1836b18c34 Support finally for Linux! 2015-11-09 04:56:20 -08:00
T. Joseph Carter
819e19f6d3 .endsWith -> .endswith 2015-11-09 04:54:05 -08:00
T. Joseph Carter
4587df5bf9 hfsutils works if installed (no check for that) 2015-11-09 03:58:56 -08:00
T. Joseph Carter
cc89978e52 Now installs on Darwin systems! 2015-11-09 03:14:35 -08:00
T. Joseph Carter
d9c4af34e0 Different tack: Just install boot blocks
This isn't done, but it reflects largely starting over.  The goal right
now is to install the boot blocks.  To do this we need to:

* Find out if we need to install anything
* Download the disk image archive
* Extract the disk image from the archive
* Mount the image
* Copy the files out of the image
* Unmount the image
* Patch the files if they need patching
* Verify the files are patched correctly

The branching possibilities for installing the disk images are:

1. That the image is currently always a .sea.bin file.  In future, it
   might not be!  After all, the other six disk images are available
   multiple places and they're not stored as self-extracting images in
   MacBinary format.

2. That there are three different ways I know of to extract the HFS disk
   image:  Mount it as a loop filesystem (Linux), attach it as a disk
   image file (OS X), or extract its contents using hfsutils which
   should be able to run just about anywhere.  Of course hfsutils has an
   additional branch in that hfsutils "sanitizes" the files you copy out
   of it for you in ways we don't want, so we need to know the file
   names it uses so we can change them back to OS X expectations.

3. How are we installing these files?  If we're installing them for
   netatalk, we need to rename a file.  If just to a UNIX path, that's
   something different.  If there was some reason to package them in
   ProDOS format, again, we need to do something different.

At this time, since I'm developing this on a Mac, I'm assuming .sea.bin
with an 800k image, I'm implementing hdiutil to mount the image, and
I'll implement the UNIX naming first (so as Mac/Linux mount the files.)

Next I'll implement renaming for netatalk and hfsutils.  I'll check it
out on the pi and implement the Linux filesystem mounting probably last,
then clean it up to behave more like Python is supposed to if I can
before I start on the GS/OS install itself.

I need a better MacBinary unpacker than unar gives me.  The way that
works right now is just clumsy.
2015-11-08 20:48:13 -08:00
T. Joseph Carter
1796676df1 os.environ.has_key(key) -> key in os.environ 2015-11-08 17:57:29 -08:00
T. Joseph Carter
876991f11f A little more progress on installing boot blocks 2015-11-08 15:39:20 -08:00
T. Joseph Carter
73fa5d5909 Add some pseudocode that is helping me understand
Think I see some of what I need to do next.
2015-11-07 22:31:43 -08:00
T. Joseph Carter
c3b4829e26 Downloads and extracts disk 7 now
I'm not real happy with how I'm doing this.  It's obviously not as clean
or as simple as a shell script would be, but that's to be expected since
we have to emulate with those shell commands--whole programs in their
own right--do.  But right now, the logic doesn't flow right either for a
structured program or an unstructured shell script.  Probably trying to
do too much in one go there.
2015-11-06 23:55:36 -08:00
T. Joseph Carter
d52b6ef9f1 Start of experimental install-gsos.py
This script replaces--or rather will eventually replace--the bash script
that installs netboot files in /media/A2SHARED.  It generally is going
to be implemented for now as a copy of the shell script, not quite
verbatim.  For example, rather than run individual commands with sudo,
it re-runs itself with sudo.  And rather than force scriptURL to include
a trailing slash, it explicitly chops the slash off to behave more like
you'd expect directories to.

Also, the body of installing the netboot files will be built as a
function rather than as straight script execution.  Basically the idea
there is to begin breaking the components of the netboot script into
their own functions that can be accessed independently in the future.
One step at a time there.

Anyway, very little of the script is done yet.  This is just to begin
the process and perhaps elicit some feedback if I'm really doing
something totally wrong here--my python's a little rusty.
2015-11-06 08:51:43 -08:00