Subversion Repositories Kolibri OS

Rev

Rev 2385 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
431 serge 1
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2
;;                                                              ;;
2540 hidnplayr 3
;; Copyright (C) KolibriOS team 2004-2012. All rights reserved. ;;
431 serge 4
;; Copyright (C) MenuetOS 2000-2004 Ville Mikael Turjanmaa      ;;
5
;; Distributed under terms of the GNU General Public License    ;;
6
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
227 serge 7
 
2540 hidnplayr 8
$Revision $
593 mikedld 9
 
2382 hidnplayr 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
 
1055 Galkov 17
uglobal
227 serge 18
align 4
1055 Galkov 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, используются только поля:
2540 hidnplayr 25
                                     ;  FreeEvents.fd=event_start и FreeEvents.bk=event_end
26
;-----------------------------------------------------------------------------
27
align 4
28
init_events:                                       ;; used from kernel.asm
29
        stdcall kernel_alloc, EV_SPACE*sizeof.EVENT
30
        or      eax, eax
31
        jz      .fail
32
      ; eax - current event, ebx - previos event below
2382 hidnplayr 33
        mov     ecx, EV_SPACE        ; current - in allocated space
34
        mov     ebx, FreeEvents      ; previos - начало списка
1055 Galkov 35
        push    ebx                  ; оно же и конец потом будет
2540 hidnplayr 36
;--------------------------------------
37
align 4
38
@@:
39
        mov     [ebx+EVENT.fd], eax
2382 hidnplayr 40
        mov     [eax+EVENT.bk], ebx
2540 hidnplayr 41
        mov     ebx, eax             ; previos <- current
42
        add     eax, sizeof.EVENT    ; new current
43
        loop    @b
44
        pop     eax                  ; вот оно концом и стало
45
        mov     [ebx+EVENT.fd], eax
46
        mov     [eax+EVENT.bk], ebx
47
;--------------------------------------
48
align 4
2382 hidnplayr 49
.fail:
50
        ret
2540 hidnplayr 51
;-----------------------------------------------------------------------------
1055 Galkov 52
EVENT_WATCHED    equ 0x10000000 ;бит 28
53
EVENT_SIGNALED   equ 0x20000000 ;бит 29
54
MANUAL_RESET     equ 0x40000000 ;бит 30
55
MANUAL_DESTROY   equ 0x80000000 ;бит 31
2540 hidnplayr 56
;-----------------------------------------------------------------------------
227 serge 57
align 4
1055 Galkov 58
create_event:                                      ;; EXPORT use
59
;info:
60
;   Переносим EVENT из списка FreeEvents в список ObjList текущего слота
61
;   EVENT.state устанавливаем из ecx, EVENT.code косвенно из esi (если esi<>0)
62
;param:
63
;   esi - event data
64
;   ecx - flags
65
;retval:
66
;   eax - event (=0 => fail)
67
;   edx - uid
68
;scratched: ebx,ecx,esi,edi
2382 hidnplayr 69
        mov     ebx, [current_slot]
70
        add     ebx, APP_OBJ_OFFSET
71
        mov     edx, [TASK_BASE]
72
        mov     edx, [edx+TASKDATA.pid]
1055 Galkov 73
        pushfd
74
        cli
2540 hidnplayr 75
;--------------------------------------
76
align 4
1055 Galkov 77
set_event:                                         ;; INTERNAL use !!! don't use for Call
78
;info:
79
;   Берем новый event из FreeEvents, заполняем его поля, как указано в ecx,edx,esi
80
;   и устанавливаем в список, указанный в ebx.
81
;   Возвращаем сам event (в eax), и его uid (в edx)
82
;param:
83
;   ebx - start-chain "virtual" event for entry new event Right of him
84
;   ecx - flags      (copied to EVENT.state)
85
;   edx - pid        (copied to EVENT.pid)
86
;   esi - event data (copied to EVENT.code indirect, =0 => skip)
87
;retval:
88
;   eax - event (=0 => fail)
89
;   edx - uid
90
;scratched: ebx,ecx,esi,edi
2382 hidnplayr 91
        mov     eax, FreeEvents
92
        cmp     eax, [eax+EVENT.fd]
1055 Galkov 93
        jne     @f  ; not empty ???
94
        pushad
95
        call    init_events
96
        popad
97
        jz      RemoveEventTo.break ; POPF+RET
