Subversion Repositories Kolibri OS

Rev

Rev 1635 | Rev 2434 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | Download | RSS feed

  1. ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
  2. ;;                                                              ;;
  3. ;; Copyright (C) KolibriOS team 2004-2007. All rights reserved. ;;
  4. ;; Copyright (C) MenuetOS 2000-2004 Ville Mikael Turjanmaa      ;;
  5. ;; Distributed under terms of the GNU General Public License    ;;
  6. ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
  7.  
  8. $Revision: 2106 $
  9.  
  10. WINDOW_MOVE_AND_RESIZE_FLAGS = \
  11.   mouse.WINDOW_RESIZE_N_FLAG + \
  12.   mouse.WINDOW_RESIZE_W_FLAG + \
  13.   mouse.WINDOW_RESIZE_S_FLAG + \
  14.   mouse.WINDOW_RESIZE_E_FLAG + \
  15.   mouse.WINDOW_MOVE_FLAG
  16.  
  17. uglobal
  18. align 4
  19.   event_start   dd ?
  20.   event_end     dd ?
  21.   event_uid     dd 0
  22. endg
  23. EV_SPACE   = 512
  24. FreeEvents = event_start-EVENT.fd    ; "âèðòóàëüíûé" event, èñïîëüçóþòñÿ òîëüêî ïîëÿ:
  25.                                      ;  FreeEvents.fd=event_start è FreeEvents.bk=event_end
  26. align 4
  27. init_events:                                       ;; used from kernel.asm
  28.         stdcall kernel_alloc,EV_SPACE*EVENT.size
  29.         or      eax,eax
  30.         jz      .fail
  31.       ; eax - current event, ebx - previos event below
  32.         mov     ecx,EV_SPACE         ; current - in allocated space
  33.         mov     ebx,FreeEvents       ; previos - íà÷àëî ñïèñêà
  34.         push    ebx                  ; îíî æå è êîíåö ïîòîì áóäåò
  35.   @@:   mov     [ebx+EVENT.fd],eax
  36.         mov     [eax+EVENT.bk],ebx
  37.         mov     ebx,eax              ; previos <- current
  38.         add     eax,EVENT.size       ; new current
  39.         loop    @b
  40.         pop     eax                  ; âîò îíî êîíöîì è ñòàëî
  41.         mov     [ebx+EVENT.fd],eax
  42.         mov     [eax+EVENT.bk],ebx
  43. .fail:  ret
  44.  
  45. EVENT_WATCHED    equ 0x10000000 ;áèò 28
  46. EVENT_SIGNALED   equ 0x20000000 ;áèò 29
  47. MANUAL_RESET     equ 0x40000000 ;áèò 30
  48. MANUAL_DESTROY   equ 0x80000000 ;áèò 31
  49.  
  50. align 4
  51. create_event:                                      ;; EXPORT use
  52. ;info:
  53. ;   Ïåðåíîñèì EVENT èç ñïèñêà FreeEvents â ñïèñîê ObjList òåêóùåãî ñëîòà
  54. ;   EVENT.state óñòàíàâëèâàåì èç ecx, EVENT.code êîñâåííî èç esi (åñëè esi<>0)
  55. ;param:
  56. ;   esi - event data
  57. ;   ecx - flags
  58. ;retval:
  59. ;   eax - event (=0 => fail)
  60. ;   edx - uid
  61. ;scratched: ebx,ecx,esi,edi
  62.         mov     ebx,[current_slot]
  63.         add     ebx,APP_OBJ_OFFSET
  64.         mov     edx,[TASK_BASE]
  65.         mov     edx,[edx+TASKDATA.pid]
  66.         pushfd
  67.         cli
  68.  
  69. set_event:                                         ;; INTERNAL use !!! don't use for Call
  70. ;info:
  71. ;   Áåðåì íîâûé event èç FreeEvents, çàïîëíÿåì åãî ïîëÿ, êàê óêàçàíî â ecx,edx,esi
  72. ;   è óñòàíàâëèâàåì â ñïèñîê, óêàçàííûé â ebx.
  73. ;   Âîçâðàùàåì ñàì event (â eax), è åãî uid (â edx)
  74. ;param:
  75. ;   ebx - start-chain "virtual" event for entry new event Right of him
  76. ;   ecx - flags      (copied to EVENT.state)
  77. ;   edx - pid        (copied to EVENT.pid)
  78. ;   esi - event data (copied to EVENT.code indirect, =0 => skip)
  79. ;retval:
  80. ;   eax - event (=0 => fail)
  81. ;   edx - uid
  82. ;scratched: ebx,ecx,esi,edi
  83.         mov     eax,FreeEvents
  84.         cmp     eax,[eax+EVENT.fd]
  85.         jne     @f  ; not empty ???
  86.         pushad
  87.         call    init_events
  88.         popad
  89.         jz      RemoveEventTo.break ; POPF+RET
  90.   @@:   mov     eax,[eax+EVENT.fd]
  91.         mov     [eax+EVENT.magic],'EVNT'
  92.         mov     [eax+EVENT.destroy],destroy_event.internal
  93.         mov     [eax+EVENT.state],ecx
  94.         mov     [eax+EVENT.pid],edx
  95.         inc     [event_uid]
  96.         Mov     [eax+EVENT.id],edx,[event_uid]
  97.         or      esi,esi
  98.         jz      RemoveEventTo
  99.         lea     edi,[eax+EVENT.code]
  100.         mov     ecx,EVENT.codesize/4
  101.         cld
  102.         rep     movsd
  103.  
  104. RemoveEventTo:                                     ;; INTERNAL use !!! don't use for Call
  105. ;param:
  106. ;   eax - óêàçàòåëü íà event, ÊÎÒÎÐÛÉ âñòàâëÿåì
  107. ;   ebx - óêàçàòåëü íà event, ÏÎÑËÅ êîòîðîãî âñòàâëÿåì
  108. ;scratched: ebx,ecx
  109.         mov     ecx,eax              ; ecx=eax=Self,      ebx=NewLeft
  110.         xchg    ecx,[ebx+EVENT.fd]   ; NewLeft.fd=Self,   ecx=NewRight
  111.         cmp     eax,ecx              ; ñòîï, ñåáå äóìàþ...
  112.         je      .break               ; - à íå äóðàê ëè ÿ?
  113.         mov     [ecx+EVENT.bk],eax   ; NewRight.bk=Self
  114.         xchg    ebx,[eax+EVENT.bk]   ; Self.bk=NewLeft,   ebx=OldLeft
  115.         xchg    ecx,[eax+EVENT.fd]   ; Self.fd=NewRight,  ecx=OldRight
  116.         mov     [ebx+EVENT.fd],ecx   ; OldLeft.fd=OldRight
  117.         mov     [ecx+EVENT.bk],ebx   ; OldRight.bk=OldLeft
  118. .break: popfd
  119.         ret
  120.  
  121. align 4
  122. NotDummyTest:                                      ;; INTERNAL use (not returned for fail !!!)
  123.         pop     edi
  124.         call    DummyTest ; not returned for fail !!!
  125.         mov     ebx,eax
  126.         mov     eax,[ebx+EVENT.pid]
  127.         push    edi
  128. .small: ; êðèâî êàê-òî...
  129.         pop     edi
  130.         pushfd
  131.         cli
  132.         call    pid_to_slot ; saved all registers (eax - retval)
  133.         shl     eax,8
  134.         jz      RemoveEventTo.break ; POPF+RET
  135.         jmp     edi ; øòàòíûé âîçâðàò
  136.  
  137. align 4
  138. raise_event:                                       ;; EXPORT use
  139. ;info:
  140. ;   Óñòàíàâëèâàåì äàííûå EVENT.code
  141. ;   Åñëè òàì ôëàã EVENT_SIGNALED óæå àêòèâåí - áîëüøå íè÷åãî
  142. ;   Èíà÷å: ýòîò ôëàã âçâîäèòñÿ, çà èñêëþ÷åíèåì ñëó÷àÿ íàëè÷èÿ ôëàãà EVENT_WATCHED â edx
  143. ;    ýòîì ñëó÷àå EVENT_SIGNALED âçâîäèòñÿ ëèøü ïðè íàëè÷èå EVENT_WATCHED â ñàìîì ñîáûòèè
  144. ;param:
  145. ;   eax - event
  146. ;   ebx - uid (for Dummy testing)
  147. ;   edx - flags
  148. ;   esi - event data (=0 => skip)
  149. ;scratched: ebx,ecx,esi,edi
  150.         call    NotDummyTest ; not returned for fail !!!
  151.         or      esi,esi
  152.         jz      @f
  153.         lea     edi,[ebx+EVENT.code]
  154.         mov     ecx,EVENT.codesize/4
  155.         cld
  156.         rep     movsd
  157.   @@:
  158.         test    byte[ebx+EVENT.state+3], EVENT_SIGNALED shr 24
  159.         jnz     RemoveEventTo.break  ; POPF+RET
  160.         bt      edx, 28 ;EVENT_WATCHED
  161.         jnc     @f
  162.         test    byte[ebx+EVENT.state+3], EVENT_WATCHED  shr 24
  163.         jz      RemoveEventTo.break  ; POPF+RET
  164.   @@:
  165.         or      byte[ebx+EVENT.state+3], EVENT_SIGNALED shr 24
  166.         add     eax,SLOT_BASE+APP_EV_OFFSET
  167.         xchg    eax,ebx
  168.         jmp     RemoveEventTo
  169.  
  170. align 4
  171. clear_event:                                       ;; EXPORT use
  172. ;info:
  173. ;
  174. ;param:
  175. ;   eax - event
  176. ;   ebx - uid (for Dummy testing)
  177. ;scratched: ebx,ecx
  178.         call    NotDummyTest ; not returned for fail !!!
  179.         add     eax,SLOT_BASE+APP_OBJ_OFFSET
  180.         and     byte[ebx+EVENT.state+3], not((EVENT_SIGNALED+EVENT_WATCHED)shr 24)
  181.         xchg    eax,ebx
  182.         jmp     RemoveEventTo
  183.  
  184. align 4
  185. send_event:                                        ;; EXPORT use
  186. ;info:
  187. ;   Ñîçäàåò íîâûé EVENT (âûòàñêèâàåò èç ñïèñêà FreeEvents) â ñïèñêå EventList
  188. ;   öåëåâîãî ñëîòà (eax=pid), ñ äàííûìè èç esi êîñâåííî, è state=EVENT_SIGNALED
  189. ;param:
  190. ;   eax - slots pid, to sending new event
  191. ;   esi - pointer to sending data (in code field of new event)
  192. ;retval:
  193. ;   eax - event (=0 => fail)
  194. ;   edx - uid
  195. ;warning:
  196. ;   may be used as CDECL with such prefix...
  197. ;       mov     esi,[esp+8]
  198. ;       mov     eax,[esp+4]
  199. ;   but not as STDCALL :(
  200. ;scratched: ebx,ecx,esi,edi
  201.         mov     edx,eax
  202.         call    NotDummyTest.small ; not returned for fail !!!
  203.         lea     ebx,[eax+SLOT_BASE+APP_EV_OFFSET]
  204.         mov     ecx,EVENT_SIGNALED
  205.         jmp     set_event
  206.  
  207. align 4
  208. DummyTest:                                         ;; INTERNAL use (not returned for fail !!!)
  209. ;param:
  210. ;   eax - event
  211. ;   ebx - uid (for Dummy testing)
  212.         cmp     [eax+EVENT.magic],'EVNT'
  213.         jne     @f
  214.         cmp     [eax+EVENT.id],ebx
  215.         je      .ret
  216.   @@:   pop     eax
  217.         xor     eax,eax
  218. .ret:   ret
  219.  
  220.  
  221. align 4
  222. Wait_events:
  223.         or      ebx,-1 ; infinite timeout
  224. Wait_events_ex:
  225. ;info:
  226. ;   Îæèäàíèå "àáñòðàêòíîãî" ñîáûòèÿ ÷åðåç ïåðåâîä ñëîòà â 5-þ ïîçèöèþ.
  227. ;   Àáñòðàêòíîñòü çàêëþ÷åíà â òîì, ÷òî ôàêò ñîáûòèÿ îïðåäåëÿåòñÿ ôóíêöèåé APPDATA.wait_test,
  228. ;   êîòîðàÿ çàäàåòñÿ êëèåíòîì è ìîæåò áûòü ôàêòè÷åñêè ëþáîé.
  229. ;   Ýòî ïîçâîëÿåò shed-ó íàäåæíî îïðåäåëèòü ôàêò ñîáûòèÿ, è íå ñîâåðøàòü "õîëîñòûõ" ïåðåêëþ÷åíèé,
  230. ;   ïðåäíàçíà÷åííûõ äëÿ ðàçáîðîê òèïà "ñâîé/÷óæîé" âíóòðè çàäà÷è.
  231. ;param:
  232. ;   edx - wait_test, êëèåíòñêàÿ ô-ÿ òåñòèðîâàíèÿ (àäðåñ êîäà)
  233. ;   ecx - wait_param, äîïîëíèòåëüíûé ïàðàìåòð, âîçìîæíî íåîáõîäèìûé äëÿ [wait_test]
  234. ;   ebx - wait_timeout
  235. ;retval:
  236. ;   eax - ðåçóëüòàò âûçîâà [wait_test] (=0 => timeout)
  237. ;scratched: esi
  238.         mov     esi,[current_slot]
  239.         mov     [esi+APPDATA.wait_param],ecx
  240.         pushad
  241.         mov     ebx,esi;ïîêà ýòî âîïðîñ, ÷åãî êóäû ñóâàòü..........
  242.         pushfd  ; ýòî ñëåäñòâèå îáùåé êîíöåïöèè: ïóñòü ô-ÿ òåñòèðîâàíèÿ èìååò
  243.         cli     ; ïðàâî ðàññ÷èòûâàòü íà çàêðûòûå ïðåðûâàíèÿ, êàê ïðè âûçîâå èç shed
  244.         call    edx
  245.         popfd
  246.         mov     [esp+28],eax
  247.         popad
  248.         or      eax,eax
  249.         jnz     @f   ;RET
  250.         mov     [esi+APPDATA.wait_test],edx
  251.         mov     [esi+APPDATA.wait_timeout],ebx
  252.         Mov     [esi+APPDATA.wait_begin],eax,[timer_ticks]
  253.         mov     eax,[TASK_BASE]
  254.         mov     [eax+TASKDATA.state], 5
  255.         call    change_task
  256.         mov     eax,[esi+APPDATA.wait_param]
  257.   @@:   ret
  258.  
  259. align 4
  260. wait_event:                                        ;; EXPORT use
  261. ;info:
  262. ;   Îæèäàíèå ôëàãà EVENT_SIGNALED â ñîâåðøåííî êîíêðåòíîì Event
  263. ;   (óñòàíàâëèâàåìîãî, íàäî ïîëàãàòü, ÷åðåç raise_event)
  264. ;   Ïðè àêòèâíîì ôëàãå MANUAL_RESET - áîëüøå íè÷åãî
  265. ;   Èíà÷å: ôëàãè EVENT_SIGNALED è EVENT_WATCHED ó ïîëó÷åííîãî ñîáûòèÿ ñáðàñûâàþòñÿ,
  266. ;   è, ïðè àêòèâíîì MANUAL_DESTROY - ïåðåìåùàåòñÿ â ñïèñîê ObjList òåêóùåãî ñëîòà,
  267. ;   à ïðè íå àêòèâíîì - óíè÷òîæàåòñÿ øòàòíî (destroy_event.internal)
  268. ;param:
  269. ;   eax - event
  270. ;   ebx - uid (for Dummy testing)
  271. ;scratched: ecx,edx,esi
  272.         call    DummyTest
  273.         mov     ecx,eax              ; wait_param
  274.         mov     edx, get_event_alone ; wait_test
  275.         call    Wait_events          ; timeout ignored
  276.         jmp     wait_finish
  277.  
  278. align 4
  279. get_event_ex:                                      ;; f68:14
  280. ;info:
  281. ;   Îæèäàíèå ëþáîãî ñîáûòèÿ â î÷åðåäè EventList òåêóùåãî ñëîòà
  282. ;   Äàííûå ñîáûòèÿ code - êîïèðóþòñÿ â ïàìÿòü ïðèëîæåíèÿ (êîñâåííî ïî edi)
  283. ;   Ïðè àêòèâíîì ôëàãå MANUAL_RESET - áîëüøå íè÷åãî
  284. ;   Èíà÷å: ôëàãè EVENT_SIGNALED è EVENT_WATCHED ó ïîëó÷åííîãî ñîáûòèÿ ñáðàñûâàþòñÿ,
  285. ;   è, ïðè àêòèâíîì MANUAL_DESTROY - ïåðåìåùàåòñÿ â ñïèñîê ObjList òåêóùåãî ñëîòà,
  286. ;   à ïðè íå àêòèâíîì - óíè÷òîæàåòñÿ øòàòíî (destroy_event.internal)
  287. ;param:
  288. ;   edi - àäðåñ â êîäå ïðèëîæåíèÿ äëÿ êîïèðîâàíèÿ äàííûõ èç EVENT.code
  289. ;retval:
  290. ;   eax - ñîáñòâåííî EVENT (áóäåì íàçûâàòü ýòî åãî õýíäëîì)
  291. ;scratched: ebx,ecx,edx,esi,edi
  292.         mov     edx, get_event_queue ; wait_test
  293.         call    Wait_events          ; timeout ignored
  294.         lea     esi,[eax+EVENT.code]
  295.         mov     ecx,EVENT.codesize/4
  296.         cld
  297.         rep     movsd
  298.         mov     [edi-EVENT.codesize+2],cl ;clear priority field
  299. wait_finish:
  300.         test    byte[eax+EVENT.state+3], MANUAL_RESET shr 24
  301.         jnz     get_event_queue.ret  ; RET
  302.         and     byte[eax+EVENT.state+3], not((EVENT_SIGNALED+EVENT_WATCHED)shr 24)
  303.         test    byte[eax+EVENT.state+3], MANUAL_DESTROY shr 24
  304.         jz      destroy_event.internal
  305.         mov     ebx,[current_slot]
  306.         add     ebx,APP_OBJ_OFFSET
  307.         pushfd
  308.         cli
  309.         jmp     RemoveEventTo
  310.  
  311. align 4
  312. destroy_event:                                     ;; EXPORT use
  313. ;info:
  314. ;   Ïåðåíîñèì EVENT â ñïèñîê FreeEvents, ÷èñòèì ïîëÿ magic,destroy,pid,id
  315. ;param:
  316. ;   eax - event
  317. ;   ebx - uid (for Dummy testing)
  318. ;retval:
  319. ;   eax - àäðåñ îáúåêòà EVENT (=0 => fail)
  320. ;scratched: ebx,ecx
  321.         call    DummyTest ; not returned for fail !!!
  322. .internal:
  323.         xor     ecx,ecx   ; clear common header
  324.         pushfd
  325.         cli
  326.         mov     [eax+EVENT.magic],ecx
  327.         mov     [eax+EVENT.destroy],ecx
  328.         mov     [eax+EVENT.pid],ecx
  329.         mov     [eax+EVENT.id],ecx
  330.         mov     ebx,FreeEvents
  331.         jmp     RemoveEventTo
  332.  
  333. align 4
  334. get_event_queue:
  335. ;info:
  336. ;   êëèåíòñêàÿ ô-ÿ òåñòèðîâàíèÿ äëÿ get_event_ex
  337. ;warning:
  338. ;  -don't use [TASK_BASE],[current_slot],[CURRENT_TASK] - it is not for your slot
  339. ;  -may be assumed, that interrupt are disabled
  340. ;  -it is not restriction for scratched registers
  341. ;param:
  342. ;   ebx - àäðåñ APPDATA ñëîòà òåñòèðîâàíèÿ
  343. ;retval:
  344. ;   eax - àäðåñ îáúåêòà EVENT (=0 => fail)
  345.         add     ebx,APP_EV_OFFSET
  346.         mov     eax,[ebx+APPOBJ.bk]  ; âûáèðàåì ñ êîíöà, ïî ïðèíöèïó FIFO
  347.         cmp     eax,ebx  ; empty ???
  348.         je      get_event_alone.ret0
  349. .ret:   ret
  350.  
  351. align 4
  352. get_event_alone:
  353. ;info:
  354. ;   êëèåíòñêàÿ ô-ÿ òåñòèðîâàíèÿ äëÿ wait_event
  355. ;warning:
  356. ;  -don't use [TASK_BASE],[current_slot],[CURRENT_TASK] - it is not for your slot
  357. ;  -may be assumed, that interrupt are disabled
  358. ;  -it is not restriction for scratched registers
  359. ;param:
  360. ;   ebx - àäðåñ APPDATA ñëîòà òåñòèðîâàíèÿ
  361. ;retval:
  362. ;   eax - àäðåñ îáúåêòà EVENT (=0 => fail)
  363.         mov     eax,[ebx+APPDATA.wait_param]
  364.         test    byte[eax+EVENT.state+3], EVENT_SIGNALED shr 24
  365.         jnz     .ret
  366.         or      byte[eax+EVENT.state+3], EVENT_WATCHED shr 24
  367. .ret0:  xor     eax,eax ; NO event!!!
  368. .ret:   ret
  369.  
  370. align 4
  371. sys_sendwindowmsg:                                 ;; f72
  372.         dec     ebx
  373.         jnz     .ret ;subfunction==1 ?
  374.        ;pushfd  ;à íàôèãà?
  375.         cli
  376.         sub     ecx,2
  377.         je      .sendkey
  378.         dec     ecx
  379.         jnz     .retf
  380. .sendbtn:
  381.         cmp     byte[BTN_COUNT],1
  382.         jae     .result ;overflow
  383.         inc     byte[BTN_COUNT]
  384.         shl     edx, 8
  385.         mov     [BTN_BUFF],edx
  386.         jmp     .result
  387. .sendkey:
  388.         movzx   eax,byte[KEY_COUNT]
  389.         cmp     al,120
  390.         jae     .result ;overflow
  391.         inc     byte[KEY_COUNT]
  392.         mov     [KEY_COUNT+1+eax],dl
  393. .result:
  394.         setae   byte[esp+32] ;ñ÷èòàåì, ÷òî èñõîäíî: dword[esp+32]==72
  395. .retf: ;popfd
  396. .ret:   ret
  397.  
  398. align 4
  399. sys_getevent:                                      ;; f11
  400.         mov     ebx,[current_slot] ;ïîêà ýòî âîïðîñ, ÷åãî êóäû ñóâàòü..........
  401.         pushfd  ; ýòî ñëåäñòâèå îáùåé êîíöåïöèè: ïóñòü ô-ÿ òåñòèðîâàíèÿ èìååò
  402.         cli     ; ïðàâî ðàññ÷èòûâàòü íà çàêðûòûå ïðåðûâàíèÿ, êàê ïðè âûçîâå èç shed
  403.         call    get_event_for_app
  404.         popfd
  405.         mov     [esp+32],eax
  406.         ret
  407.  
  408. align 4
  409. sys_waitforevent:                                  ;; f10
  410.         or      ebx,-1 ; infinite timeout
  411. sys_wait_event_timeout:                            ;; f23
  412.         mov     edx,get_event_for_app ; wait_test
  413.         call    Wait_events_ex        ; ebx - timeout
  414.         mov     [esp+32],eax
  415.         ret
  416.  
  417. align 4
  418. get_event_for_app:                                 ;; used from f10,f11,f23
  419. ;info:
  420. ;   êëèåíòñêàÿ ô-ÿ òåñòèðîâàíèÿ äëÿ ïðèëîæåíèé (f10,f23)
  421. ;warning:
  422. ;  -don't use [TASK_BASE],[current_slot],[CURRENT_TASK] - it is not for your slot
  423. ;  -may be assumed, that interrupt are disabled
  424. ;  -it is not restriction for scratched registers
  425. ;param:
  426. ;   ebx - àäðåñ APPDATA ñëîòà òåñòèðîâàíèÿ
  427. ;retval:
  428. ;   eax - íîìåð ñîáûòèÿ (=0 => no events)
  429.         movzx   edi,bh                ; bh  is assumed as [CURRENT_TASK]
  430.         shl     edi,5
  431.         add     edi,CURRENT_TASK      ; edi is assumed as [TASK_BASE]
  432.         mov     ecx,[edi+TASKDATA.event_mask]
  433. .loop: ; ïîêà íå èñ÷åðïàåì âñå áèòû ìàñêè
  434.         bsr     eax,ecx        ; íàõîäèì íåíóëåâîé áèò ìàñêè (31 -> 0)
  435.         jz      .no_events     ; èñ÷åðïàëè âñå áèòû ìàñêè, íî íè÷åãî íå íàøëè ???
  436.         btr     ecx,eax        ; ñáðàñûâàåì ïðîâåðÿåìûé áèò ìàñêè
  437.        ; ïåðåõîäèì íà îáðàáîò÷èê ýòîãî (eax) áèòà
  438.         cmp     eax,9
  439.         jae     .loop          ; eax=[9..31], ignored
  440.         cmp     eax,3
  441.         je      .loop          ; eax=3, ignored
  442.         ja      .FlagAutoReset ; eax=[4..8], retvals=eax+1
  443.         cmp     eax,1
  444.         jae     .BtKy          ; eax=[1,2],  retvals=eax+1
  445. .WndRedraw:                    ; eax=0, retval WndRedraw=1
  446.         cmp     [edi-twdw+WDATA.fl_redraw],al ;al==0
  447.         jne     .result
  448.         jmp     .loop
  449.   .no_events:
  450.         xor     eax,eax
  451.         ret
  452.  
  453. .FlagAutoReset: ; retvals: BgrRedraw=5, Mouse=6, IPC=7, Stack=8, Debug=9
  454.         cmp     eax,5 ; Mouse 5+1=6
  455.         jne     @f
  456.         push    eax
  457. ; If the window is captured and moved by the user, then no mouse events!!!
  458.         mov     al,[mouse.active_sys_window.action]
  459.                 and     al,WINDOW_MOVE_AND_RESIZE_FLAGS
  460.         test    al,al
  461.         pop     eax
  462.         jnz     .loop
  463. @@:
  464.         btr     [ebx+APPDATA.event_mask],eax
  465.         jnc     .loop
  466.   .result:      ; retval = eax+1
  467.         inc     eax
  468.         ret
  469.   .BtKy:
  470.         movzx   edx,bh
  471.         movzx   edx, word[WIN_STACK+edx*2]
  472.         je      .Keys          ; eax=1, retval Keys=2
  473. .Buttons:                      ; eax=2, retval Buttons=3
  474.         cmp     byte[BTN_COUNT],0
  475.         je      .loop          ; empty ???
  476.         cmp     edx,[TASK_COUNT]
  477.         jne     .loop          ; not Top ???
  478.         mov     edx, [BTN_BUFF]
  479.         shr     edx, 8
  480.         cmp     edx, 0xFFFF    ;-ID for Minimize-Button of Form
  481.         jne     .result
  482.         mov     [window_minimize],1
  483.         dec     byte[BTN_COUNT]
  484.         jmp     .loop
  485. .Keys:    ; eax==1
  486.         cmp     edx,[TASK_COUNT]
  487.         jne     @f             ; not Top ???
  488.         cmp     [KEY_COUNT],al ; al==1
  489.         jae     .result        ; not empty ???
  490.   @@:   mov     edx, hotkey_buffer
  491.   @@:   cmp     [edx],bh       ; bh - slot for testing
  492.         je      .result
  493.         add     edx,8
  494.         cmp     edx, hotkey_buffer+120*8
  495.         jb      @b
  496.         jmp     .loop
  497. ;end.
  498.