Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Get the correct computed tb lineno #158

Merged

Conversation

jmao-denver
Copy link
Contributor

@jmao-denver jmao-denver commented Aug 8, 2024

Fix for python/cpython#109181 introduced lazily computed lineno for traceback object in 3.11.7 and 3.12.1. Tested in a number of Python versions, the change seems to be safe.

The problem was initially reported in deephaven/vscode-deephaven#9

Fix for python/cpython#109181 introduced
lazily computed lineno for traceback object in 3.11.7 and 3.12.1.
Tested in a number of Python versions, the change seems to be safe.
@jmao-denver jmao-denver self-assigned this Aug 8, 2024
@jmao-denver jmao-denver requested a review from chipkent August 9, 2024 19:51
Copy link
Member

@devinrsmith devinrsmith left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This does point out that we need to be careful when accessing c python structs that don't have proper / stable APIs. To be technically safe, we would need to be using using PyObject_GetAttrString to access attributes everywhere instead of assuming simple c struct access.

For example, while we are "ok" accessing tb->tb_next as a proxy for the tb_next attribute (https://docs.python.org/3/reference/datamodel.html#traceback.tb_next) a similar change could happen in the future where we'd need to go the official route to access the attribute. https://github.com/python/cpython/blob/v3.12.5/Python/traceback.c#L100-L108

@@ -25,7 +25,7 @@ jobs:
distribution: 'temurin'
java-version: ${{ matrix.java }}

- run: pip install setuptools
- run: pip install "setuptools < 72"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why do we need to limit setuptools?

Copy link
Contributor Author

@jmao-denver jmao-denver Aug 12, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We reply on setuptools.command.test to run the test suite. See pypa/setuptools#4519 and a solution is out of scope for now. will create a ticket.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

#160 is filed.

Comment on lines +2733 to +2738
static int get_traceback_lineno(PyTracebackObject *tb) {
PyObject* po_lineno = PyObject_GetAttrString((PyObject*)tb, "tb_lineno");
int lineno = (int)PyLong_AsLong(po_lineno);
JPy_DECREF(po_lineno);
return lineno;
}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Took me a little bit to figure out what actually changed. python/cpython#111548 is a useful reference. I'm a bit surprised there's not a more official stable API around PyTracebackObject. I understand the need to wash through PyObject_GetAttrString in this case, but I'm sad.

Does calling PyObject_GetAttrString actually set tb->tb_lineno? I can't tell from the linked PR if that's actually what python does in this case. From the description of the patch

Speed up :obj:Traceback object creation by lazily compute the line number.

it's seems to me that "lazily" means that it will be cached after first access? (If that is not the case, it seems like tb->tb_lineno is completely useless and unused?)

Assuming "yes", we could probably check tb->tb_lineno == -1 before doing the more expensive call?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No, and PyTracebackObject isn't part of the public stable API, so they are free to change the struct itself and how to use it.

@devinrsmith devinrsmith merged commit 498cf19 into jpy-consortium:master Aug 12, 2024
52 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants