[AC21.5] commit: Add support for installing bundled packages.

Stephen J. Turnbull stephen at xemacs.org
Mon Dec 24 00:02:00 EST 2007


APPROVE COMMIT 21.5

 > changeset:   4354:232d873b9705ad6655ef42e6f59cecadc3100853
 > tag:         tip
 > user:        Stephen J. Turnbull <stephen at xemacs.org>
 > date:        Sun Dec 23 20:32:16 2007 -0800
 > files:       .hgignore ChangeLog Makefile.in.in etc/ChangeLog etc/bundled-packages/README etc/bundled-packages/test.sh
 > description:
 > Add support for installing bundled patches.

Oops, that's a pretty bad typo -- should be "packages", not "patches".

Vin: this doesn't depend on anything in 21.5.  If you think it would
be appropriate for 21.4 let me know.

Mike: this uses the value of --with-late-packages.  What values does
that take?  Just a directory, or a path?  I need to add some better
checking on that, I think.

I've added support for bundled packages in tarball distributions.
There doesn't seem to be much point in doing it for the Mercurial
repo, but support for bootstrapping packages could be added at the
cost of a few 100KBs in the repo.  There's an included test suite.

A more detailed description is in the README, attached below.

This is pretty raw, so please let me know if you find any problems.
Instructions for setting up a tree with packages are in the README.

etc/bundled-packages/README

Package distributions may be placed in this directory.
If present and a package-path is configured, packages can be installed
using the top-level makefile.

To configure the package path, use the --with-late-packages option to
configure, which specifies the path to the directory containing the
xemacs-packages and mule-packages hierarchies to install.

To find out if a distribution includes bundled packages, type

    make check-available-packages

There are three Make targets that may be available depending on the package
sets supplied.

    make install-bootstrap-packages
        Install a selected set of packages sufficient to support
        downloading and installing packages via the M-x list-packages
        interface.  Chose this if you want to be able to install the
        latest version of each package immediately.

    make install-nomule-packages
        Install the full distribution of packages that do not require a
        Mule-enabled XEmacs.  Choose this package if you don't have a
        Mule-enabled XEmacs and want the convenience of a single-command
        installation.  You can add or update packages via M-x list-packages
        at any time.

    make install-all-packages
        Install the full distribution of packages, including those requiring
        a Mule-enabled XEmacs.  Choose this package if you have a Mule-
        enabled XEmacs and want the convenience of a single-command
        installation.  You can add or update packages via M-x list-packages
        at any time.

DISTRIBUTOR'S NOTE: you may choose what packages you wish to include in
bootstrap.tar.gz, but to make list-packages work you need to include at
least xemacs-base, dired, and efs.  The tarball should unpack directly as
an xemacs-packages tree (and optionaly, a mule-packages tree.  Also, if
either of xemacs-sumo.tar.gz or xemacs-mule-sumo.tar.gz is provided, the
other should be as well.

If packages are not available with the distribution, you can get them at

    ftp://ftp.xemacs.org/pub/xemacs/packages/xemacs-sumo.tar.gz
    ftp://ftp.xemacs.org/pub/xemacs/packages/xemacs-mule-sumo.tar.gz
    http://turnbull.sk.tsukuba.ac.jp/Tools/XEmacs/bootstrap.tar.gz

and place them in the same directory as this file.  You can also make your
own bootstrap.tar.gz by creating a directory xemacs-packages, then
untarring the packages of your choice into that directory, and tarring the
whole thing up with "tar czf bootstrap.tar.gz xemacs-packages".  (If you
wish to include mule-packages, you should place them in mule-packages as
a sibling of xemacs-packages.)

This facility currently does not support installations which configure
the --with-early-packages, --with-late-packages, or --with-last-packages
options.

This facility currently will not overwrite an existing package
installation, not even if a whole hierarchy (usually the mule-packages)
is missing.  In particular, you cannot use this feature to add the
mule-packages to a package installation which lacks them, even if the
hierarchy is missing, or the xemacs-packages hierarchy was installed
this way.  Nor can you "upgrade" a bootstrap installation to a full
installation.  If you wish to do any of these things you will need to
remove the existing hierarchies.



More information about the XEmacs-Beta mailing list