summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorTodd Gamblin <tgamblin@llnl.gov>2014-08-22 11:00:19 -0700
committerTodd Gamblin <tgamblin@llnl.gov>2014-08-22 11:00:19 -0700
commitd87a6525823e0d75b9f6b71fb265ebffb9c060a4 (patch)
tree33987364fa00f29ab77d764c9ea56c25cfe37eab /lib
parenteb5efed421783dddbc6ebfe4ee7a9a987dfda3a5 (diff)
downloadspack-d87a6525823e0d75b9f6b71fb265ebffb9c060a4.tar.gz
spack-d87a6525823e0d75b9f6b71fb265ebffb9c060a4.tar.bz2
spack-d87a6525823e0d75b9f6b71fb265ebffb9c060a4.tar.xz
spack-d87a6525823e0d75b9f6b71fb265ebffb9c060a4.zip
Add spack cd and spack location commands.
- Better shell support for cd'ing into directories - Fix some csh weirdness with nested aliases.
Diffstat (limited to 'lib')
-rw-r--r--lib/spack/spack/cmd/cd.py38
-rw-r--r--lib/spack/spack/cmd/location.py93
-rw-r--r--lib/spack/spack/cmd/mirror.py2
-rw-r--r--lib/spack/spack/cmd/stage.py30
-rw-r--r--lib/spack/spack/modules.py6
5 files changed, 138 insertions, 31 deletions
diff --git a/lib/spack/spack/cmd/cd.py b/lib/spack/spack/cmd/cd.py
new file mode 100644
index 0000000000..24d56db7d0
--- /dev/null
+++ b/lib/spack/spack/cmd/cd.py
@@ -0,0 +1,38 @@
+##############################################################################
+# 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 spack.cmd.location
+import spack.modules
+
+description="cd to spack directories in the shell."
+
+def setup_parser(subparser):
+ """This is for decoration -- spack cd is used through spack's
+ shell support. This allows spack cd to print a descriptive
+ help message when called with -h."""
+ spack.cmd.location.setup_parser(subparser)
+
+
+def cd(parser, args):
+ spack.modules.print_help()
diff --git a/lib/spack/spack/cmd/location.py b/lib/spack/spack/cmd/location.py
new file mode 100644
index 0000000000..074d984ee6
--- /dev/null
+++ b/lib/spack/spack/cmd/location.py
@@ -0,0 +1,93 @@
+##############################################################################
+# 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.filesystem import join_path
+
+import spack
+import spack.cmd
+
+description="Print out locations of various diectories used by Spack"
+
+def setup_parser(subparser):
+ global directories
+ directories = subparser.add_mutually_exclusive_group()
+
+ directories.add_argument(
+ '-m', '--module-dir', action='store_true', help="Spack python module directory.")
+ directories.add_argument(
+ '-r', '--spack-root', action='store_true', help="Spack installation root.")
+
+ directories.add_argument(
+ '-i', '--install-dir', action='store_true',
+ help="Install prefix for spec (spec need not be installed).")
+ directories.add_argument(
+ '-p', '--package-dir', action='store_true',
+ help="Directory enclosing a spec's package.py file.")
+ directories.add_argument(
+ '-s', '--stage-dir', action='store_true', help="Stage directory for a spec.")
+ directories.add_argument(
+ '-b', '--build-dir', action='store_true',
+ help="Expanded archive directory for a spec (requires it to be staged first).")
+
+ subparser.add_argument(
+ 'spec', nargs=argparse.REMAINDER, help="spec of package to fetch directory for.")
+
+
+def location(parser, args):
+ if args.module_dir:
+ print spack.module_path
+
+ elif args.spack_root:
+ print spack.prefix
+
+ else:
+ specs = spack.cmd.parse_specs(args.spec, concretize=True)
+ if not specs:
+ tty.die("You must supply a spec.")
+ if len(specs) != 1:
+ tty.die("Too many specs. Need only one.")
+ spec = specs[0]
+
+ if args.install_dir:
+ print spec.prefix
+
+ elif args.package_dir:
+ print join_path(spack.db.root, spec.name)
+
+ else:
+ pkg = spack.db.get(spec)
+
+ if args.stage_dir:
+ print pkg.stage.path
+
+ else: # args.build_dir is the default.
+ if not os.listdir(pkg.stage.path):
+ tty.die("Build directory does not exist yet. Run this to create it:",
+ "spack stage " + " ".join(args.spec))
+ print pkg.stage.expanded_archive_path
+
diff --git a/lib/spack/spack/cmd/mirror.py b/lib/spack/spack/cmd/mirror.py
index a039e3383a..b42b329085 100644
--- a/lib/spack/spack/cmd/mirror.py
+++ b/lib/spack/spack/cmd/mirror.py
@@ -41,7 +41,7 @@ from spack.stage import Stage
from spack.util.compression import extension
-description = "Manage spack mirrors."
+description = "Manage mirrors."
def setup_parser(subparser):
subparser.add_argument(
diff --git a/lib/spack/spack/cmd/stage.py b/lib/spack/spack/cmd/stage.py
index 5df0ffc2a5..c8bc473c55 100644
--- a/lib/spack/spack/cmd/stage.py
+++ b/lib/spack/spack/cmd/stage.py
@@ -37,13 +37,6 @@ def setup_parser(subparser):
help="Do not check downloaded packages against checksum")
dir_parser = subparser.add_mutually_exclusive_group()
- dir_parser.add_argument(
- '-d', '--print-stage-dir', action='store_const', dest='print_dir',
- const='print_stage', help="Prints out the stage directory for a spec.")
- dir_parser.add_argument(
- '-b', '--print-build-dir', action='store_const', dest='print_dir',
- const='print_build', help="Prints out the expanded archive path for a spec.")
-
subparser.add_argument(
'specs', nargs=argparse.REMAINDER, help="specs of packages to stage")
@@ -56,24 +49,7 @@ def stage(parser, args):
spack.do_checksum = False
specs = spack.cmd.parse_specs(args.specs, concretize=True)
-
- if args.print_dir:
- if len(specs) != 1:
- tty.die("--print-stage-dir and --print-build-dir options only take one spec.")
-
- spec = specs[0]
- pkg = spack.db.get(spec)
-
- if args.print_dir == 'print_stage':
- print pkg.stage.path
- elif args.print_dir == 'print_build':
- if not os.listdir(pkg.stage.path):
- tty.die("Stage directory is empty. Run this first:",
- "spack stage " + " ".join(args.specs))
- print pkg.stage.expanded_archive_path
-
- else:
- for spec in specs:
- package = spack.db.get(spec)
- package.do_stage()
+ for spec in specs:
+ package = spack.db.get(spec)
+ package.do_stage()
diff --git a/lib/spack/spack/modules.py b/lib/spack/spack/modules.py
index 5d2105e37c..755e9ea900 100644
--- a/lib/spack/spack/modules.py
+++ b/lib/spack/spack/modules.py
@@ -64,10 +64,10 @@ module_types = {}
def print_help():
"""For use by commands to tell user how to activate shell support."""
- tty.msg("Spack module/dotkit support is not initialized.",
+ tty.msg("This command requires spack's shell integration.",
"",
- "To use dotkit or modules with Spack, you must first run",
- "one of the commands below. You can copy/paste them.",
+ "To initialize spack's shell commands, you must run one of",
+ "the commands below. Choose the right command for your shell.",
"",
"For bash and zsh:",
" . %s/setup-env.sh" % spack.share_path,