LSST Applications  21.0.0-142-gef555c1e+42c9bccae2,22.0.0+052faf71bd,22.0.0+1c4650f311,22.0.0+40ce427c77,22.0.0+5b6c068b1a,22.0.0+7589c3a021,22.0.0+81ed51be6d,22.0.1-1-g7d6de66+6cae67f2c6,22.0.1-1-g87000a6+314cd8b7ea,22.0.1-1-g8760c09+052faf71bd,22.0.1-1-g8e32f31+5b6c068b1a,22.0.1-10-g779eefa+a163f08322,22.0.1-12-g3bd7ecb+bbeacc25a9,22.0.1-15-g63cc0c1+2a7037787d,22.0.1-17-ge5a99e88+3d2c1afe2e,22.0.1-19-g88addfe+6cae67f2c6,22.0.1-2-g1cb3e5b+84de06d286,22.0.1-2-g8ef0a89+6cae67f2c6,22.0.1-2-g92698f7+1c4650f311,22.0.1-2-ga9b0f51+052faf71bd,22.0.1-2-gb66926d+5b6c068b1a,22.0.1-2-gcb770ba+0723a13595,22.0.1-2-ge470956+ff9f1dc8d5,22.0.1-22-g608e23ac+2ac85e833c,22.0.1-29-g184b6e44e+8b185d4e2d,22.0.1-3-g59f966b+11ba4df19d,22.0.1-3-g8c1d971+f90df4c6d0,22.0.1-3-g997b569+d69a7aa2f8,22.0.1-3-gaaec9c0+4d194bf81c,22.0.1-4-g1930a60+283d9d2f1a,22.0.1-4-g5b7b756+c1283a92b8,22.0.1-4-g8623105+6cae67f2c6,22.0.1-7-gba73697+283d9d2f1a,22.0.1-8-g47d23f5+43acea82f3,master-g5f2689bdc5+40ce427c77,w.2021.38
LSST Data Management Base Package
Functions
lsst.utils.inheritDoc Namespace Reference

Functions

def inheritDoc (klass)
 

Function Documentation

◆ inheritDoc()

def lsst.utils.inheritDoc.inheritDoc (   klass)
Extends existing documentation for a method that exists in another
class and extend it with any additional documentation defined.

This decorator takes a class from which to draw documentation from as an
argument. This is so that any class may be used as a source of documentation
and not just the immediate parent of a class. This is useful when there may
be a long inheritance chain, or in the case of mixins.

Parameters
----------
klass : object
    The class to inherit documentation from.

Returns
-------
decorator : callable
    Intermediate decorator used in the documentation process.

Definition at line 23 of file inheritDoc.py.

23 def inheritDoc(klass):
24  """Extends existing documentation for a method that exists in another
25  class and extend it with any additional documentation defined.
26 
27  This decorator takes a class from which to draw documentation from as an
28  argument. This is so that any class may be used as a source of documentation
29  and not just the immediate parent of a class. This is useful when there may
30  be a long inheritance chain, or in the case of mixins.
31 
32  Parameters
33  ----------
34  klass : object
35  The class to inherit documentation from.
36 
37  Returns
38  -------
39  decorator : callable
40  Intermediate decorator used in the documentation process.
41  """
42  def tmpDecorator(method):
43  """Decorator to update the documentation from a class with the same method
44  """
45  methodName = method.__name__
46  if not hasattr(klass, methodName):
47  raise AttributeError(f"{klass} has no method named {methodName} to inherit from")
48  appendText = method.__doc__ or ""
49  method.__doc__ = getattr(klass, methodName).__doc__ + appendText
50  return method
51  return tmpDecorator
def inheritDoc(klass)
Definition: inheritDoc.py:23