2540 hidnplayr 98
;--------------------------------------
99
align 4
100
@@:
2382 hidnplayr 101
        mov     eax, [eax+EVENT.fd]
102
        mov     [eax+EVENT.magic], 'EVNT'
103
        mov     [eax+EVENT.destroy], destroy_event.internal
104
        mov     [eax+EVENT.state], ecx
105
        mov     [eax+EVENT.pid], edx
1055 Galkov 106
        inc     [event_uid]
107
        Mov     [eax+EVENT.id],edx,[event_uid]
2540 hidnplayr 108
        or      esi, esi
109
        jz      RemoveEventTo
110
        lea     edi, [eax+EVENT.code]
111
        mov     ecx, (sizeof.EVENT -EVENT.code)/4
112
        cld
113
        rep movsd
114
;--------------------------------------
115
align 4
1055 Galkov 116
RemoveEventTo:                                     ;; INTERNAL use !!! don't use for Call
117
;param:
118
;   eax - указатель на event, КОТОРЫЙ вставляем
119
;   ebx - указатель на event, ПОСЛЕ которого вставляем
120
;scratched: ebx,ecx
2382 hidnplayr 121
        mov     ecx, eax             ; ecx=eax=Self,      ebx=NewLeft
122
        xchg    ecx, [ebx+EVENT.fd]  ; NewLeft.fd=Self,   ecx=NewRight
123
        cmp     eax, ecx             ; стоп, себе думаю...
1059 Galkov 124
        je      .break               ; - а не дурак ли я?
2382 hidnplayr 125
        mov     [ecx+EVENT.bk], eax  ; NewRight.bk=Self
126
        xchg    ebx, [eax+EVENT.bk]  ; Self.bk=NewLeft,   ebx=OldLeft
127
        xchg    ecx, [eax+EVENT.fd]  ; Self.fd=NewRight,  ecx=OldRight
128
        mov     [ebx+EVENT.fd], ecx  ; OldLeft.fd=OldRight
129
        mov     [ecx+EVENT.bk], ebx  ; OldRight.bk=OldLeft
2540 hidnplayr 130
;--------------------------------------
131
align 4
2382 hidnplayr 132
.break:
133
        popfd
1055 Galkov 134
        ret
2540 hidnplayr 135
;-----------------------------------------------------------------------------
1055 Galkov 136
align 4
137
NotDummyTest:                                      ;; INTERNAL use (not returned for fail !!!)
138
        pop     edi
139
        call    DummyTest ; not returned for fail !!!
2382 hidnplayr 140
        mov     ebx, eax
141
        mov     eax, [ebx+EVENT.pid]
1055 Galkov 142
        push    edi
2540 hidnplayr 143
;--------------------------------------
144
align 4
1055 Galkov 145
.small: ; криво как-то...
146
        pop     edi
147
        pushfd
148
        cli
1061 Galkov 149
        call    pid_to_slot ; saved all registers (eax - retval)
2382 hidnplayr 150
        shl     eax, 8
1055 Galkov 151
        jz      RemoveEventTo.break ; POPF+RET
152
        jmp     edi ; штатный возврат
2540 hidnplayr 153
;-----------------------------------------------------------------------------
227 serge 154
align 4
1055 Galkov 155
raise_event:                                       ;; EXPORT use
156
;info:
157
;   Устанавливаем данные EVENT.code
158
;   Если там флаг EVENT_SIGNALED уже активен - больше ничего
159
;   Иначе: этот флаг взводится, за исключением случая наличия флага EVENT_WATCHED в edx
160
;   В этом случае EVENT_SIGNALED взводится лишь при наличие EVENT_WATCHED в самом событии
161
;param:
162
;   eax - event
163
;   ebx - uid (for Dummy testing)
164
;   edx - flags
165
;   esi - event data (=0 => skip)
166
;scratched: ebx,ecx,esi,edi
167
        call    NotDummyTest ; not returned for fail !!!
2540 hidnplayr 168
        or      esi, esi
169
        jz      @f
170
        lea     edi, [ebx+EVENT.code]
171
        mov     ecx, (sizeof.EVENT -EVENT.code)/4
172
        cld
173
        rep movsd
174
;--------------------------------------
175
align 4
176
@@:
1055 Galkov 177
        test    byte[ebx+EVENT.state+3], EVENT_SIGNALED shr 24
178
        jnz     RemoveEventTo.break  ; POPF+RET
