summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTodd Gamblin <tgamblin@llnl.gov>2014-09-18 23:22:03 -0700
committerTodd Gamblin <tgamblin@llnl.gov>2014-09-18 23:22:03 -0700
commit9165a000a3b0ac68692d8ad58bb41d85276cec61 (patch)
treea38cac17b1f0d1f08be0d913714970a15253e1ce
parentc55041e9d47cba97fc461c088c4b935b3355e340 (diff)
downloadspack-9165a000a3b0ac68692d8ad58bb41d85276cec61.tar.gz
spack-9165a000a3b0ac68692d8ad58bb41d85276cec61.tar.bz2
spack-9165a000a3b0ac68692d8ad58bb41d85276cec61.tar.xz
spack-9165a000a3b0ac68692d8ad58bb41d85276cec61.zip
Better C++11 support, remove non-standalone llvm-compiler-rt.
- LLVM non-standalone add-ons are difficult to build outside LLVM. - May have to wait for future versions of LLVM to build some of these
-rw-r--r--lib/spack/spack/build_environment.py2
-rw-r--r--lib/spack/spack/cmd/pkg.py124
-rw-r--r--lib/spack/spack/compiler.py3
-rw-r--r--lib/spack/spack/compilers/gcc.py11
-rw-r--r--lib/spack/spack/compilers/intel.py9
-rw-r--r--lib/spack/spack/package.py9
-rw-r--r--var/spack/packages/clang/package.py2
-rw-r--r--var/spack/packages/llvm-compiler-rt/package.py57
-rw-r--r--var/spack/packages/llvm-lld/package.py4
-rw-r--r--var/spack/packages/llvm/package.py2
10 files changed, 161 insertions, 62 deletions
diff --git a/lib/spack/spack/build_environment.py b/lib/spack/spack/build_environment.py
index f72c724420..80abde70a9 100644
--- a/lib/spack/spack/build_environment.py
+++ b/lib/spack/spack/build_environment.py
@@ -84,7 +84,7 @@ class MakeExecutable(Executable):
def set_compiler_environment_variables(pkg):
assert(pkg.spec.concrete)
- compiler = compilers.compiler_for_spec(pkg.spec.compiler)
+ compiler = pkg.compiler
# Set compiler variables used by CMake and autotools
os.environ['CC'] = 'cc'
diff --git a/lib/spack/spack/cmd/pkg.py b/lib/spack/spack/cmd/pkg.py
new file mode 100644
index 0000000000..82ebd13ff9
--- /dev/null
+++ b/lib/spack/spack/cmd/pkg.py
@@ -0,0 +1,124 @@
+##############################################################################
+# 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
+##############################################################################
+import os
+
+from external import argparse
+import llnl.util.tty as tty
+from llnl.util.tty.colify import colify
+
+import spack
+from spack.util.executable import *
+
+description = "Query packages associated with particular git revisions in spack."
+
+def setup_parser(subparser):
+ sp = subparser.add_subparsers(
+ metavar='SUBCOMMAND', dest='pkg_command')
+
+ list_parser = sp.add_parser('list', help=pkg_list.__doc__)
+ list_parser.add_argument('rev', default='HEAD', nargs='?',
+ help="Revision to list packages for.")
+
+ diff_parser = sp.add_parser('diff', help=pkg_diff.__doc__)
+ diff_parser.add_argument('rev1', nargs='?', default='HEAD^',
+ help="Revision to compare against.")
+ diff_parser.add_argument('rev2', nargs='?', default='HEAD',
+ help="Revision to compare to rev1 (default is HEAD).")
+
+ add_parser = sp.add_parser('added', help=pkg_added.__doc__)
+ add_parser.add_argument('rev1', nargs='?', default='HEAD^',
+ help="Revision to compare against.")
+ add_parser.add_argument('rev2', nargs='?', default='HEAD',
+ help="Revision to compare to rev1 (default is HEAD).")
+
+ rm_parser = sp.add_parser('removed', help=pkg_removed.__doc__)
+ rm_parser.add_argument('rev1', nargs='?', default='HEAD^',
+ help="Revision to compare against.")
+ rm_parser.add_argument('rev2', nargs='?', default='HEAD',
+ help="Revision to compare to rev1 (default is HEAD).")
+
+
+def get_git():
+ # cd to spack prefix to do git operations
+ os.chdir(spack.prefix)
+
+ # If this is a non-git version of spack, give up.
+ if not os.path.isdir('.git'):
+ tty.die("No git repo in %s. Can't use 'spack pkg'" % spack.prefix)
+
+ return which("git", required=True)
+
+
+def list_packages(rev):
+ git = get_git()
+ relpath = spack.packages_path[len(spack.prefix + os.path.sep):] + os.path.sep
+ output = git('ls-tree', '--full-tree', '--name-only', rev, relpath,
+ return_output=True)
+ return sorted(line[len(relpath):] for line in output.split('\n') if line)
+
+
+def pkg_list(args):
+ """List packages associated with a particular spack git revision."""
+ colify(list_packages(args.rev))
+
+
+def diff_packages(rev1, rev2):
+ p1 = set(list_packages(rev1))
+ p2 = set(list_packages(rev2))
+ return p1.difference(p2), p2.difference(p1)
+
+
+def pkg_diff(args):
+ """Compare packages available in two different git revisions."""
+ u1, u2 = diff_packages(args.rev1, args.rev2)
+
+ if u1:
+ print "%s:" % args.rev1
+ colify(sorted(u1), indent=4)
+ if u1: print
+
+ if u2:
+ print "%s:" % args.rev2
+ colify(sorted(u2), indent=4)
+
+
+def pkg_removed(args):
+ """Show packages removed since a commit."""
+ u1, u2 = diff_packages(args.rev1, args.rev2)
+ if u1: colify(sorted(u1))
+
+
+def pkg_added(args):
+ """Show packages added since a commit."""
+ u1, u2 = diff_packages(args.rev1, args.rev2)
+ if u2: colify(sorted(u2))
+
+
+def pkg(parser, args):
+ action = { 'diff' : pkg_diff,
+ 'list' : pkg_list,
+ 'removed' : pkg_removed,
+ 'added' : pkg_added }
+ action[args.pkg_command](args)
diff --git a/lib/spack/spack/compiler.py b/lib/spack/spack/compiler.py
index 716356bdd2..e4a6629759 100644
--- a/lib/spack/spack/compiler.py
+++ b/lib/spack/spack/compiler.py
@@ -94,6 +94,9 @@ class Compiler(object):
# Names of generic arguments used by this compiler
arg_rpath = '-Wl,-rpath,%s'
+ # argument used to get C++11 options
+ cxx11_flag = "-std=c++11"
+
def __init__(self, cspec, cc, cxx, f77, fc):
def check(exe):
diff --git a/lib/spack/spack/compilers/gcc.py b/lib/spack/spack/compilers/gcc.py
index cc3c52ca61..097b24bb87 100644
--- a/lib/spack/spack/compilers/gcc.py
+++ b/lib/spack/spack/compilers/gcc.py
@@ -22,7 +22,9 @@
# along with this program; if not, write to the Free Software Foundation,
# Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
##############################################################################
+import llnl.util.tty as tty
from spack.compiler import *
+from spack.version import ver
class Gcc(Compiler):
# Subclasses use possible names of C compiler
@@ -40,6 +42,15 @@ class Gcc(Compiler):
# MacPorts builds gcc versions with prefixes and -mp-X.Y suffixes.
suffixes = [r'-mp-\d\.\d']
+ @property
+ def cxx11_flag(self):
+ if self.version < ver('4.3'):
+ tty.die("Only gcc 4.3 and above support c++11.")
+ elif self.version < ver('4.7'):
+ return "-std=gnu++0x"
+ else:
+ return "-std=gnu++11"
+
@classmethod
def fc_version(cls, fc):
return get_compiler_version(
diff --git a/lib/spack/spack/compilers/intel.py b/lib/spack/spack/compilers/intel.py
index 02e3b96b19..2a72c4eaea 100644
--- a/lib/spack/spack/compilers/intel.py
+++ b/lib/spack/spack/compilers/intel.py
@@ -37,6 +37,15 @@ class Intel(Compiler):
# Subclasses use possible names of Fortran 90 compiler
fc_names = ['ifort']
+ @property
+ def cxx11_flag(self):
+ if self.version < ver('11.1'):
+ tty.die("Only intel 11.1 and above support c++11.")
+ elif self.version < ver('13'):
+ return "-std=c++0x"
+ else:
+ return "-std=c++11"
+
@classmethod
def default_version(cls, comp):
diff --git a/lib/spack/spack/package.py b/lib/spack/spack/package.py
index 0375df7dac..1afdeaf2a0 100644
--- a/lib/spack/spack/package.py
+++ b/lib/spack/spack/package.py
@@ -48,6 +48,7 @@ from llnl.util.lang import *
import spack
import spack.spec
import spack.error
+import spack.compilers
import spack.hooks
import spack.build_environment as build_env
import spack.url as url
@@ -505,6 +506,14 @@ class Package(object):
return self.spec.prefix
+ @property
+ def compiler(self):
+ """Get the spack.compiler.Compiler object used to build this package."""
+ if not self.spec.concrete:
+ raise ValueError("Can only get a compiler for a concrete package.")
+ return spack.compilers.compiler_for_spec(self.spec.compiler)
+
+
def url_version(self, version):
"""Given a version, this returns a string that should be substituted into the
package's URL to download that version.
diff --git a/var/spack/packages/clang/package.py b/var/spack/packages/clang/package.py
index 07948a3ed7..b0097bd126 100644
--- a/var/spack/packages/clang/package.py
+++ b/var/spack/packages/clang/package.py
@@ -36,7 +36,7 @@ class Clang(Package):
version('3.4.2', '87945973b7c73038871c5f849a818588')
def install(self, spec, prefix):
- env['CXXFLAGS'] = '-std=c++11'
+ env['CXXFLAGS'] = self.compiler.cxx11_flag
with working_dir('spack-build', create=True):
cmake('..',
diff --git a/var/spack/packages/llvm-compiler-rt/package.py b/var/spack/packages/llvm-compiler-rt/package.py
deleted file mode 100644
index e3fa176afe..0000000000
--- a/var/spack/packages/llvm-compiler-rt/package.py
+++ /dev/null
@@ -1,57 +0,0 @@
-##############################################################################
-# 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 spack import *
-
-class LlvmCompilerRt(Package):
- """Compiler-rt consists of several libraries to be used with LLVM:
- basics:
- A simple library that provides an implementation of the
- low-level target-specific hooks required by code
- generation and other runtime components.
-
- sanitizer runtimes:
- Runtime libraries that are required to run the code with
- sanitizer instrumentation.
-
- profiler:
- Library used to collect coverage information.
-
- BlocksRuntime:
- A target-independent implementation of Apple "Blocks"
- runtime interfaces.
- """
- homepage = "http://compiler-rt.llvm.org"
- url = "http://llvm.org/releases/3.4/compiler-rt-3.4.src.tar.gz"
-
- depends_on("clang")
- depends_on("llvm")
-
- version('3.4', '7938353e3a3bda85733a165e7ac4bb84')
-
- def install(self, spec, prefix):
- cmake(".", *std_cmake_args)
-
- make()
- make("install")
diff --git a/var/spack/packages/llvm-lld/package.py b/var/spack/packages/llvm-lld/package.py
index ba0b229228..f229211396 100644
--- a/var/spack/packages/llvm-lld/package.py
+++ b/var/spack/packages/llvm-lld/package.py
@@ -35,12 +35,12 @@ class LlvmLld(Package):
version('3.4', '3b6a17e58c8416c869c14dd37682f78e')
def install(self, spec, prefix):
- env['CXXFLAGS'] = '-std=c++11'
+ env['CXXFLAGS'] = self.compier.cxx11_flag
with working_dir('spack-build', create=True):
cmake('..',
'-DLLD_PATH_TO_LLVM_BUILD=%s' % spec['llvm'].prefix,
'-DLLVM_MAIN_SRC_DIR=%s' % spec['llvm'].prefix,
*std_cmake_args)
- make('VERBOSE=1')
+ make()
make("install")
diff --git a/var/spack/packages/llvm/package.py b/var/spack/packages/llvm/package.py
index 08ae7208cd..c7a10df55a 100644
--- a/var/spack/packages/llvm/package.py
+++ b/var/spack/packages/llvm/package.py
@@ -37,7 +37,7 @@ class Llvm(Package):
version('3.4.2', 'a20669f75967440de949ac3b1bad439c')
def install(self, spec, prefix):
- env['CXXFLAGS'] = '-std=c++11'
+ env['CXXFLAGS'] = self.compiler.cxx11_flag
with working_dir('spack-build', create=True):
cmake('..',