Annotation of 43BSD/contrib/emacs/etc/APOLLO, revision 1.1.1.1

1.1       root        1: The Apollo has a bizarre operating system which does not permit
                      2: Emacs to be dumped with preloaded pure Lisp code.  Therefore, each
                      3: time you start Emacs on this system, the standard Lisp code is loaded
                      4: into it.  Expect it to take a long time.  You can prevent loading of
                      5: the standard Lisp code by specifying the -nl switch.  It must
                      6: come at the beginning of the command line; only the -t and -batch
                      7: switches may come before it.
                      8: 
                      9: You must use m-apollo.h in the config.h file, together with
                     10: s-bsd4.2.h.
                     11: 
                     12: There is one remaining problem on the Apollo.  The system does not
                     13: come with a C preprocessor as a separate program.
                     14: 
                     15: The C compiler can be used in place of cpp, but you must fool it into
                     16: thinking that ymakefile is a C program.  This requires replacing the
                     17: rule for xmakefile in src/Makefile with the following:
                     18: 
                     19: xmakefile: ymakefile config.h
                     20:        rm -f xmakefile
                     21:        cp ymakefile ymakefile.c
                     22:        (cc -E ymakefile.c | sed -e 's/^#.*//' -e 's/^[ \f      ]$$//' -e 's/^ /        /' | \
                     23:        sed -n -e '/^..*$$/p' > xmakefile)
                     24:        rm ymakefile.c
                     25: 
                     26: It has also been suggested that you change etc/Makefile not to make
                     27: loadst.c.  I think it would be better to fix loadst.c than to turn
                     28: it off, but nobody has told me what, if any, problem it encounters.
                     29: 
                     30: 
                     31: Here is a design for a method of dumping and reloading the relevant
                     32: necessary impure areas of Emacs.
                     33: 
                     34: On dumping, you need to dump only the array `pure' plus the
                     35: locations that contain values of forwarded Lisp variables or that are
                     36: protected for garbage collection.  The former can be found by a
                     37: garbage- collection-like technique, and the latter are in the
                     38: staticprolist vector (see alloc.c for both things).
                     39: 
                     40: Reloading would work in an Emacs that has just been started; except
                     41: when a switch is specified to inhibit this, it would read the dump
                     42: file and set all the appropriate locations.  The data loaded must be
                     43: relocated, but that's not hard.  Those locations that are of type
                     44: Lisp_Object can be found by a technique like garbage-collection, and
                     45: those of them that point to storage can be relocated.  The other data
                     46: read from the file will not need to be relocated.
                     47: 
                     48: The switch to inhibit loading the data base would be used when it
                     49: is time to dump a new data base.
                     50: 
                     51: This would take a few seconds, which is much faster than loading
                     52: the Lisp code of Emacs from scratch.

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.