179
        bt      edx, 28 ;EVENT_WATCHED
180
        jnc     @f
2382 hidnplayr 181
        test    byte[ebx+EVENT.state+3], EVENT_WATCHED shr 24
1055 Galkov 182
        jz      RemoveEventTo.break  ; POPF+RET
2540 hidnplayr 183
;--------------------------------------
184
align 4
185
@@:
1055 Galkov 186
        or      byte[ebx+EVENT.state+3], EVENT_SIGNALED shr 24
2382 hidnplayr 187
        add     eax, SLOT_BASE+APP_EV_OFFSET
188
        xchg    eax, ebx
1055 Galkov 189
        jmp     RemoveEventTo
2540 hidnplayr 190
;-----------------------------------------------------------------------------
1055 Galkov 191
align 4
192
clear_event:                                       ;; EXPORT use
193
;info:
354 serge 194
;
1055 Galkov 195
;param:
196
;   eax - event
197
;   ebx - uid (for Dummy testing)
198
;scratched: ebx,ecx
199
        call    NotDummyTest ; not returned for fail !!!
2382 hidnplayr 200
        add     eax, SLOT_BASE+APP_OBJ_OFFSET
1055 Galkov 201
        and     byte[ebx+EVENT.state+3], not((EVENT_SIGNALED+EVENT_WATCHED)shr 24)
2382 hidnplayr 202
        xchg    eax, ebx
1055 Galkov 203
        jmp     RemoveEventTo
