2 Copyright © 1995-2011, The AROS Development Team. All rights reserved.
3 Copyright © 2001-2003, The MorphOS Development Team. All Rights Reserved.
7 #include <proto/timer.h>
8 #include "intuition_intern.h"
10 #define DEBUG_SENDINTUIMESSAGE(x) ;
11 /*****i***********************************************************************
14 #include <proto/intuition.h>
16 AROS_LH2(void, SendIntuiMessage
,
19 AROS_LHA(struct Window
*, window
, A0
),
20 AROS_LHA(struct IntuiMessage
*, imsg
, A1
),
23 struct IntuitionBase
*, IntuitionBase
, 151, Intuition
)
26 Private: send an IntuiMessage to an Intuition window
29 window - The window to which the IntuiMessage shall be sent
30 imsg - The IntuiMessage to send, which must have been allocated with
37 The caller of this function should first check himself
38 whether window->UserPort is NULL. And in this case do not
39 call this function at all.
41 If inside this function the window->UserPort turns out to
42 be NULL, then what happens is, that the IntuiMessage is
43 immediately ReplyMessage()ed in here, just like if this was
44 done by the app whose window was supposed to get the
47 The protection with Forbid() is necessary, because of the
48 way shared window userports are handled, when one of this
49 windows is closed, where there is also just a protection with
50 Forbid() when stripping those IntuiMessages from the port
51 which belong to the window which is going to be closed.
53 This function does not check whether the window to which
54 the IntuiMessage is supposed to be sent, really wants to
55 get the IDCMP in question, that is, whether the corresponding
56 flag in window->IDCMPFLags is set.
67 *****************************************************************************/
71 ASSERT_VALID_PTR(window
);
72 ASSERT_VALID_PTR(imsg
);
74 struct Library
*TimerBase
= GetPrivIBase(IntuitionBase
)->TimerBase
;
76 DEBUG_SENDINTUIMESSAGE(dprintf("SendIntuiMessage: Window 0x%lx Port 0x%lx Msg 0x%lx\n",
77 window
, window
->UserPort
, imsg
));
87 struct Task
*apptask
= window
->UserPort
->mp_SigTask
;
89 if (apptask
&& (!apptask
->tc_SigWait
) && (apptask
->tc_State
== TS_WAIT
))
92 imsg
->IDCMPWindow
= 0;
95 ReplyMsg(&imsg
->ExecMessage
);
97 if (IW(window
)->messagecache
)
99 IW(window
)->messagecache
->IDCMPWindow
= 0;
100 IW(window
)->messagecache
->Code
= 0;
101 IW(window
)->messagecache
->Qualifier
= 0;
102 ReplyMsg(&IW(window
)->messagecache
->ExecMessage
);
103 IW(window
)->messagecache
= 0;
107 //give some visual feedback to the user
108 IW(window
)->specialflags
|= SPFLAG_IAMDEAD
;
110 int_refreshwindowframe(window
,REFRESHGAD_TOPBORDER
,0,IntuitionBase
);
116 IW(window
)->specialflags
&= ~SPFLAG_IAMDEAD
;
121 if (imsg
->Qualifier
& IEQUALIFIER_REPEAT
)
123 IW(window
)->num_repeatevents
++;
126 #if USE_IDCMPUPDATE_MESSAGECACHE
127 if (imsg
->Class
== IDCMP_IDCMPUPDATE
)
129 if (IW(window
)->num_idcmpupdate
&& !IW(window
)->messagecache
)
131 kprintf("======= setting messagecache\n");
132 IW(window
)->messagecache
= imsg
;
137 //reduce number of messages if possible (prop updates only!)
138 if (IW(window
)->num_idcmpupdate
&& IW(window
)->messagecache
)
140 if (imsg
->Code
== IW(window
)->messagecache
->Code
&& imsg
->Qualifier
== IEQUALIFIER_REPEAT
)
142 IW(window
)->messagecache
->MouseX
= imsg
->MouseX
;
143 IW(window
)->messagecache
->MouseY
= imsg
->MouseY
;
144 IW(window
)->messagecache
->Seconds
= imsg
->Seconds
;
145 IW(window
)->messagecache
->Micros
= imsg
->Micros
;
146 imsg
->IDCMPWindow
= 0;
149 ReplyMsg(&imsg
->ExecMessage
);
155 IW(window
)->num_idcmpupdate
++;
160 GetSysTime(&((struct IntWindow
*)(window
))->lastmsgsent
);
163 if (window
->UserPort
)
165 if (imsg
->Class
== IDCMP_INTUITICKS
)
167 window
->Flags
|= WFLG_WINDOWTICKED
;
169 DEBUG_SENDINTUIMESSAGE(dprintf("SendIntuiMessage: Class 0x%lx Code 0x%lx Qual 0x%lx Mouse %d,%d IAddress 0x%lx\n", imsg
->Class
, imsg
->Code
, imsg
->Qualifier
, imsg
->MouseX
, imsg
->MouseY
, imsg
->IAddress
));
171 PutMsg(window
->UserPort
, &imsg
->ExecMessage
);
173 /* Help sucky programs... (die DigiBooster, die!) */
174 window
->MessageKey
= imsg
;
178 ReplyMsg(&imsg
->ExecMessage
);