summaryrefslogtreecommitdiffstats
path: root/generic/tkUtil.c
diff options
context:
space:
mode:
authorfvogel <fvogelnew1@free.fr>2016-05-20 15:43:02 (GMT)
committerfvogel <fvogelnew1@free.fr>2016-05-20 15:43:02 (GMT)
commit0529352ef03d575aa2df3317cd1e3145209c5292 (patch)
tree8b543030b85167824d0f31f1c0d3ce71a9782f92 /generic/tkUtil.c
parent1a64042e82238940c820745c5057df95c98e1c5d (diff)
parent2f150c8d18e576998e9d30ac08c562a1365b3051 (diff)
downloadtk-multiscreens.zip
tk-multiscreens.tar.gz
tk-multiscreens.tar.bz2
Merged core-8-6-branchmultiscreens
Diffstat (limited to 'generic/tkUtil.c')
-rw-r--r--generic/tkUtil.c9
1 files changed, 7 insertions, 2 deletions
diff --git a/generic/tkUtil.c b/generic/tkUtil.c
index 7ff9ecb..6563165 100644
--- a/generic/tkUtil.c
+++ b/generic/tkUtil.c
@@ -1162,7 +1162,8 @@ TkMakeEnsemble(
* TkSendVirtualEvent --
*
* Send a virtual event notification to the specified target window.
- * Equivalent to "event generate $target <<$eventName>>"
+ * Equivalent to:
+ * "event generate $target <<$eventName>> -data $detail"
*
* Note that we use Tk_QueueWindowEvent, not Tk_HandleEvent, so this
* routine does not reenter the interpreter.
@@ -1173,7 +1174,8 @@ TkMakeEnsemble(
void
TkSendVirtualEvent(
Tk_Window target,
- const char *eventName)
+ const char *eventName,
+ Tcl_Obj *detail)
{
union {XEvent general; XVirtualEvent virtual;} event;
@@ -1184,6 +1186,9 @@ TkSendVirtualEvent(
event.general.xany.window = Tk_WindowId(target);
event.general.xany.display = Tk_Display(target);
event.virtual.name = Tk_GetUid(eventName);
+ if (detail != NULL) {
+ event.virtual.user_data = detail;
+ }
Tk_QueueWindowEvent(&event.general, TCL_QUEUE_TAIL);
}