LSST Applications g07dc498a13+7851b72aa9,g1409bbee79+7851b72aa9,g1a7e361dbc+7851b72aa9,g1fd858c14a+a4e18a0dda,g33399d78f5+a0324bbf49,g35bb328faa+e55fef2c71,g3bd4b5ce2c+8524b1c0c8,g53246c7159+e55fef2c71,g579b87e3d2+a58ba40925,g60b5630c4e+7b4465799a,g78460c75b0+8427c4cc8f,g78619a8342+5517f7db9e,g786e29fd12+307f82e6af,g8534526c7b+8e1c6b434f,g89139ef638+7851b72aa9,g8b49a6ea8e+7b4465799a,g8ffcb69f3d+0065d7bbc8,g9125e01d80+e55fef2c71,g97b8272a79+a8c4cb337e,g989de1cb63+7851b72aa9,g9f33ca652e+747bd1f1f9,gaaedd4e678+7851b72aa9,gabe3b4be73+9c0c3c7524,gb1101e3267+c03a154bbb,gb58c049af0+28045f66fd,gc1fe0db326+7b4465799a,gca43fec769+e55fef2c71,gce7788e931+99adca4f64,gcf25f946ba+a0324bbf49,gd397e13551+18f805d5e0,gd6cbbdb0b4+f6e5445f66,gde0f65d7ad+78b6ec8427,ge278dab8ac+b4c2c8faf7,geab183fbe5+7b4465799a,gecb8035dfe+1f480bec5e,gf58bf46354+e55fef2c71,gf92a8ffd38+e7bc33f3ea,gfe7187db8c+38a2c5c626,w.2025.03
LSST Data Management Base Package
Loading...
Searching...
No Matches
lsst.pex.config.callStack Namespace Reference

Classes

class  StackFrame
 

Functions

 getCallerFrame (relative=0)
 
 getStackFrame (relative=0)
 
 getCallStack (skip=0)
 

Function Documentation

◆ getCallerFrame()

lsst.pex.config.callStack.getCallerFrame ( relative = 0)
Get the frame for the user's caller.

Parameters
----------
relative : `int`, optional
    Number of frames (0 or more) above the caller to retrieve.
    Default is 0.

Returns
-------
frame : `types.FrameType`
    Frame for the caller.

Notes
-----
This function is excluded from the frame.

Definition at line 34 of file callStack.py.

34def getCallerFrame(relative=0):
35 """Get the frame for the user's caller.
36
37 Parameters
38 ----------
39 relative : `int`, optional
40 Number of frames (0 or more) above the caller to retrieve.
41 Default is 0.
42
43 Returns
44 -------
45 frame : `types.FrameType`
46 Frame for the caller.
47
48 Notes
49 -----
50 This function is excluded from the frame.
51 """
52 frame = inspect.currentframe().f_back.f_back # Our caller's caller
53 for ii in range(relative):
54 frame = frame.f_back
55 return frame
56
57

◆ getCallStack()

lsst.pex.config.callStack.getCallStack ( skip = 0)
Retrieve the call stack for the caller.

Parameters
----------
skip : `int`, non-negative
    Number of stack frames above caller to skip.

Returns
-------
output : `list` of `StackFrame`
    The call stack. The `list` is ordered with the most recent frame to
    last.

Notes
-----
This function is excluded from the call stack.

Definition at line 174 of file callStack.py.

174def getCallStack(skip=0):
175 """Retrieve the call stack for the caller.
176
177 Parameters
178 ----------
179 skip : `int`, non-negative
180 Number of stack frames above caller to skip.
181
182 Returns
183 -------
184 output : `list` of `StackFrame`
185 The call stack. The `list` is ordered with the most recent frame to
186 last.
187
188 Notes
189 -----
190 This function is excluded from the call stack.
191 """
192 frame = getCallerFrame(skip + 1)
193 stack = []
194 while frame:
195 stack.append(StackFrame.fromFrame(frame))
196 frame = frame.f_back
197 return list(reversed(stack))

◆ getStackFrame()

lsst.pex.config.callStack.getStackFrame ( relative = 0)
Get the `StackFrame` for the user's caller.

Parameters
----------
relative : `int`, optional
    Number of frames (0 or more) above the caller to retrieve.

Returns
-------
frame : `StackFrame`
    Stack frame for the caller.

Definition at line 58 of file callStack.py.

58def getStackFrame(relative=0):
59 """Get the `StackFrame` for the user's caller.
60
61 Parameters
62 ----------
63 relative : `int`, optional
64 Number of frames (0 or more) above the caller to retrieve.
65
66 Returns
67 -------
68 frame : `StackFrame`
69 Stack frame for the caller.
70 """
71 frame = getCallerFrame(relative + 1)
72 return StackFrame.fromFrame(frame)
73
74