Modula-2 || Compiler & Tools || Library || Search Engine
(* diagnostic *) PROCEDURE done () : BOOLEAN; PROCEDURE success() : FmtExitCode;
(* error handling *) PROCEDURE setmode (mode : BITSET); PROCEDURE getmode (VAR mode : BITSET);
(* output *) PROCEDURE rintf0 (fmt : ARRAY OF CHAR); PROCEDURE rintf1 (fmt : ARRAY OF CHAR; i1 : ARRAY OF BYTE); PROCEDURE rintf2 (fmt : ARRAY OF CHAR; i1,i2 : ARRAY OF BYTE); (* ... *) PROCEDURE rintf8 (fmt : ARRAY OF CHAR; i1, i2, i3, i4, i5, i6, i7 , i8 : ARRAY OF BYTE);
Output of P is echoed to all echo files defined for stdout by means of LongStrings.Echo.
done returns TRUE if the last call of P.rintf0 .. P.rintf8 was successful, more detailed information can be obtained by success (FmtExitCode is imported from Printf).
setmode defines a new error handling mode mode which is by default set to Printf.Default. getmode yields the current mode.
In case of errors P.rintf0 .. P.rintf8 do not produce any output. Errors may result from illegal format strings or from problems when writing to stdout (error code CannotWriteStdout).
Error message issued by P will contain information about their reason and the affected procedure call:
[fatal] P.rintf1("%*u",...); Bad Format: too many format elements. [a.out] Exit code 201. Stop.
Modula-2 || Compiler & Tools || Library || Search Engine