From 30d3b32085ab31c91ac45f2f14c5de07774823f7 Mon Sep 17 00:00:00 2001 From: Todd Gamblin Date: Fri, 3 Jan 2014 11:43:29 -0800 Subject: Bug fix in how class names are determined --- lib/spack/spack/packages/__init__.py | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/lib/spack/spack/packages/__init__.py b/lib/spack/spack/packages/__init__.py index a97d8b5546..5fb4329aeb 100644 --- a/lib/spack/spack/packages/__init__.py +++ b/lib/spack/spack/packages/__init__.py @@ -203,7 +203,10 @@ def class_name_for_package_name(pkg_name): conflicts don't matter because the classes are in different modules. """ validate_package_name(pkg_name) - class_name = string.capwords(pkg_name.replace('_', '-'), '-') + + class_name = pkg_name.replace('_', '-') + class_name = string.capwords(class_name, '-') + class_name = class_name.replace('-', '') # If a class starts with a number, prefix it with Number_ to make it a valid # Python class name. @@ -241,7 +244,7 @@ def get_class_for_package_name(pkg_name): if not re.match(r'%s' % spack.module_path, spack.packages_path): raise RuntimeError("Packages path is not a submodule of spack.") - class_name = pkg_name.capitalize() + class_name = class_name_for_package_name(pkg_name) try: module_name = "%s.%s" % (packages_module(), pkg_name) module = __import__(module_name, fromlist=[class_name]) -- cgit v1.2.3-70-g09d2