
- spack install suppresses build output by default. - use install -v to show build output on the console too - package.py uses log_output context to redirect output and log it to a file - filters color codes out of output written to file - optionally echos to the terminal - YAML directory layout knows about its build log. - can get path to install build log to from directory layout - Package.install now copies the build log to $prefix/.spack/build.out - Error message from failed install execution now includes build log location
81 lines
3.3 KiB
Python
81 lines
3.3 KiB
Python
##############################################################################
|
|
# Copyright (c) 2013, Lawrence Livermore National Security, LLC.
|
|
# Produced at the Lawrence Livermore National Laboratory.
|
|
#
|
|
# This file is part of Spack.
|
|
# Written by Todd Gamblin, tgamblin@llnl.gov, All rights reserved.
|
|
# LLNL-CODE-647188
|
|
#
|
|
# For details, see https://scalability-llnl.github.io/spack
|
|
# Please also see the LICENSE file for our notice and the LGPL.
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License (as published by
|
|
# the Free Software Foundation) version 2.1 dated February 1999.
|
|
#
|
|
# This program is distributed in the hope that it will be useful, but
|
|
# WITHOUT ANY WARRANTY; without even the IMPLIED WARRANTY OF
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the terms and
|
|
# conditions of the GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Lesser General Public License
|
|
# along with this program; if not, write to the Free Software Foundation,
|
|
# Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
##############################################################################
|
|
from external import argparse
|
|
|
|
import llnl.util.tty as tty
|
|
|
|
import spack
|
|
import spack.cmd
|
|
|
|
description = "Build and install packages"
|
|
|
|
def setup_parser(subparser):
|
|
subparser.add_argument(
|
|
'-i', '--ignore-dependencies', action='store_true', dest='ignore_deps',
|
|
help="Do not try to install dependencies of requested packages.")
|
|
subparser.add_argument(
|
|
'-j', '--jobs', action='store', type=int,
|
|
help="Explicitly set number of make jobs. Default is #cpus.")
|
|
subparser.add_argument(
|
|
'--keep-prefix', action='store_true', dest='keep_prefix',
|
|
help="Don't remove the install prefix if installation fails.")
|
|
subparser.add_argument(
|
|
'--keep-stage', action='store_true', dest='keep_stage',
|
|
help="Don't remove the build stage if installation succeeds.")
|
|
subparser.add_argument(
|
|
'-n', '--no-checksum', action='store_true', dest='no_checksum',
|
|
help="Do not check packages against checksum")
|
|
subparser.add_argument(
|
|
'-v', '--verbose', action='store_true', dest='verbose',
|
|
help="Display verbose build output while installing.")
|
|
subparser.add_argument(
|
|
'--fake', action='store_true', dest='fake',
|
|
help="Fake install. Just remove the prefix and touch a fake file in it.")
|
|
subparser.add_argument(
|
|
'packages', nargs=argparse.REMAINDER, help="specs of packages to install")
|
|
|
|
|
|
def install(parser, args):
|
|
if not args.packages:
|
|
tty.die("install requires at least one package argument")
|
|
|
|
if args.jobs is not None:
|
|
if args.jobs <= 0:
|
|
tty.die("The -j option must be a positive integer!")
|
|
|
|
if args.no_checksum:
|
|
spack.do_checksum = False # TODO: remove this global.
|
|
|
|
specs = spack.cmd.parse_specs(args.packages, concretize=True)
|
|
for spec in specs:
|
|
package = spack.db.get(spec)
|
|
package.do_install(
|
|
keep_prefix=args.keep_prefix,
|
|
keep_stage=args.keep_stage,
|
|
ignore_deps=args.ignore_deps,
|
|
make_jobs=args.jobs,
|
|
verbose=args.verbose,
|
|
fake=args.fake)
|