2540 hidnplayr 204
;-----------------------------------------------------------------------------
1055 Galkov 205
align 4
206
send_event:                                        ;; EXPORT use
207
;info:
208
;   Создает новый EVENT (вытаскивает из списка FreeEvents) в списке EventList
209
;   целевого слота (eax=pid), с данными из esi косвенно, и state=EVENT_SIGNALED
210
;param:
211
;   eax - slots pid, to sending new event
212
;   esi - pointer to sending data (in code field of new event)
213
;retval:
214
;   eax - event (=0 => fail)
215
;   edx - uid
216
;warning:
217
;   may be used as CDECL with such prefix...
218
;       mov     esi,[esp+8]
219
;       mov     eax,[esp+4]
220
;   but not as STDCALL :(
221
;scratched: ebx,ecx,esi,edi
2382 hidnplayr 222
        mov     edx, eax
1055 Galkov 223
        call    NotDummyTest.small ; not returned for fail !!!
2382 hidnplayr 224
        lea     ebx, [eax+SLOT_BASE+APP_EV_OFFSET]
225
        mov     ecx, EVENT_SIGNALED
1055 Galkov 226
        jmp     set_event
2540 hidnplayr 227
;-----------------------------------------------------------------------------
1055 Galkov 228
align 4
229
DummyTest:                                         ;; INTERNAL use (not returned for fail !!!)
230
;param:
231
;   eax - event
232
;   ebx - uid (for Dummy testing)
2382 hidnplayr 233
        cmp     [eax+EVENT.magic], 'EVNT'
1055 Galkov 234
        jne     @f
2382 hidnplayr 235
        cmp     [eax+EVENT.id], ebx
1055 Galkov 236
        je      .ret
2540 hidnplayr 237
;--------------------------------------
238
align 4
239
@@:
2382 hidnplayr 240
        pop     eax
241
        xor     eax, eax
2540 hidnplayr 242
;--------------------------------------
243
align 4
2382 hidnplayr 244
.ret:
245
        ret
2540 hidnplayr 246
;-----------------------------------------------------------------------------
1055 Galkov 247
align 4
248
Wait_events:
2382 hidnplayr 249
        or      ebx, -1; infinite timeout
2540 hidnplayr 250
;--------------------------------------
251
align 4
1055 Galkov 252
Wait_events_ex:
253
;info:
254
;   Ожидание "абстрактного" события через перевод слота в 5-ю позицию.
255
;   Абстрактность заключена в том, что факт события определяется функцией APPDATA.wait_test,
256
;   которая задается клиентом и может быть фактически любой.
257
;   Это позволяет shed-у надежно определить факт события, и не совершать "холостых" переключений,
258
;   предназначенных для разборок типа "свой/чужой" внутри задачи.
259
;param:
260
;   edx - wait_test, клиентская ф-я тестирования (адрес кода)
261
;   ecx - wait_param, дополнительный параметр, возможно необходимый для [wait_test]
262
;   ebx - wait_timeout
263
;retval:
264
;   eax - результат вызова [wait_test] (=0 => timeout)
265
;scratched: esi
2382 hidnplayr 266
        mov     esi, [current_slot]
267
        mov     [esi+APPDATA.wait_param], ecx
1055 Galkov 268
        pushad
2382 hidnplayr 269
        mov     ebx, esi;пока это вопрос, чего куды сувать..........
1055 Galkov 270
        pushfd  ; это следствие общей концепции: пусть ф-я тестирования имеет
271
        cli     ; право рассчитывать на закрытые прерывания, как при вызове из shed
272
        call    edx
273
        popfd
2382 hidnplayr 274
        mov     [esp+28], eax
1055 Galkov 275
        popad
2382 hidnplayr 276
        or      eax, eax
1055 Galkov 277
        jnz     @f   ;RET
2382 hidnplayr 278
        mov     [esi+APPDATA.wait_test], edx
279
        mov     [esi+APPDATA.wait_timeout], ebx
1055 Galkov 280
        Mov     [esi+APPDATA.wait_begin],eax,[timer_ticks]
2382 hidnplayr 281
        mov     eax, [TASK_BASE]
1055 Galkov 282
        mov     [eax+TASKDATA.state], 5
283
        call    change_task
2382 hidnplayr 284
        mov     eax, [esi+APPDATA.wait_param]
2540 hidnplayr 285
;--------------------------------------
286
align 4
287
@@:
2382 hidnplayr 288
        ret
2540 hidnplayr 289
;-----------------------------------------------------------------------------
1055 Galkov 290
align 4
291
wait_event:                                        ;; EXPORT use
292
;info:
293
;   Ожидание флага EVENT_SIGNALED в совершенно конкретном Event
294
;   (устанавливаемого, надо полагать, через raise_event)
295
;   При активном флаге MANUAL_RESET - больше ничего
296
;   Иначе: флаги EVENT_SIGNALED и EVENT_WATCHED у полученного события сбрасываются,
297
;   и, при активном MANUAL_DESTROY - перемещается в список ObjList текущего слота,
298
;   а при не активном - уничтожается штатно (destroy_event.internal)
299
;param:
300
;   eax - event
301
;   ebx - uid (for Dummy testing)
302
;scratched: ecx,edx,esi
303
        call    DummyTest
2382 hidnplayr 304
        mov     ecx, eax             ; wait_param
1061 Galkov 305
        mov     edx, get_event_alone ; wait_test
1055 Galkov 306
        call    Wait_events          ; timeout ignored
307
        jmp     wait_finish
2540 hidnplayr 308
;-----------------------------------------------------------------------------
1055 Galkov 309
align 4
310
get_event_ex:                                      ;; f68:14
311
;info:
312
;   Ожидание любого события в очереди EventList текущего слота
313
;   Данные события code - копируются в память приложения (косвенно по edi)
314
;   При активном флаге MANUAL_RESET - больше ничего
315
;   Иначе: флаги EVENT_SIGNALED и EVENT_WATCHED у полученного события сбрасываются,
316
;   и, при активном MANUAL_DESTROY - перемещается в список ObjList текущего слота,
317
;   а при не активном - уничтожается штатно (destroy_event.internal)
318
;param:
319
;   edi - адрес в коде приложения для копирования данных из EVENT.code
320
;retval:
321
;   eax - собственно EVENT (будем называть это его хэндлом)
322
;scratched: ebx,ecx,edx,esi,edi
2540 hidnplayr 323
        mov     edx, get_event_queue ; wait_test
324
        call    Wait_events          ; timeout ignored
325
        lea     esi, [eax+EVENT.code]
326
        mov     ecx, (sizeof.EVENT-EVENT.code)/4
327
        cld
328
        rep movsd
329
        mov     byte[edi-(sizeof.EVENT-EVENT.code)+2], cl;clear priority field
330
;--------------------------------------
331
align 4
332
wait_finish:
333
        test    byte[eax+EVENT.state+3], MANUAL_RESET shr 24
334
        jnz     get_event_queue.ret  ; RET
1061 Galkov 335
        and     byte[eax+EVENT.state+3], not((EVENT_SIGNALED+EVENT_WATCHED)shr 24)
1055 Galkov 336
        test    byte[eax+EVENT.state+3], MANUAL_DESTROY shr 24
337
        jz      destroy_event.internal
2382 hidnplayr 338
        mov     ebx, [current_slot]
339
        add     ebx, APP_OBJ_OFFSET
1055 Galkov 340
        pushfd
341
        cli
342
        jmp     RemoveEventTo
2540 hidnplayr 343
;-----------------------------------------------------------------------------
1055 Galkov 344
align 4
345
destroy_event:                                     ;; EXPORT use
346
;info:
347
;   Переносим EVENT в список FreeEvents, чистим поля magic,destroy,pid,id
348
;param:
349
;   eax - event
350
;   ebx - uid (for Dummy testing)
351
;retval:
352
;   eax - адрес объекта EVENT (=0 => fail)
353
;scratched: ebx,ecx
354
        call    DummyTest ; not returned for fail !!!
2540 hidnplayr 355
;--------------------------------------
356
align 4
363 serge 357
.internal:
2382 hidnplayr 358
        xor     ecx, ecx  ; clear common header
1055 Galkov 359
        pushfd
360
        cli
2382 hidnplayr 361
        mov     [eax+EVENT.magic], ecx
362
        mov     [eax+EVENT.destroy], ecx
363
        mov     [eax+EVENT.pid], ecx
364
        mov     [eax+EVENT.id], ecx
365
        mov     ebx, FreeEvents
1055 Galkov 366
        jmp     RemoveEventTo
2540 hidnplayr 367
;-----------------------------------------------------------------------------
227 serge 368
align 4
1055 Galkov 369
get_event_queue:
370
;info:
371
;   клиентская ф-я тестирования для get_event_ex
372
;warning:
373
;  -don't use [TASK_BASE],[current_slot],[CURRENT_TASK] - it is not for your slot
374
;  -may be assumed, that interrupt are disabled
375
;  -it is not restriction for scratched registers
376
;param:
377
;   ebx - адрес APPDATA слота тестирования
378
;retval:
379
;   eax - адрес объекта EVENT (=0 => fail)
2382 hidnplayr 380
        add     ebx, APP_EV_OFFSET
381
        mov     eax, [ebx+APPOBJ.bk] ; выбираем с конца, по принципу FIFO
382
        cmp     eax, ebx ; empty ???
1055 Galkov 383
        je      get_event_alone.ret0
2540 hidnplayr 384
;--------------------------------------
385
align 4
2382 hidnplayr 386
.ret:
387
        ret
2540 hidnplayr 388
;-----------------------------------------------------------------------------
227 serge 389
align 4
1055 Galkov 390
get_event_alone:
391
;info:
392
;   клиентская ф-я тестирования для wait_event
393
;warning:
394
;  -don't use [TASK_BASE],[current_slot],[CURRENT_TASK] - it is not for your slot
395
;  -may be assumed, that interrupt are disabled
396
;  -it is not restriction for scratched registers
397
;param:
398
;   ebx - адрес APPDATA слота тестирования
399
;retval:
400
;   eax - адрес объекта EVENT (=0 => fail)
2382 hidnplayr 401
        mov     eax, [ebx+APPDATA.wait_param]
1055 Galkov 402
        test    byte[eax+EVENT.state+3], EVENT_SIGNALED shr 24
403
        jnz     .ret
404
        or      byte[eax+EVENT.state+3], EVENT_WATCHED shr 24
2540 hidnplayr 405
;--------------------------------------
406
align 4
2382 hidnplayr 407
.ret0:
408
        xor     eax, eax; NO event!!!
2540 hidnplayr 409
;--------------------------------------
410
align 4
2382 hidnplayr 411
.ret:
412
        ret
2540 hidnplayr 413
;-----------------------------------------------------------------------------
354 serge 414
align 4
1055 Galkov 415
sys_sendwindowmsg:                                 ;; f72
416
        dec     ebx
417
        jnz     .ret ;subfunction==1 ?
2540 hidnplayr 418
        pushfd
1055 Galkov 419
        cli
2382 hidnplayr 420
        sub     ecx, 2
1055 Galkov 421
        je      .sendkey
2382 hidnplayr 422
        dec     ecx
423
        jnz     .retf
2540 hidnplayr 424
;--------------------------------------
425
align 4
1055 Galkov 426
.sendbtn:
2382 hidnplayr 427
        cmp     byte[BTN_COUNT], 1
1055 Galkov 428
        jae     .result ;overflow
429
        inc     byte[BTN_COUNT]
2382 hidnplayr 430
        shl     edx, 8
431
        mov     [BTN_BUFF], edx
1055 Galkov 432
        jmp     .result
2540 hidnplayr 433
;--------------------------------------
434
align 4
1055 Galkov 435
.sendkey:
2382 hidnplayr 436
        movzx   eax, byte[KEY_COUNT]
437
        cmp     al, 120
1055 Galkov 438
        jae     .result ;overflow
439
        inc     byte[KEY_COUNT]
2382 hidnplayr 440
        mov     [KEY_COUNT+1+eax], dl
2540 hidnplayr 441
;--------------------------------------
442
align 4
1055 Galkov 443
.result:
1067 Galkov 444
        setae   byte[esp+32] ;считаем, что исходно: dword[esp+32]==72
2540 hidnplayr 445
;--------------------------------------
446
align 4
447
.retf:
448
        popfd
449
;--------------------------------------
450
align 4
2382 hidnplayr 451
.ret:
452
        ret
2540 hidnplayr 453
;-----------------------------------------------------------------------------
377 serge 454
align 4
1055 Galkov 455
sys_getevent:                                      ;; f11
2382 hidnplayr 456
        mov     ebx, [current_slot];пока это вопрос, чего куды сувать..........
1055 Galkov 457
        pushfd  ; это следствие общей концепции: пусть ф-я тестирования имеет
458
        cli     ; право рассчитывать на закрытые прерывания, как при вызове из shed
531 diamond 459
        call    get_event_for_app
1055 Galkov 460
        popfd
2382 hidnplayr 461
        mov     [esp+32], eax
1055 Galkov 462
        ret
2540 hidnplayr 463
;-----------------------------------------------------------------------------
1055 Galkov 464
align 4
465
sys_waitforevent:                                  ;; f10
2382 hidnplayr 466
        or      ebx, -1; infinite timeout
2540 hidnplayr 467
;--------------------------------------
468
align 4
1055 Galkov 469
sys_wait_event_timeout:                            ;; f23
2382 hidnplayr 470
        mov     edx, get_event_for_app; wait_test
1061 Galkov 471
        call    Wait_events_ex        ; ebx - timeout
2382 hidnplayr 472
        mov     [esp+32], eax
1055 Galkov 473
        ret
2540 hidnplayr 474
;-----------------------------------------------------------------------------
1055 Galkov 475
align 4
476
get_event_for_app:                                 ;; used from f10,f11,f23
477
;info:
478
;   клиентская ф-я тестирования для приложений (f10,f23)
479
;warning:
480
;  -don't use [TASK_BASE],[current_slot],[CURRENT_TASK] - it is not for your slot
481
;  -may be assumed, that interrupt are disabled
482
;  -it is not restriction for scratched registers
483
;param:
484
;   ebx - адрес APPDATA слота тестирования
485
;retval:
486
;   eax - номер события (=0 => no events)
2382 hidnplayr 487
        movzx   edi, bh               ; bh  is assumed as [CURRENT_TASK]
488
        shl     edi, 5
489
        add     edi, CURRENT_TASK     ; edi is assumed as [TASK_BASE]
490
        mov     ecx, [edi+TASKDATA.event_mask]
2540 hidnplayr 491
        and     ecx, 0x7FFFFFFF
492
;--------------------------------------
493
align 4
1055 Galkov 494
.loop: ; пока не исчерпаем все биты маски
2382 hidnplayr 495
        bsr     eax, ecx       ; находим ненулевой бит маски (31 -> 0)
1055 Galkov 496
        jz      .no_events     ; исчерпали все биты маски, но ничего не нашли ???
2382 hidnplayr 497
        btr     ecx, eax       ; сбрасываем проверяемый бит маски
1055 Galkov 498
       ; переходим на обработчик этого (eax) бита
2382 hidnplayr 499
        cmp     eax, 9
2540 hidnplayr 500
        jae     .loop          ; eax=[9..31], ignored (event 10...32)
501
 
2382 hidnplayr 502
        cmp     eax, 3
2540 hidnplayr 503
        je      .loop          ; eax=3, ignored (event 4)
504
 
505
        cmp     eax, 4
506
        je      .FlagAutoReset  ; eax=4, retvals=eax+1 (event 5)
507
 
508
        cmp     eax, 5
509
        je      .mouse_check  ; eax=5, retvals=eax+1 (event 6)
510
 
511
        ja      .FlagAutoReset ; eax=[6..8], retvals=eax+1 (event 7...9)
512
 
2382 hidnplayr 513
        cmp     eax, 1
2540 hidnplayr 514
        jae     .BtKy          ; eax=[1,2],  retvals=eax+1 (event 2,3)
515
;--------------------------------------
516
align 4
1055 Galkov 517
.WndRedraw:                    ; eax=0, retval WndRedraw=1
2382 hidnplayr 518
        cmp     [edi-twdw+WDATA.fl_redraw], al;al==0
1055 Galkov 519
        jne     .result
520
        jmp     .loop
2540 hidnplayr 521
;--------------------------------------
522
align 4
523
.no_events:
2382 hidnplayr 524
        xor     eax, eax
531 diamond 525
        ret
2540 hidnplayr 526
;--------------------------------------
527
align 4
528
.mouse_check:    ; Mouse 5+1=6
2382 hidnplayr 529
        push    eax
2540 hidnplayr 530
        mov     eax, [TASK_BASE]
531
        mov     eax, [eax + TASKDATA.event_mask]
532
        test    eax, 0x80000000 ; bit 31: active/inactive filter f.40
533
        jz      @f
534
        pop     eax
535
        jmp     .FlagAutoReset
536
;--------------------------------------
537
align 4
538
@@:
2382 hidnplayr 539
; If the window is captured and moved by the user, then no mouse events!!!
540
        mov     al, [mouse.active_sys_window.action]
541
        and     al, WINDOW_MOVE_AND_RESIZE_FLAGS
542
        test    al, al
543
        pop     eax
544
        jnz     .loop
2540 hidnplayr 545
;--------------------------------------
546
align 4
547
.FlagAutoReset: ; retvals: BgrRedraw=5, IPC=7, Stack=8, Debug=9
2382 hidnplayr 548
        btr     [ebx+APPDATA.event_mask], eax
1055 Galkov 549
        jnc     .loop
2540 hidnplayr 550
;--------------------------------------
551
align 4
552
.result:      ; retval = eax+1
665 diamond 553
        inc     eax
554
        ret
2540 hidnplayr 555
;--------------------------------------
556
align 4
557
.BtKy:
2382 hidnplayr 558
        movzx   edx, bh
1055 Galkov 559
        movzx   edx, word[WIN_STACK+edx*2]
560
        je      .Keys          ; eax=1, retval Keys=2
2540 hidnplayr 561
;--------------------------------------
562
align 4
1055 Galkov 563
.Buttons:                      ; eax=2, retval Buttons=3
2382 hidnplayr 564
        cmp     byte[BTN_COUNT], 0
1055 Galkov 565
        je      .loop          ; empty ???
2382 hidnplayr 566
        cmp     edx, [TASK_COUNT]
1055 Galkov 567
        jne     .loop          ; not Top ???
2382 hidnplayr 568
        mov     edx, [BTN_BUFF]
569
        shr     edx, 8
570
        cmp     edx, 0xFFFF    ;-ID for Minimize-Button of Form
1055 Galkov 571
        jne     .result
2382 hidnplayr 572
        mov     [window_minimize], 1
1055 Galkov 573
        dec     byte[BTN_COUNT]
574
        jmp     .loop
2540 hidnplayr 575
;--------------------------------------
576
align 4
1055 Galkov 577
.Keys:    ; eax==1
2382 hidnplayr 578
        cmp     edx, [TASK_COUNT]
1055 Galkov 579
        jne     @f             ; not Top ???
2382 hidnplayr 580
        cmp     [KEY_COUNT], al; al==1
1055 Galkov 581
        jae     .result        ; not empty ???
2540 hidnplayr 582
;--------------------------------------
583
align 4
584
@@:
2382 hidnplayr 585
        mov     edx, hotkey_buffer
2540 hidnplayr 586
;--------------------------------------
587
align 4
588
@@:
2382 hidnplayr 589
        cmp     [edx], bh      ; bh - slot for testing
1055 Galkov 590
        je      .result
2382 hidnplayr 591
        add     edx, 8
1055 Galkov 592
        cmp     edx, hotkey_buffer+120*8
92 diamond 593
        jb      @b
1055 Galkov 594
        jmp     .loop
595
;end.
2540 hidnplayr 596
;-----------------------------------------------------------------------------