bpo-33165: Remove redundant stack unwind for findCaller()#17714
Closed
evandrocoan wants to merge 2 commits intopython:mainfrom
Closed
bpo-33165: Remove redundant stack unwind for findCaller()#17714evandrocoan wants to merge 2 commits intopython:mainfrom
evandrocoan wants to merge 2 commits intopython:mainfrom
Conversation
the right frame on Lib/logging/__init__.py:currentframe()
because when extending the default Logger and implementing/specializing the `_log` function, all stacktraces need to be increased by 1. For example, the debug_tools pypi module inherits from Logger and defines its own _log() function: https://github.com/evandrocoan/debugtools/blob/d279bf3278f501294a72159f3aa189b7237528b2/all/debug_tools/logger.py#L166 https://github.com/evandrocoan/debugtools/blob/d279bf3278f501294a72159f3aa189b7237528b2/all/debug_tools/logger.py#L970 https://github.com/evandrocoan/debugtools/blob/d279bf3278f501294a72159f3aa189b7237528b2/all/debug_tools/logger.py#L1317
evandrocoan
added a commit
to evandrocoan/debugtools
that referenced
this pull request
Dec 27, 2019
bpo-33165: Remove redundant stack unwind for findCaller() python/cpython#17714
evandrocoan
added a commit
to evandrocoan/debugtools
that referenced
this pull request
Dec 27, 2019
bpo-33165: Remove redundant stack unwind for findCaller() python/cpython#17714
| file name, line number and function name. | ||
| """ | ||
| f = currentframe() | ||
| f = currentframe(self.default_stack_level + stacklevel) |
Contributor
There was a problem hiding this comment.
Shouldn't the unwinding really be done later? A few lines down, we read:
while hasattr(f, "f_code"):
co = f.f_code
filename = os.path.normcase(co.co_filename)
if filename == _srcfile:
f = f.f_back
continueThis 'escapes' the stack frames generated inside the current file. I would expect any additional stacklevel treatment to happen afterwards.
As a result of the current implementation (with or without the proposed changes in the current PR), the stacklevel parameter to .warn must be one higher than the parameter to .warning in order to get to the same frame.
| raise Exception | ||
| except Exception: | ||
| return sys.exc_info()[2].tb_frame.f_back | ||
| return sys.exc_info()[level-1].tb_frame.f_back |
Contributor
There was a problem hiding this comment.
I believe this is incorrect. exc_info returns three items and probably all we can do is
Suggested change
| return sys.exc_info()[level-1].tb_frame.f_back | |
| frame = sys.exc_info()[2].tb_frame.f_back | |
| while frame and stacklevel > 0: | |
| frame = frame.f_back | |
| stacklevel -= 1 | |
| if not frame: | |
| raise ValueError("call stack is not deep enough") | |
| return frame |
Contributor
Author
|
This was already fixed/implemented by dde9fdb |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
by directly getting the right frame on Lib/logging/init.py:currentframe()
This is a slight improvement for #7424 (bpo-33165: Added stacklevel parameter to logging APIs)
Instead of getting the fullstack trace and only then unwind the desired frames, just pass the required frame index and get it directly, i.e., without "unstacking" n frames.
I also added the frame level as a Logger attribute because when extending the default Logger and implementing/specializing the
_logfunction, all stacktraces need to be increased by 1. For example, the debug_tools pypi module inherits from Logger and defines its own _log() function:https://github.com/evandrocoan/debugtools/blob/d279bf3278f501294a72159f3aa189b7237528b2/all/debug_tools/logger.py#L166
https://github.com/evandrocoan/debugtools/blob/d279bf3278f501294a72159f3aa189b7237528b2/all/debug_tools/logger.py#L970
https://github.com/evandrocoan/debugtools/blob/d279bf3278f501294a72159f3aa189b7237528b2/all/debug_tools/logger.py#L1317
https://bugs.python.org/issue33165