61d42c32c7
a package into destdir but do not want to have it in masterdir. Useful to test different versions, with incompatible ABI changes, etc. --HG-- extra : convert_revision : cd13448fb92fdf0df6547477c7e9d7343bb197a0
127 lines
4.6 KiB
Text
127 lines
4.6 KiB
Text
pkgfs - Build packages from s(cratch|ource)
|
||
|
||
It is a simple package system manager that uses Xstow to allow packages
|
||
to be available at a master directory.
|
||
|
||
Multiple versions of a package can be installed, because they can be enabled
|
||
or disabled at the master directory anytime, to e.g allow testing different
|
||
versions of the same package by "stowning" or "unstowning" them.
|
||
|
||
------------------------------------------------------------------------------
|
||
HOW TO USE IT
|
||
------------------------------------------------------------------------------
|
||
|
||
Once you download it, you should edit the configuration file located at the
|
||
pkgfs directory. By default it uses the pkgfs directory in your $HOME.
|
||
|
||
If PKGFS_CONFIG_FILE is not set or specified from the command line with the
|
||
-c flag, it will use the location "/usr/local/etc/pkgfs.conf".
|
||
|
||
Once that you read the "pkgfs.conf" file and configured it, you can start
|
||
installing packages by using the command:
|
||
|
||
$ pkgfs.sh -c pkgfs.conf install glib-2.18.1
|
||
|
||
Please note that it's assumed that PKGFS_TEMPLATESDIR is properly defined
|
||
and actually contains valid template files.
|
||
|
||
While installing your first package, if pkgfs couldn't find the Xstow program
|
||
specified at the configuration file with PKGFS_XSTOW_CMD, the Xstow package
|
||
will be installed and "stowned".
|
||
|
||
If the package is properly installed, it will be "stowned" automatically.
|
||
``stowned´´ means that this package is available in the master directory,
|
||
on which ``Xstow´´ has created links from DESTDIR/<pkgname>.
|
||
|
||
To remove a currently installed (and stowned) package, you can use:
|
||
|
||
$ pkgfs.sh -c pkgfs.conf remove glib-2.18.1
|
||
|
||
Please note that when you remove it, the package will also be removed
|
||
from PKGFS_DESTDIR and previously "unstowned".
|
||
|
||
pkgfs uses some db(1) btree files, to record what packages are currently
|
||
"stowned". Once you install successfully or stown a package, the package
|
||
will be registered in PKGFS_DESTDIR/.pkgfs-registered-pkg.db.
|
||
|
||
While "unstowning" a package, it won't be available anymore in the master
|
||
directory and therefore it probably won't work if used from
|
||
PKGFS_DESTDIR/<pkgname>.
|
||
|
||
Summary, to stow an already installed package (into PKGFS_DESTDIR/<pkgname>):
|
||
|
||
$ pkgfs.sh -c pkgs.conf stow glib-2.18.1
|
||
|
||
and to unstow an already installed (stowned) package:
|
||
|
||
$ pkgfs.sh -c pkgfs.conf unstow glib-2.18.1
|
||
|
||
You can also print some stuff about any template, e.g:
|
||
|
||
$ pkgfs.sh info glib-2.18.1
|
||
|
||
To list installed (stowned) packages, use this:
|
||
|
||
$ pkgfs.sh -c pkgfs.conf list
|
||
|
||
To only extract the distfile, without configuring/building/installing:
|
||
|
||
$ pkgfs.sh -c pkgfs.conf -i install foo-1.0
|
||
|
||
To not remove the build directory after successful installation:
|
||
|
||
$ pkgfs.sh -c pkgfs.conf -C install blah-1.0
|
||
|
||
To only fetch the distfile:
|
||
|
||
$ pkgfs.sh -c pkgfs.conf -e install blah-1.0
|
||
|
||
To only install the package, _without_ stowning it into the master directory:
|
||
|
||
$ pkgfs.sh -c pkgfs.conf -i install blob-4.0
|
||
|
||
That's all for now folks. I hope you find it useful, as I do.
|
||
|
||
------------------------------------------------------------------------------
|
||
PERFORMANCE
|
||
------------------------------------------------------------------------------
|
||
|
||
pkgfs is really fast, trust me. That was one of my reasons to make my own
|
||
pkgsrc/ports alike system.
|
||
|
||
If you want benchmarks, here is one; building libX11 (all deps installed)
|
||
with pkgfs:
|
||
|
||
217.00s real 103.23s user 29.96s system
|
||
|
||
versus pkgsrc (make install clean):
|
||
|
||
229.22s real 112.75s user 54.79s system
|
||
|
||
The difference in this package might not be too big as I might think... but
|
||
anyway, 12 seconds faster is not that bad.
|
||
|
||
------------------------------------------------------------------------------
|
||
HOW TO MAKE TEMPLATES
|
||
------------------------------------------------------------------------------
|
||
|
||
A template in pkgfs is just a small text file with a few variables that are
|
||
required to build the package. pkgfs should be easy to work on, and
|
||
making templates shouldn't be too hard... if you have made any pkgsrc, it
|
||
should be trivial.
|
||
|
||
The required variables are: pkgname, build_type, extract_sufx, url
|
||
and checksum. Also there are some optional, like make_cmd, wrksrc,
|
||
configure_args, configure_env, make_build_args, make_install_args, etc.
|
||
|
||
Please take a look at the example.tmpl file located in the templates/
|
||
directory.
|
||
|
||
Also to help you creating templates and dependencies, there's a script
|
||
that will ask you some required information and will create the template
|
||
file once the distfile is downloaded: mktmpl.sh.
|
||
|
||
Try it and let me know if you have any problem or suggestion.
|
||
|
||
------------------------------------------------------------------------------
|
||
Juan Romero Pardines <xtraeme@gmail.com>
|