(* StdIO.def provides general Read and Write procedures. Copyright (C) 2001-2024 Free Software Foundation, Inc. Contributed by Gaius Mulley . This file is part of GNU Modula-2. GNU Modula-2 is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3, or (at your option) any later version. GNU Modula-2 is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. Under Section 7 of GPL version 3, you are granted additional permissions described in the GCC Runtime Library Exception, version 3.1, as published by the Free Software Foundation. You should have received a copy of the GNU General Public License and a copy of the GCC Runtime Library Exception along with this program; see the files COPYING3 and COPYING.RUNTIME respectively. If not, see . *) DEFINITION MODULE StdIO ; EXPORT QUALIFIED ProcRead, ProcWrite, Read, Write, PushOutput, PopOutput, GetCurrentOutput, PushInput, PopInput, GetCurrentInput ; TYPE ProcWrite = PROCEDURE (CHAR) ; ProcRead = PROCEDURE (VAR CHAR) ; (* Read - is the generic procedure that all higher application layers should use to receive a character. *) PROCEDURE Read (VAR ch: CHAR) ; (* Write - is the generic procedure that all higher application layers should use to emit a character. *) PROCEDURE Write (ch: CHAR) ; (* PushOutput - pushes the current Write procedure onto a stack, any future references to Write will actually invoke procedure, p. *) PROCEDURE PushOutput (p: ProcWrite) ; (* PopOutput - restores Write to use the previous output procedure. *) PROCEDURE PopOutput ; (* GetCurrentOutput - returns the current output procedure. *) PROCEDURE GetCurrentOutput () : ProcWrite ; (* PushInput - pushes the current Read procedure onto a stack, any future references to Read will actually invoke procedure, p. *) PROCEDURE PushInput (p: ProcRead) ; (* PopInput - restores Write to use the previous output procedure. *) PROCEDURE PopInput ; (* GetCurrentInput - returns the current input procedure. *) PROCEDURE GetCurrentInput () : ProcRead ; END StdIO.