gh-47655: Add support for user data of Tk virtual events to tkinter#7142
gh-47655: Add support for user data of Tk virtual events to tkinter#7142serhiy-storchaka merged 9 commits into
Conversation
|
Hello, and thanks for your contribution! I'm a bot set up to make sure that the project can legally accept your contribution by verifying you have signed the PSF contributor agreement (CLA). Unfortunately our records indicate you have not signed the CLA. For legal reasons we need you to sign this before we can look at your contribution. Please follow the steps outlined in the CPython devguide to rectify this issue. When your account is ready, please add a comment in this pull request Thanks again to your contribution and we look forward to looking at it! |
Sorry, something went wrong.
|
I see a "Contributor Form Received: Yes" now on my account on bpo. So CLA has arrived. |
Sorry, something went wrong.
|
@the-knights-who-say-ni , what is missing? Why it is not accepted yet?
Those erros are not related to tkinter |
Sorry, something went wrong.
koutoftimer
left a comment
There was a problem hiding this comment.
Verified for Python 3.7.3 win64.
Sorry, something went wrong.
|
I have not seen any news about this issue after the migration, but it looks like this is the most complete patch. @serhiy-storchaka could anything else be done to help with this review? |
Sorry, something went wrong.
|
This PR is stale because it has been open for 30 days with no activity. |
Sorry, something went wrong.
|
This PR is stale because it has been open for 30 days with no activity. |
Sorry, something went wrong.
|
This PR is stale because it has been open for 30 days with no activity. |
Sorry, something went wrong.
|
This PR is stale because it has been open for 30 days with no activity. |
Sorry, something went wrong.
|
Ping. |
Sorry, something went wrong.
|
This PR is stale because it has been open for 30 days with no activity. |
Sorry, something went wrong.
|
Ping. |
Sorry, something went wrong.
|
Thank you for reminder @ZelphirKaltstahl. I'm going to finish this. Sorry that it took so much time, @mkiever. For now, I have the following comments:
If you have no time, @mkiever, or lost interest, I'll continue this work, preserving your credits. |
Sorry, something went wrong.
There are also mentioning of Both The UPD: |
Sorry, something went wrong.
|
Well, lets keep As for the WidgetViewSync event, this is an error in the documentation. All virtual events have field case 'd':
if (flags & (CROSSING|FOCUS)) {
int detail = (flags & FOCUS) ? evPtr->xfocus.detail : evPtr->xcrossing.detail;
string = TkFindStateString(notifyDetail, detail);
} else if (flags & CONFIGREQ) {
if (evPtr->xconfigurerequest.value_mask & CWStackMode) {
string = TkFindStateString(configureRequestDetail, evPtr->xconfigurerequest.detail);
} else {
string = "";
}
} else if (flags & VIRTUAL) {
XVirtualEvent *vePtr = (XVirtualEvent *) evPtr;
string = vePtr->user_data ? Tcl_GetString(vePtr->user_data) : "";
}
break; |
Sorry, something went wrong.
If you are talking about this As for |
Sorry, something went wrong.
|
Yes, this XEvent. It is a union of different structs that correspond different event types. Each substitution usually corresponds to fields with the same name in different structures. Except "%d", which correspond to |
Sorry, something went wrong.
|
This PR is stale because it has been open for 30 days with no activity. |
Sorry, something went wrong.
f8ce51a
into
python:main
Feb 25, 2026
…tkinter (pythonGH-7142) Expose the %d substitution as the tkinter.Event attributes: * "detail" for Enter, Leave, FocusIn, FocusOut, and ConfigureRequest events * "user_data" for virtual events Co-authored-by: Serhiy Storchaka <storchaka@gmail.com>
…tkinter (pythonGH-7142) Expose the %d substitution as the tkinter.Event attributes: * "detail" for Enter, Leave, FocusIn, FocusOut, and ConfigureRequest events * "user_data" for virtual events Co-authored-by: Serhiy Storchaka <storchaka@gmail.com>
This adds Tk %d event field as 'detail' and 'user_data' attributes to tkinter events.
I have not yet changed the documentation, because I am not sure about the intent
of the table in "25.1.6.7. Bindings and Events" in tkinter documentation.
If supposed to be complete, I suggest also adding the other three missing fields (%#, %b, %D).
I have added a simple test of virtual events and the userdata attribute including bind/unbind.
To make the test possible I use a pump_events function found on
stackoverflow (https://stackoverflow.com/questions/4083796/how-do-i-run-unittest-on-a-tkinter-app/49028688#49028688).
Note, I tested this only on Debian Linux.
Also, I had spurious "Bad Drawable" errors from the X server running the tkinter unittest,
but I have those in the same way on the changed and unchanged Python.
Seems to be my non-mainstream setup (ctwm with interactive window placement).
This is my first pull request. Sorry, if I have forgotten obvious things.
https://bugs.python.org/issue3405