LSST Applications 26.0.0,g0265f82a02+6660c170cc,g07994bdeae+30b05a742e,g0a0026dc87+17526d298f,g0a60f58ba1+17526d298f,g0e4bf8285c+96dd2c2ea9,g0ecae5effc+c266a536c8,g1e7d6db67d+6f7cb1f4bb,g26482f50c6+6346c0633c,g2bbee38e9b+6660c170cc,g2cc88a2952+0a4e78cd49,g3273194fdb+f6908454ef,g337abbeb29+6660c170cc,g337c41fc51+9a8f8f0815,g37c6e7c3d5+7bbafe9d37,g44018dc512+6660c170cc,g4a941329ef+4f7594a38e,g4c90b7bd52+5145c320d2,g58be5f913a+bea990ba40,g635b316a6c+8d6b3a3e56,g67924a670a+bfead8c487,g6ae5381d9b+81bc2a20b4,g93c4d6e787+26b17396bd,g98cecbdb62+ed2cb6d659,g98ffbb4407+81bc2a20b4,g9ddcbc5298+7f7571301f,ga1e77700b3+99e9273977,gae46bcf261+6660c170cc,gb2715bf1a1+17526d298f,gc86a011abf+17526d298f,gcf0d15dbbd+96dd2c2ea9,gdaeeff99f8+0d8dbea60f,gdb4ec4c597+6660c170cc,ge23793e450+96dd2c2ea9,gf041782ebf+171108ac67
LSST Data Management Base Package
Loading...
Searching...
No Matches
Public Member Functions | Protected Attributes | List of all members
lsstDebug.Info Class Reference

Public Member Functions

 __init__ (self, modname)
 
 __getattr__ (self, what)
 
 __setattr__ (self, what, value)
 

Protected Attributes

 _modname
 

Detailed Description

An object cognisant of debugging parameters appropriate for module
``modname``.

Any request for a value will return False unless that value has
been set, either in the module or as an attribute of this object.

E.g.

.. code-block:: python

    import lsstDebug

    display = lsstDebug.Info(__name__).display

will set display to `False`, unless display has been set with

.. code-block:: python

    lsstDebug.Info(__name__).display = True

Why is this interesting?  Because you can replace `lsstDebug.Info` with
your own version, e.g.

.. code-block:: python

    import lsstDebug

    def DebugInfo(name):
        # N.b. lsstDebug.Info(name) would call us recursively
        di = lsstDebug.getInfo(name)
        if name == "foo":
            di.display = dict(repair=1, background=2, calibrate=3)

        return di

    lsstDebug.Info = DebugInfo

Parameters
----------
modname : `str`
    Module name.

Raises
------
KeyError
    Raised if ``modname`` is not loaded.

Definition at line 28 of file lsstDebug.py.

Constructor & Destructor Documentation

◆ __init__()

lsstDebug.Info.__init__ (   self,
  modname 
)

Definition at line 76 of file lsstDebug.py.

76 def __init__(self, modname):
77 import sys
78 self.__dict__["_dict"] = sys.modules[modname].__dict__
79 self._modname = modname
80

Member Function Documentation

◆ __getattr__()

lsstDebug.Info.__getattr__ (   self,
  what 
)
Return the value of the variable "what" in ``self.__modname``
if set, else False

Definition at line 81 of file lsstDebug.py.

81 def __getattr__(self, what):
82 """Return the value of the variable "what" in ``self.__modname``
83 if set, else False"""
84 return self._dict.get(what, False)
85

◆ __setattr__()

lsstDebug.Info.__setattr__ (   self,
  what,
  value 
)
Set the value of the variable "what" in ``self.__modname``
to value

Definition at line 86 of file lsstDebug.py.

86 def __setattr__(self, what, value):
87 """Set the value of the variable "what" in ``self.__modname``
88 to value"""
89 self._dict[what] = value
90
91

Member Data Documentation

◆ _modname

lsstDebug.Info._modname
protected

Definition at line 79 of file lsstDebug.py.


The documentation for this class was generated from the following file: