ack/lang/m2/test/Thalmann/Shoes.mod
1988-04-20 10:43:48 +00:00

54 lines
1,013 B
Modula-2

MODULE Shoes;
(* From: MODULA-2, An Introduction, by Daniel Thalmann, Springer-Verlag,
New York, 1985
Figure 21.3
*)
FROM SYSTEM IMPORT WORD, ADR, ADDRESS, NEWPROCESS, TRANSFER;
FROM InOut IMPORT Write, WriteLn;
CONST
WorkLength = 200;
MaxShoes = 50;
MaxDif = 6;
TYPE
WorkSpace = ARRAY [0..WorkLength-1] OF WORD;
VAR
NbLeft, NbRight : INTEGER;
WSLeft, WSRight : WorkSpace;
Left, Right, Main : ADDRESS;
PROCEDURE Leftp;
BEGIN
WHILE NbLeft < MaxShoes DO
INC(NbLeft);
Write("L");
IF (NbLeft-NbRight>=MaxDif) OR (NbLeft>=MaxShoes) THEN
TRANSFER(Left,Right);
END;
END;
WriteLn;
END Leftp;
PROCEDURE Rightp;
BEGIN
WHILE NbRight < MaxShoes DO
INC(NbRight);
Write("R");
IF (NbRight-NbLeft>=MaxDif) OR (NbRight>=MaxShoes) THEN
TRANSFER(Right,Left);
END;
END;
WriteLn;
END Rightp;
BEGIN
NbLeft := 0;
NbRight := 0;
NEWPROCESS(Leftp,ADR(WSLeft),SIZE(WSLeft),Left);
NEWPROCESS(Rightp,ADR(WSRight),SIZE(WSRight),Right);
TRANSFER(Main,Left);
END Shoes.