spack/lib/spack/docs/features.rst

134 lines
4.1 KiB
ReStructuredText
Raw Normal View History

================
Feature Overview
================
2013-12-12 20:25:31 +08:00
2013-12-19 03:02:31 +08:00
This is a high-level overview of features that make Spack different
from other `package managers
<http://en.wikipedia.org/wiki/Package_management_system>`_ and `port
systems <http://en.wikipedia.org/wiki/Ports_collection>`_.
2013-12-12 20:25:31 +08:00
---------------------------
2013-12-12 20:25:31 +08:00
Simple package installation
---------------------------
2013-12-12 20:25:31 +08:00
2013-12-19 03:02:31 +08:00
Installing the default version of a package is simple. This will install
the latest version of the ``mpileaks`` package and all of its dependencies:
2013-12-12 20:25:31 +08:00
.. code-block:: console
2013-12-12 20:25:31 +08:00
$ spack install mpileaks
--------------------------------
2013-12-12 20:25:31 +08:00
Custom versions & configurations
--------------------------------
2013-12-12 20:25:31 +08:00
2013-12-19 03:02:31 +08:00
Spack allows installation to be customized. Users can specify the
version, build compiler, compile-time options, and cross-compile
platform, all on the command line.
2013-12-12 20:25:31 +08:00
.. code-block:: console
2013-12-12 20:25:31 +08:00
# Install a particular version by appending @
$ spack install mpileaks@1.1.2
2013-12-19 03:02:31 +08:00
# Specify a compiler (and its version), with %
2013-12-12 20:25:31 +08:00
$ spack install mpileaks@1.1.2 %gcc@4.7.3
2016-05-26 01:56:12 +08:00
# Add special compile-time options by name
$ spack install mpileaks@1.1.2 %gcc@4.7.3 debug=True
# Add special boolean compile-time options with +
2013-12-12 20:25:31 +08:00
$ spack install mpileaks@1.1.2 %gcc@4.7.3 +debug
2016-05-26 01:56:12 +08:00
# Add compiler flags using the conventional names
$ spack install mpileaks@1.1.2 %gcc@4.7.3 cppflags=\"-O3 -floop-block\"
# Cross-compile for a different architecture with arch=
$ spack install mpileaks@1.1.2 arch=bgqos_0
2013-12-12 20:25:31 +08:00
2016-05-26 01:56:12 +08:00
Users can specify as many or few options as they care about. Spack
will fill in the unspecified values with sensible defaults. The two listed
syntaxes for variants are identical when the value is boolean.
2013-12-19 03:02:31 +08:00
----------------------
2013-12-12 20:25:31 +08:00
Customize dependencies
----------------------
2013-12-12 20:25:31 +08:00
2014-03-17 08:00:13 +08:00
Spack allows *dependencies* of a particular installation to be
customized extensively. Suppose that ``mpileaks`` depends indirectly
on ``libelf`` and ``libdwarf``. Using ``^``, users can add custom
configurations for the dependencies:
2013-12-12 20:25:31 +08:00
.. code-block:: console
2013-12-12 20:25:31 +08:00
# Install mpileaks and link it with specific versions of libelf and libdwarf
$ spack install mpileaks@1.1.2 %gcc@4.7.3 +debug ^libelf@0.8.12 ^libdwarf@20130729+debug
------------------------
2013-12-12 20:25:31 +08:00
Non-destructive installs
------------------------
2013-12-12 20:25:31 +08:00
2013-12-19 03:02:31 +08:00
Spack installs every unique package/dependency configuration into its
own prefix, so new installs will not break existing ones.
2013-12-12 20:25:31 +08:00
-------------------------------
2013-12-12 20:25:31 +08:00
Packages can peacefully coexist
-------------------------------
2013-12-12 20:25:31 +08:00
2013-12-19 03:02:31 +08:00
Spack avoids library misconfiguration by using ``RPATH`` to link
dependencies. When a user links a library or runs a program, it is
tied to the dependencies it was built with, so there is no need to
manipulate ``LD_LIBRARY_PATH`` at runtime.
2013-12-12 20:25:31 +08:00
-------------------------
2013-12-12 20:25:31 +08:00
Creating packages is easy
-------------------------
2013-12-12 20:25:31 +08:00
2013-12-19 03:02:31 +08:00
To create a new packages, all Spack needs is a URL for the source
archive. The ``spack create`` command will create a boilerplate
package file, and the package authors can fill in specific build steps
in pure Python.
2013-12-12 20:25:31 +08:00
2014-03-17 08:00:13 +08:00
For example, this command:
.. code-block:: console
2013-12-12 20:25:31 +08:00
2013-12-21 09:11:25 +08:00
$ spack create http://www.mr511.de/software/libelf-0.8.13.tar.gz
2013-12-12 20:25:31 +08:00
2014-03-17 08:00:13 +08:00
creates a simple python file:
2013-12-12 20:25:31 +08:00
.. code-block:: python
from spack import *
2013-12-21 09:11:25 +08:00
class Libelf(Package):
"""FIXME: Put a proper description of your package here."""
# FIXME: Add a proper url for your package's homepage here.
homepage = "http://www.example.com"
2013-12-21 09:11:25 +08:00
url = "http://www.mr511.de/software/libelf-0.8.13.tar.gz"
2014-10-08 14:32:34 +08:00
version('0.8.13', '4136d7b4c04df68b686570afa26988ac')
2013-12-12 20:25:31 +08:00
# FIXME: Add dependencies if required.
# depends_on('foo')
def install(self, spec, prefix):
# FIXME: Modify the configure line to suit your build system here.
configure('--prefix={0}'.format(prefix))
# FIXME: Add logic to build and install here.
2013-12-12 20:25:31 +08:00
make()
make('install')
2013-12-12 20:25:31 +08:00
2014-03-17 08:00:13 +08:00
It doesn't take much python coding to get from there to a working
package:
2013-12-21 09:11:25 +08:00
.. literalinclude:: ../../../var/spack/repos/builtin/packages/libelf/package.py
:lines: 25-
2013-12-21 09:11:25 +08:00
2013-12-19 03:02:31 +08:00
Spack also provides wrapper functions around common commands like
``configure``, ``make``, and ``cmake`` to make writing packages
simple.