
The hashing logic looks for function calls that are Spack directives. It expects that when a Spack directive is used that it is referenced directly by name, and that the directive function is not itself retrieved by calling another function. When the hashing logic encountered a function call where the function was determined dynamically, it would fail (attempting to access a name attribute that does not happen to exist in this case). This updates the hashing logic to filter out function calls where the function is determined dynamically when looking for uses of Spack directives.
28 lines
698 B
Python
28 lines
698 B
Python
# Copyright 2013-2020 Lawrence Livermore National Security, LLC and other
|
|
# Spack Project Developers. See the top-level COPYRIGHT file for details.
|
|
#
|
|
# SPDX-License-Identifier: (Apache-2.0 OR MIT)
|
|
|
|
from spack import *
|
|
|
|
|
|
class HashTest4(Package):
|
|
"""This package isn't compared with others, but it contains constructs
|
|
that package hashing logic has tripped over in the past.
|
|
"""
|
|
|
|
homepage = "http://www.hashtest4.org"
|
|
url = "http://www.hashtest1.org/downloads/hashtest4-1.1.tar.bz2"
|
|
|
|
version('1.1', 'a' * 32)
|
|
|
|
def install(self, spec, prefix):
|
|
pass
|
|
|
|
@staticmethod
|
|
def examine_prefix(pkg):
|
|
pass
|
|
|
|
run_after('install')(
|
|
examine_prefix)
|