FitIOJaM.mesa
Last Edited by Maureen Stone July 2, 1984 2:16:35 pm PDT
Last Edited by Michael Plass December 7, 1982 10:25 am
Last Edited by: Stone, November 27, 1984 5:04:19 pm PST
DIRECTORY
FitState,
FitIO,
FitJaM,
FitBasic USING [Handle],
Cubic,
Complex,
IO,
BasicTime, --used implicitly by IO.time
FS,
JaMImager USING [Painter],
JaM,
Imager,
Real,
Rope USING [ROPE, Length],
Seq,
Vector;
FitIOJaM:
CEDAR
PROGRAM
IMPORTS JaMImager, JaM, IO, FS, Rope, FitIO, FitJaM, Imager
EXPORTS =
BEGIN OPEN FitState;
all: BOOLEAN ← FALSE;
fill: BOOLEAN ← FALSE;
State: TYPE = JaM.State;
DrawSamples:
PROC[state: State]= {
Paint:
PROC[dc: Imager.Context] = {
FitJaM.defaultFitIO.imager ← dc;
FitIO.DrawSamples[ctx: FitJaM.defaultFitIO, handle: FitJaM.defaultFitState, all: all, fill: fill];
};
JaMImager.Painter[Paint,state];
};
MarkSamples:
PROC[state: State]= {
Paint:
PROC[dc: Imager.Context] = {
FitJaM.defaultFitIO.imager ← dc;
FitIO.MarkSamples[FitJaM.defaultFitIO, FitJaM.defaultFitState, all];
};
JaMImager.Painter[Paint,state];
MarkNodes:
PROC[state: State] = {
Paint:
PROC[dc: Imager.Context] = {
FitJaM.defaultFitIO.imager ← dc;
FitIO.MarkNodes[FitJaM.defaultFitIO, FitJaM.defaultFitState, all];
};
JaMImager.Painter[Paint,state];
};
MarkLinks:
PROC[state: State] = {
Paint:
PROC[dc: Imager.Context] = {
FitJaM.defaultFitIO.imager ← dc;
FitIO.MarkJoints[FitJaM.defaultFitIO, FitJaM.defaultFitState, all];
};
JaMImager.Painter[Paint,state];
};
DrawLinks:
PROC[state: JaM.State] = {
Paint:
PROC[dc: Imager.Context] = {
FitJaM.defaultFitIO.imager ← dc;
FitIO.DrawContour[FitJaM.defaultFitIO, FitJaM.defaultFitState, all, fill];
};
JaMImager.Painter[Paint,state];
};
SetMarkSize:
PROC[state: JaM.State] = {
FitJaM.defaultFitIO.feedback.sampleSize ← JaM.PopReal[state];
FitJaM.defaultFitIO.feedback.jointSize ← 2*FitJaM.defaultFitIO.feedback.sampleSize;
};
SetFeedbackColor:
PROC[state: JaM.State] = {
FitJaM.defaultFitIO.feedback.color ← NARROW[JaM.Pop[state]];
};
SetFeedback:
PROC[state: JaM.State] = {
sampleSize, jointSize, nodeLength, nodeLineWidth, lineWidth: REAL;
color: Imager.Color;
lineWidth ← JaM.PopReal[state];
nodeLineWidth ← JaM.PopReal[state];
nodeLength ← JaM.PopReal[state];
jointSize ← JaM.PopReal[state];
sampleSize ← JaM.PopReal[state];
color ← NARROW[JaM.Pop[state]];
FitJaM.defaultFitIO.feedback^ ← [
color: color,
sampleSize: sampleSize,
jointSize: jointSize,
nodeLength: nodeLength,
nodeLineWidth: nodeLineWidth,
lineWidth: lineWidth
];
};
XORColor: PROC[state: JaM.State] = {JaM.Push[state, Imager.XOR]}; --should be in jamicolorimpl
SetScale:
PROC[state: JaM.State] = {
FitIO.MagnifyData[FitJaM.defaultFitIO, JaM.PopReal[state]];
};
SetOffset:
PROC[state: JaM.State] = {
y: REAL ← JaM.PopReal[state];
x: REAL ← JaM.PopReal[state];
FitIO.PositionData[FitJaM.defaultFitIO, [x,y]];
};
SetFill: PROC[state: State] = {fill ← JaM.PopBool[state]};
SetAll: PROC[state: State] = {all ← JaM.PopBool[state]};
OpenLogFile:
PROC[state: State] = {
rope: Rope.ROPE ← JaM.PopRope[state];
create: BOOLEAN ← JaM.PopBool[state];
stream: IO.STREAM;
IF rope.Length[] > 0
AND
NOT create
THEN stream ←
FS.StreamOpen[rope, append !
FS.Error =>
IF error.group=user
THEN JaM.ExecuteRope[state, "(Invalid file name) .print" ! JaM.Stop => CONTINUE]
ELSE
IF error.group=lock
THEN {
JaM.ExecuteRope[state, "(Locked! new version created) .print" ! JaM.Stop => CONTINUE];
create ← TRUE;
CONTINUE;
}
ELSE REJECT;
];
IF create
THEN stream ←
FS.StreamOpen[fileName: rope, accessOptions: create, keep: 3 !
FS.Error =>
IF error.group=user
THEN JaM.ExecuteRope[state, "(Invalid file name) .print" ! JaM.Stop => CONTINUE]];
FitIO.StartLog[FitJaM.defaultFitIO, stream];
};
CloseLogFile:
PROC[state: State] = {
FitIO.StopLog[ctx: FitJaM.defaultFitIO, close: TRUE];
};
SetTypescript:
PROC[state: State] = {
IF JaM.PopBool[state]
THEN {
FitIO.StartLog[FitJaM.defaultFitIO, ! FitIO.NoLog =>
JaM.ExecuteRope[state, "(no log file) .print" ! JaM.Stop => CONTINUE]];
};
};
Note:
PROC[state: State] = {
c: Rope.ROPE ← JaM.PopRope[state];
IF FitJaM.defaultFitIO.logActions THEN PrintRope[c];
};
Notes:
PROC[state: State] = {
c: Rope.ROPE ← JaM.PopRope[state];
IF FitJaM.defaultFitIO.logActions THEN {PrintRope[c]; PrintRope[" "]};
};
Noter:
PROC[state: State] = {
c: Rope.ROPE ← JaM.PopRope[state];
IF FitJaM.defaultFitIO.logActions THEN {PrintLine[c]; FitJaM.defaultFitIO.log.Flush[]};
};
Time:
PROC[state: State] = {
IF FitJaM.defaultFitIO.logActions THEN {IO.Put[FitJaM.defaultFitIO.log,IO.time[]]; FitJaM.defaultFitIO.log.Flush[]};
};
PrintRope: PROC[s: Rope.ROPE] = {OPEN IO; Put[FitJaM.defaultFitIO.log,rope[s]]};
PrintLine: PROC[s: Rope.ROPE] = {OPEN IO; Put[FitJaM.defaultFitIO.log,rope[s],char[CR]]};
Init: FitJaM.InitProc = {
JaM.Register[state,".drawsa", DrawSamples];
JaM.Register[state,".marksa", MarkSamples];
JaM.Register[state,".drawli", DrawLinks];
JaM.Register[state,".markli", MarkLinks];
JaM.Register[state,".marknodes", MarkNodes];
JaM.Register[state,".setfill", SetFill];
JaM.Register[state,".setall", SetAll];
JaM.Register[state,".setlog", SetTypescript];
JaM.Register[state,".setscale", SetScale];
JaM.Register[state,".setoffset", SetOffset];
JaM.Register[state,".setmarksize", SetMarkSize];
JaM.Register[state,".setfeedbackcolor", SetFeedbackColor];
JaM.Register[state,".setfeedback", SetFeedback];
sampleSize, jointSize, nodeLength, nodeLineWidth, lineWidth color
JaM.Register[state,".note", Note];
JaM.Register[state,".notes", Notes];
JaM.Register[state,".noter", Noter];
JaM.Register[state,".time", Time];
JaM.Register[state,".xorcolor", XORColor]; -- puts an XOR color on the stack.
JaM.Register[state,".openlogfile", OpenLogFile]; -- filename create => . Opens the log file.
JaM.Register[state,".closelogfile", CloseLogFile]; -- => . Closes the log file.
};
FitJaM.RegisterInit[$FitIOJaM, Init];
END.