From 7a575d2f4b1c20b61e4f2f847ad3e0a4bf37c0ed Mon Sep 17 00:00:00 2001 From: Massimiliano Culpo Date: Tue, 25 Oct 2016 17:30:40 +0200 Subject: multimethod.py : calls functools.wraps before returning the correct method fixes #2118 (#2119) --- lib/spack/spack/multimethod.py | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) (limited to 'lib') diff --git a/lib/spack/spack/multimethod.py b/lib/spack/spack/multimethod.py index d1d1f32445..4e2fb3bdaa 100644 --- a/lib/spack/spack/multimethod.py +++ b/lib/spack/spack/multimethod.py @@ -105,7 +105,17 @@ class SpecMultiMethod(object): def __get__(self, obj, objtype): """This makes __call__ support instance methods.""" - return functools.partial(self.__call__, obj) + # Method_list is a list of tuples (constraint, method) + # Here we are going to assume that we have at least one + # element in the list. The first registered function + # will be the one 'wrapped'. + wrapped_method = self.method_list[0][1] + # Call functools.wraps manually to get all the attributes + # we need to be disguised as the wrapped_method + func = functools.wraps(wrapped_method)( + functools.partial(self.__call__, obj) + ) + return func def __call__(self, package_self, *args, **kwargs): """Find the first method with a spec that matches the -- cgit v1.2.3-70-g09d2