PutGet.mesa
Copyright © 1985, 1986 by Xerox Corporation. All rights reserved.
written by Bill Paxton, May 1981
last edit by Paxton. October 21, 1982 1:55 pm
Russ Atkinson, July 22, 1983 10:24 am
Doug Wyatt, August 28, 1986 5:16:53 pm PDT
DIRECTORY
FS USING [OpenFile],
IO USING [STREAM],
Rope USING [ROPE],
TextNode USING [Node];
PutGet: CEDAR DEFINITIONS
= BEGIN
Node: TYPE = TextNode.Node;
ROPE: TYPE = Rope.ROPE;
MaxLen: INT = LAST[INT];
File Input/Output
ToFile: PROC [fileName: ROPE, node: Node, start: INT ← 0, flatten, textOnly: BOOLFALSE]
RETURNS
[dataLen, count: INT];
ToFileC: PROC [file: FS.OpenFile, node: Node, start: INT ← 0, flatten, textOnly: BOOLFALSE]
RETURNS
[dataLen, count: INT];
write the node on the specified file
starts writing at given address in file
returns dataLen = number of data bytes at start of file,
and count = the total number of bytes written
FromFile: PROC [fileName: ROPE, start: INT ← 0, len: INT ← MaxLen] RETURNS [Node];
FromFileC: PROC [file: FS.OpenFile, start: INT ← 0, len: INT ← MaxLen] RETURNS [Node];
create node from the contents of a file
starts reading at given start address in file
pretends that start+len is the end of the file
if file was not created by ToFile (i.e., password not correct)
then returns a single node containing contents of the file
FromFileError: ERROR;
WritePlain: PROC[h: IO.STREAM, root: Node, restoreDashes: BOOLFALSE];
WriteFilePlain: PROC [fileName: ROPE, root: Node];
WriteFileCPlain: PROC [file: FS.OpenFile, root: Node];
gives text of file with CR after each node and TABs before according to nesting
WriteMesaFilePlain: PROC [fileName: ROPE, root: Node];
like WriteFilePlain, but adds initial dashes to comments if necessary.
Input/Output using ropes instead of files
ToRope: PROC [node: Node, flatten, textOnly: BOOLFALSE]
RETURNS
[dataLen, count: INT, output: ROPE];
resulting rope contains same representation of node as would be put on file
FromRope: PROC [rope: ROPE, start: INT ← 0, len: INT ← MaxLen] RETURNS [Node];
reads rope to construct node
WriteRopePlain: PROC [root: Node, restoreDashes: BOOLFALSE] RETURNS [output: ROPE];
IO Operations
ToStream: PROC [stream: IO.STREAM, node: Node, flatten, textOnly: BOOLFALSE]
RETURNS
[dataLen, count: INT];
does a series of IO.PutBlock's
returns number of bytes written
FromStream: PROC [stream: IO.STREAM, len: INT ← MaxLen] RETURNS [Node];
reads up to len chars from stream (via GetBlock's) to construct a node
END.