-- file P3.mesa
-- last modified by Satterthwaite, March 11, 1983 12:18 pm

DIRECTORY
  Alloc: TYPE USING [Notifier],
  Copier: TYPE USING [SEToken],
  Inline: TYPE USING [BITAND],
  Symbols: TYPE USING [
    Name, Type, ISEIndex, CSEIndex, RecordSEIndex, RefSEIndex,
    CTXIndex, IncludedCTXIndex, MDIndex, BTIndex, Closure],
  Tree: TYPE USING [Index, Link, Map, Scan];

P3: DEFINITIONS IMPORTS Inline = {
  OPEN Symbols;

  mark: BOOL = TRUE;		-- mark in tree as set by pass 3

 -- text literals

  TextForm: TYPE = {text, rope, ropeText};

 -- attributes

  Attr: TYPE = RECORD [
    noAssign: BOOL,
    noXfer: BOOL,
    const: BOOL];

  emptyAttr: Attr = [noAssign:FALSE, noXfer:FALSE, const:FALSE];
  fullAttr: Attr = [noAssign:TRUE, noXfer:TRUE, const:TRUE];
  voidAttr: Attr = [noAssign:TRUE, noXfer:TRUE, const:FALSE];

  And: PROC [Attr, Attr] RETURNS [Attr] = LOOPHOLE[Inline.BITAND];

 -- safety (Cedar)

  Safety: TYPE = {none, asserted, checked};

 -- narrowing operations
 
  NarrowOp: TYPE = RECORD [
    error, indirect, rtTest, tagTest, computed, unImpl: BOOL←FALSE];
  
  
 -- parameter use bookkeeping (for subst by name)

  NPUse: TYPE = {none, ref, set, refset, unsafe};	-- (name) param use
  NPMap: TYPE = ARRAY NPUse OF ARRAY NPUse OF NPUse;

  SetNP: ARRAY NPUse OF NPUse = [set, refset, set, refset, unsafe];

  MergeNP: NPMap =
    [[  none,    ref,    set, refset, unsafe],
     [   ref,    ref, unsafe, unsafe, unsafe],
     [   set, unsafe,    set, unsafe, unsafe],
     [refset, unsafe, unsafe, unsafe, unsafe],
     [unsafe, unsafe, unsafe, unsafe, unsafe]];

  SequenceNP: NPMap =
    [[  none,    ref,    set, refset, unsafe],
     [   ref,    ref, refset, refset, unsafe],
     [   set, unsafe,    set, unsafe, unsafe],
     [refset, unsafe, refset, unsafe, unsafe],
     [unsafe, unsafe, unsafe, unsafe, unsafe]];

  BoundNP: NPMap =
    [[  none,    ref,    set, refset, unsafe],
     [   ref,    ref, unsafe, refset, unsafe],
     [   set, unsafe,    set, refset, unsafe],
     [refset, refset, refset, refset, unsafe],
     [unsafe, unsafe, unsafe, unsafe, unsafe]];


 -- notifiers

  DeclNotify, MiscNotify, StmtNotify, VRNotify: Alloc.Notifier;
  ExpANotify, ExpBNotify, ExpCNotify: Alloc.Notifier;

 -- exported by Pass3B

  Header: PROC [node: Tree.Index];
  SetDefaultImport: PROC [iCtx: IncludedCTXIndex, implicitOK: BOOL←FALSE];

 -- exported by Pass3D

  DeclList: Tree.Scan;
  FirstId: PROC [Tree.Index] RETURNS [ISEIndex];
  InitialExp: PROC [Tree.Link, Type] RETURNS [v: Tree.Link, extended: BOOL];
  MakeLongType: PROC [Type, CSEIndex] RETURNS [CSEIndex];
  MakeRefType: PROC [cType: Type, hint: CSEIndex, readOnly,counted,var: BOOL←FALSE]
    RETURNS [RefSEIndex];
  ResolveType: PROC [ISEIndex];
  ResolveValue: PROC [ISEIndex];
  TypeAppl: Tree.Map;
  TypeExp: Tree.Map;

 -- exported by Pass3I

  IdInit: PROC [UNCOUNTED ZONE];
  IdReset: Tree.Scan;

  ArrangeKeys: PROC [
	expList: Tree.Link,
	nextKey: PROC RETURNS [Name],
	omittedValue: PROC RETURNS [Tree.Link]]
    RETURNS [CARDINAL];
  BaseTree: PROC [Tree.Link, Type] RETURNS [Tree.Link];
  BindTree: PROC [Tree.Link, PROC [ISEIndex] RETURNS [Tree.Link]] RETURNS [Tree.Link];
  BumpCount: PROC [ISEIndex];
  CheckDisjoint: PROC [ctx1, ctx2: CTXIndex];
  ClearRefStack: PROC;
  CloseBase: PROC [Tree.Link, Name];
  ClusterId: PROC [Name, CTXIndex] RETURNS [found: BOOL, sei: ISEIndex];
  CompleteRecord: PROC [rSei: RecordSEIndex, depth: Closure←$unit];
  CopyTree: Tree.Map;
  EnterIdList: PROC [IncludedCTXIndex, Tree.Link];
  EnterComposite: PROC [type: Type, t: Tree.Link, init: BOOL];
  EnterType: PROC [type: Type, canonical: BOOL←TRUE];
  FieldId: PROC [Name, RecordSEIndex] RETURNS [CARDINAL, ISEIndex];
  FindSe: PROC [Name] RETURNS [symbol: ISEIndex, base: Tree.Link, indirect: BOOL];
  Id: PROC [Name] RETURNS [Tree.Link];
  InterfaceId: PROC [Name, CTXIndex] RETURNS [found: BOOL, sei: ISEIndex];
  MainIncludedCtx: PROC [MDIndex] RETURNS [IncludedCTXIndex];
  MakeIdTable: PROC [CARDINAL];
  OpenBase: PROC [Tree.Link, Name] RETURNS [Tree.Link];
  OpenPointer: PROC [Tree.Link, Type] RETURNS [Tree.Link, Type];
  PopCtx: PROC;
  PushCtx: PROC [CTXIndex];
  PushHtCtx: PROC [Name, Tree.Link, BOOL];
  PushRecordCtx: PROC [RecordSEIndex, Tree.Link, BOOL]; 
  RecordLhs: PROC [ISEIndex];
  RecordMention: PROC [ISEIndex];
  SealRefStack: PROC;
  SearchCtxList: PROC [Name, CTXIndex] RETURNS [found: BOOL, sei: ISEIndex];
  Shared: PROC [CTXIndex] RETURNS [BOOL];
  TopCtx: PROC RETURNS [CTXIndex];
  UnsealRefStack: PROC;
  UpdateTreeAttr: PROC [Tree.Link] RETURNS [attr: Attr];

 -- exported by Pass3M
  
  CatchPhrase: PROC [Tree.Link] RETURNS [unwindCaught: BOOL];
  CopyLock: PROC RETURNS [Tree.Link];
  FindLockParams: PROC RETURNS [formal, actual: ISEIndex];
  LockVar: PROC [Tree.Link] RETURNS [Tree.Link];
  MakeFrameRecord: PROC [Tree.Link] RETURNS [CSEIndex];
  MiscStmt: PROC [Tree.Index] RETURNS [Tree.Link];
  MiscXfer: PROC [Tree.Index, CSEIndex] RETURNS [Tree.Link];
  TextRep: PROC [Type] RETURNS [TextForm];
  XferForFrame: PROC [CTXIndex] RETURNS [CSEIndex];

  InsertCatchLabel: SIGNAL [catchSeen, exit: BOOL];

 -- exported by Pass3S
  
  pathNP: VAR NPUse;

  BodyList: PROC [firstBti: BTIndex];
  BumpArgRefs: PROC [record: RecordSEIndex, write: BOOL];
  Case: PROC [Tree.Index, Tree.Map];
  CheckLocals: PROC [Tree.Link] RETURNS [localsOnly: BOOL];
  SafetyAttr: PROC [Tree.Index] RETURNS [Safety];
  SetSafety: PROC [Safety];
  Scope: PROC [Tree.Index, Tree.Map];
  Stmt: Tree.Map;

 -- exported by Pass3V

  DiscriminatedType: PROC [CSEIndex, Tree.Link] RETURNS [CSEIndex];
  Discrimination: PROC [Tree.Index, Tree.Map];
  Narrowing: PROC [type, target: CSEIndex] RETURNS [NarrowOp];
  SelectVariantType: PROC [Type, Name] RETURNS [ISEIndex];
  SequenceField: PROC [RecordSEIndex] RETURNS [ISEIndex];
  VariantUnionType: PROC [Type] RETURNS [CSEIndex];

 -- exported by Pass3Xa

  phraseNP: VAR NPUse;

  All: PROC [node: Tree.Index, target: CSEIndex, init: BOOL←FALSE];
  Apply: PROC [Tree.Index, CSEIndex, BOOL] RETURNS [Tree.Index];
  Assignment: PROC [Tree.Index];
  CheckScope: PROC [Tree.Link, Type] RETURNS [Tree.Link];
  Dot: PROC [Tree.Index, CSEIndex] RETURNS [Tree.Index];
  Extract: PROC [Tree.Index];
  FieldDefault: PROC [ISEIndex] RETURNS [Tree.Link];
  Initialization: PROC [CSEIndex, Tree.Link] RETURNS [Tree.Link];
  InterfaceCtx: PROC [CSEIndex, Tree.Link] RETURNS [CTXIndex];
  MatchFields: PROC [
      record: RecordSEIndex, expList: Tree.Link,
      init: BOOL←FALSE, scopeCheck: BOOL←TRUE]
    RETURNS [Tree.Link];

 -- exported by Pass3Xb

  ExpInit: PROC [UNCOUNTED ZONE];
  ExpReset: PROC;

  Exp: PROC [Tree.Link, CSEIndex] RETURNS [Tree.Link];
  Interval: PROC [Tree.Link, CSEIndex, BOOL];
  ForceType: PROC [Tree.Link, CSEIndex] RETURNS [Tree.Link];
  RAttr: PROC RETURNS [Attr];
  Rhs: PROC [Tree.Link, CSEIndex] RETURNS [Tree.Link];
  RPop: PROC;
  RPush: PROC [Type, Attr];
  RType: PROC RETURNS [Type];
  VoidExp: Tree.Map;

 -- exported by Pass3Xc

  AddrOp: PROC [Tree.Index, CSEIndex];
  Range: PROC [Tree.Link, CSEIndex] RETURNS [Tree.Link];
  Span: PROC [CSEIndex] RETURNS [first, last: Copier.SEToken];


  }.