File: Nut.mesa
Implemented by: NutImpl as part of the Nuts package
Contents: An interface to allow Cypress application programs for different database
entity types to call each other without knowing about each other beforehand. Each
application implements one or more "nut" types; nuts are viewers on Cypress entities.
Created by: Rick Cattell on 11-Dec-81 12:29:29
Last edited by:
Rick Cattell on July 22, 1983 2:31 pm
Willie-Sue on January 21, 1983 8:48 am
Jim Donahue on July 17, 1984 7:43:12 am PDT
Margaret Butler on July 11, 1984 4:25:11 pm PDT
Jennifer Widom on June 14, 1984 3:38:45 pm PDT
DIRECTORY
DB, Rope, ViewerClasses;
Nut: CEDAR DEFINITIONS =
BEGIN OPEN DB;
ROPE: TYPE = Rope.ROPE;
Viewer: TYPE = ViewerClasses.Viewer;
Interaction between nuts: these are implemented in NutImpl.mesa. Each nut implementation registers itself as knowing how to display, edit, and query some set of domains (a domain is a type of entity, see DB), with the Register proc. Any application (or the user through Squirrel) can then call one of the following procs to invoke whoever has registered himself for an entity type (or the default implementations if no one is registered). NoRegistration is raised if no Implementations (including defaults) have been registered.
NutProc: TYPE = PROC[eName, domain: ROPE, segment: DB.Segment, lastSpawned: Viewer ← NIL] RETURNS[v: Viewer];
Return a viewer for displaying, editing or querying the database entity with the given name and domain.
NoRegistration: ERROR;
Register: PROC[
domain: ROPE,
segment: DB.Segment,
display: NutProc ← NIL, -- proc to make displayer for entity in domain
edit: NutProc ← NIL, -- proc to make editor for new or old entity in domain
query: NutProc ← NIL, -- proc to make queryer on domain
reset: PROC[v: Viewer] ← NIL -- proc to redisplay the contents of a previously created viewer
];
Registers a display, create, and query for given domain.
These will supersede the top registrations for this domain except where new procs NIL.
DeRegister: PROC[domain: ROPE, segment: DB.Segment];
Deregisters all procs for this domain
Push: PROC[
domain: ROPE,
segment: DB.Segment,
display: NutProc ← NIL, -- proc to make displayer for entity in domain
edit: NutProc ← NIL, -- proc to make editor for new or old entity in domain
query: NutProc ← NIL, -- proc to make queryer on domain
reset: PROC[v: Viewer] ← NIL, -- proc to redisplay the contents of a previously created viewer
register: BOOLFALSE -- determines whether to add new entry or change top
];
Registers a display, create, and query for given domain.
Pop: PROC[domain: ROPE, segment: DB.Segment];
Deregisters top procs for this domain
PushDefaults: PROC[domain: ROPE, segment: DB.Segment];
Makes the defaults for the segment be registered as the ones to use. Mainly for debugging new display et al procs. An implementor can use this to actually see the things that a specialized displayer is attempting to display.
Display: PROC[ eName, domain: ROPE, segment: DB.Segment, parent: Viewer ← NIL] RETURNS[v: Viewer];
Displays e in newV. A new viewer is created if newV is NIL. If a nut implementation has registered itself for e's type, that implementation will be called, else the registered default implementation will be used. The seg argument is only necessary for system entities, which have no implicit segment.
Edit: PROC[ eName, domain: ROPE, segment: DB.Segment, parent: Viewer← NIL] RETURNS[v: Viewer];
Edit e in newV. A new viewer is created if newV is NIL. If a nut implementation has registered itself for e's type, that implementation will be called, else the registered default implementation will be used. The seg argument is only necessary for system entities, which have no implicit segment
Query: PROC[ eName, domain: ROPE, segment: DB.Segment, parent: Viewer← NIL ] RETURNS[v: Viewer];
Queries e in newV. A new viewer is created if newV is NIL. If a nut implementation has registered itself for e's type, that implementation will be called, else the registered default implementation will be used. The seg argument is only necessary for system entities, which have no implicit segment
ResetNuts: PROC[segment: DB.Segment];
Call the reset proc for all current Nut viewers that are manipulating entities in the given segment. This procedure may be called after restarting due to a transaction abort, for instance.
SetSpawnedProperty: PROC[v: Viewer, new: Viewer] RETURNS[previous: Viewer];
Set the "spawned" property of the first viewer to point to the second. The previous value is returned.
GetSpawnedProperty: PROC[v: Viewer] RETURNS[current: Viewer];
Set the "spawned" property of the first viewer to point to the second. The previous value is returned.
SetFrozenProperty: PROC[v: Viewer, new: BOOL] RETURNS[previous: BOOL];
Set the "frozen" property of the viewer and return its previous value. If the value of this property is TRUE (the default is FALSE), then the viewer will not be used as a "spawned" viewer.
GetFrozenProperty: PROC[v: Viewer] RETURNS[current: BOOL];
Set the "frozen" property of the viewer and return its previous value. If the value of this property is TRUE (the default is FALSE), then the viewer will not be used as a "spawned" viewer.
GetNutInfo: PROC[v: Viewer] RETURNS[segment: Segment, domain, entity: ROPE];
Returns information about the database entity being displayed in the viewer. These properties are set by the display, etc. procs in Nut for viewers that are created by calling through the Nut interface; they can also be set explicitly for other viewers by calling the SetNutInfo procedure given below.
ChangeName: PROC [v: Viewer, newName: Rope.ROPE];
Change the entity name associated with the viewer (to reflect executing a DB.ChangeName on the corresponding entity).
EntityNameForViewer: PROC [v: Viewer] RETURNS [entityName: ROPE];
Return the DBNames form of the entity for the viewer.
SetNutInfo: PROC[v: Viewer, segment: Segment, domain, entity: ROPE];
Sets the properties of the viewer to remember the DB entity displayed
END. . .
Change Log:
Edited by Rick on March 18, 1982 11:50 am: Major reorganization. Register now allows registration of all or some of the three procedures, and replaces any previous registration for that domain with the new one. Edit take init REF ANY. DisplayProc, EditProc, QueryProc take new viewer on calls out from Nut, old viewer on calls into Nut. Added close and open notify procs.
Edited by Rick on March 25, 1982 4:29 pm: Added user interaction procs section, dump and load stuff.
WSH on April 1, 1982: added MessageConfirm
Rick on April 3, 1982 4:29 pm: added width option to button. Added CreateProc feature.
Willie-Sue on July 8, 1982: changed EnumerateNutList, created NutPrivate.mesa, NutListImpl.mesa
Willie-Sue on July 27, 1982: changed EnumerateNutList to return LIST OF NutRec.
Cattell on August 5, 1982 7:11 pm: added init parm to Display, Create procs. Added GetDBTransaction proc.
Maxwell on September 8, 1982 9:29 am: moved procedures to Palm and SquirrelOps
Cattell on April 12, 1983 1:16 pm: fixed up some outdated comments.
Butler on June 26, 1984 3:58:24 pm PDT:
Major rewrite has been completed. Push, PushDefaults, and Pop have been added. Display, Edit, and Query now take the same arguments in the same order. See NutImpl for details of implementation changes.
Donahue on July 12, 1984 1:01:04 pm PDT:
Changed structure of Nut one final time: Domain is passed as a ROPE, so that no opportunities for DB aborts can arise. All procs take a "parent" viewer as argument and pass "last spawned" viewer to the display, etc. proc registered. Freeze moved here from NutViewer and changed slightly.