Some invariants must be established by programs which create this data structure:
1) The actual wire of an instance must conform to the public wire of the cell type which is pointed to by the instance.
2) The actual field of an instance must point directly to a wire that is not reachable from the internal of the record cell. This wire, as is true of all public wires, must not be atomic and all of its subwires must be reachable from the internal of the cell type.
3) The public field of a cell type of record cell class must point to a wire that is not reachable from the internal of the record cell. This wire, as is true of all public wires, must not be atomic and all of its subwires must be reachable from the internal of the cell type.
4) The first level of the internal wire hierarchy exists only to allow smooth recursion, and to give a handle on the whole internal. Consequently, internal.size=0 should be interpreted as an empty internal and not an atomic wire. CoreOps naming strategy requires that internal are immutable, once part of a recordCell.
CreateRecordCell:
PROC [public: Wire, internal: Wire, instances:
LIST
OF CellInstance, name:
ROPE ←
NIL, props: Properties ←
NIL]
RETURNS [recordCell: CellType];
Checks that actuals conform to the sub publics and that actuals and public are part of the internals.
CreateInstance:
PROC [actual: Wire, type: CellType, name:
ROPE ←
NIL, props: Properties ←
NIL]
RETURNS [instance: CellInstance];
CorrespondingActual:
PROC [instance: CellInstance, public: Wire]
RETURNS [actual: Wire ←
NIL];
Returns the actual bound to the public in the instance, NIL if not found
ReverseCellInstances:
PROC [instances: CellInstances]
RETURNS [rev: CellInstances ←
NIL];
Reverses a list of CellInstances