ActionQueue.mesa
Copyright © 1985 by Xerox Corporation. All rights reserved.
Created by: Cattell and Haugeland on October 21, 1982 9:11 am
Last edited by: Cattell on October 21, 1982 9:11 am
Last edited by: MBrown on October 21, 1982 6:22 pm
Last Edited by: Maxwell, December 17, 1982 10:06 am
Doug Wyatt, April 14, 1985 11:34:53 pm PST
Crow, September 16, 1986 7:18:25 pm PDT
DIRECTORY
Buttons USING [Button, ButtonProc],
Imager USING [Font],
Menus USING [MenuEntry, MenuProc, MouseButton],
Rope USING [ROPE],
ViewerClasses USING [ViewerRec];
=
BEGIN
Queue: TYPE = RECORD [std, panic: REF QueueObj];
QueueObj:
TYPE ~
MONITORED
RECORD [
firstEvent: Event ← NIL,
pushModel: BOOL,
newEvent: CONDITION,
notifierRunning: BOOL ← FALSE
];
Create:
PROC [pushModel:
BOOL ←
TRUE]
RETURNS [Queue];
Creates a queue, a context in which mouse buttons are serialized. All menu item and
mouse button procs defined in the context of this queue will be strictly serialized, i.e.
the procs will be called in the order that the user clicked, and each proc will completely
finish execution before the next one starts.
If pushModel = FALSE, then actions are to be removed from the queue by a client process,
using DequeueAction (below), rather than by this package.
The client process should be prepared to handle ABORTED.
CreateMenuEntry:
PROC [q: Queue,
name: Rope.
ROPE,
proc: Menus.MenuProc,
clientData:
REF
ANY ←
NIL,
documentation:
REF
ANY ←
NIL,
fork:
BOOL ←
TRUE,
guarded:
BOOL ←
FALSE,
panic:
BOOL ←
FALSE
]
RETURNS [Menus.MenuEntry];
Identical to Menus.CreateEntry, except for the first and last arguments. Defines a menu item that is interpreted in the context of q. The last argument, panic, if true, requires immediate attention, flushing the existing queue.
CreateButton:
PROC [q: Queue,
info: ViewerClasses.ViewerRec ← [],
proc: Buttons.ButtonProc,
clientData:
REF
ANY ←
NIL,
fork:
BOOL ←
TRUE,
font: Imager.Font ←
NIL,
documentation:
REF
ANY ←
NIL,
guarded:
BOOL ←
FALSE,
paint:
BOOL ←
TRUE,
panic:
BOOL ←
FALSE
]
RETURNS [Buttons.Button];
Identical to Buttons.Create, except for the first and last arguments. Defines a button that is interpreted in the context of q. The last argument, panic, if true, requires immediate attention, flushing the existing queue.
QueueClientAction:
PROC [q: Queue, proc:
PROC [
REF
ANY], data:
REF
ANY];
Allows client to queue actions other than the menu item clicks and button clicks, which
are user-initiated. The client's proc will be called after any user clicks before the call,
and before any user clicks after the call.
Event: TYPE ~ LIST OF Action;
Action:
TYPE =
RECORD [
SELECT type: *
FROM
client => [
proc: PROC [REF ANY],
data: REF ANY
],
user => [
proc: Menus.MenuProc,
parent: REF ANY, clientData: REF ANY,
mouseButton: Menus.MouseButton, shift, control: BOOL
]
ENDCASE
DequeueAction:
PROC [q: Queue]
RETURNS [Action];
Waits for an action to appear, then returns it.
Called only for "pull model" queues.
Flush:
PROC [q: Queue];
Flushes all pending button presses and menu selections in the context of q. This procedure
can be called, e.g., when some illegal actions suggests the user is confused an further
mouse-ahead should be ignored.
FlushWithCallback:
PROC [q: Queue, proc:
PROC[Action] ←
NIL];
Like Flush, but applies proc to each action being flushed.