In accordance with the terminology used by Trestle, we refer to mouse
   button transitions as to {\em mouse events}. A mouse event is represented
   by a record MouseCB.Rec.
   A {\em mouse event callback object} is an object which has one
   method, invoke. Each geometric object has a stack of mouse callback
   objects. When a mouse event mr is relayed to a particular geometric
   o, the the message cb.invoke(mr) is sent to the top callback
   object on o's mouse callback stack (if o's mouse callback stack is
   empty, the event is simply dropped). It is cb's reponsibility to
   perform whatever action is appropriate in the current context. 
INTERFACEMouseCB ; IMPORT CB, Point, ProxiedObj, VBT; TYPE T <: Public; Public = ProxiedObj.T OBJECT METHODS init () : T; invoke (mr : Rec) RAISES {CB.BadMethod}; END;
MouseCB.Tis the abstract class of mouse callback objects. Ifois a geometric object,cis the top object in its mouse callback stack, and a mouse eventmrgets relayed too, thencb.invoke(mr)will be called. It is up to the user to create subclasses ofMouseCB.Tthat handle mouse events in a given context appropriately.
  Rec = RECORD
    pos2D       : Point.T;
    whatChanged : VBT.Button;
    modifiers   : VBT.Modifiers;
    clickType   : VBT.ClickType;
  END;
MouseCB.Recis a record type containing information about a mouse event.pos2Dis the position of the mouse when the button transition occurred.whatChangedis the button that went up or down.modifiersis the set of modifiers (Shift, Control, Mouse Buttons, etc.) that was active when the transition took place.clickTypeindicates whether the button went down or up, and whether any other button was already or still down.{\em NOTE: There is a fair chance that I will add other fields to
Rec, once we have gained more experience with event handling. So far, I pretty much mimick (part of) what is there inVBT.MouseRec.}
END MouseCB.