blob: 0be12d6de80646603f40e4d3b7d1f0b77af11f3b [file] [log] [blame]
(* StrIO.mod provides simple string input output routines.
Copyright (C) 2001-2026 Free Software Foundation, Inc.
Contributed by Gaius Mulley <gaius.mulley@southwales.ac.uk>.
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
<http://www.gnu.org/licenses/>. *)
IMPLEMENTATION MODULE StrIO ;
FROM ASCII IMPORT cr, nul, lf, bel, del, bs, nak, etb, ff, eof ;
FROM StdIO IMPORT Read, Write ;
FROM libc IMPORT isatty ;
VAR
IsATTY: BOOLEAN ; (* Is default input from the keyboard? *)
(*
WriteLn - writes a carriage return and a newline
character.
*)
PROCEDURE WriteLn ;
BEGIN
Echo(cr) ;
Write(lf)
END WriteLn ;
(*
ReadString - reads a sequence of characters into a string.
Line editing accepts Del, Ctrl H, Ctrl W and
Ctrl U.
*)
PROCEDURE ReadString (VAR a: ARRAY OF CHAR) ;
VAR
n ,
high : CARDINAL ;
ch : CHAR ;
BEGIN
high := HIGH(a) ;
n := 0 ;
REPEAT
Read(ch) ;
IF (ch=del) OR (ch=bs)
THEN
IF n=0
THEN
Write(bel)
ELSE
Erase ;
DEC(n)
END
ELSIF ch=nak (* Ctrl U *)
THEN
WHILE n>0 DO
Erase ;
DEC(n)
END
ELSIF ch=etb (* Ctrl W *)
THEN
IF n=0
THEN
Echo(bel)
ELSIF AlphaNum(a[n-1])
THEN
REPEAT
Erase ;
DEC(n)
UNTIL (n=0) OR (NOT AlphaNum(a[n-1]))
ELSE
Erase ;
DEC(n)
END
ELSIF n<=high
THEN
IF (ch=cr) OR (ch=lf)
THEN
a[n] := nul ;
INC(n)
ELSIF ch=ff
THEN
a[0] := ch ;
IF high>0
THEN
a[1] := nul
END ;
ch := cr
ELSIF ch>=' '
THEN
Echo(ch) ;
a[n] := ch ;
INC(n)
ELSIF ch=eof
THEN
a[n] := ch ;
INC(n) ;
ch := cr;
IF n<=high
THEN
a[n] := nul
END
END
ELSIF ch#cr
THEN
Echo(bel)
END
UNTIL (ch=cr) OR (ch=lf)
END ReadString ;
(*
WriteString - writes a string to the default output.
*)
PROCEDURE WriteString (a: ARRAY OF CHAR) ;
VAR
n ,
high : CARDINAL ;
BEGIN
high := HIGH(a) ;
n := 0 ;
WHILE (n <= high) AND (a[n] # nul) DO
Write(a[n]) ;
INC(n)
END
END WriteString ;
(*
Erase - writes a backspace, space and backspace to remove the
last character displayed.
*)
PROCEDURE Erase ;
BEGIN
Echo(bs) ;
Echo(' ') ;
Echo(bs)
END Erase ;
(*
Echo - echos the character, ch, onto the output channel if IsATTY
is true.
*)
PROCEDURE Echo (ch: CHAR) ;
BEGIN
IF IsATTY
THEN
Write(ch)
END
END Echo ;
(*
AlphaNum- returns true if character, ch, is an alphanumeric character.
*)
PROCEDURE AlphaNum (ch: CHAR) : BOOLEAN ;
BEGIN
RETURN ((ch>='a') AND (ch<='z')) OR
((ch>='A') AND (ch<='Z')) OR
((ch>='0') AND (ch<='9'))
END AlphaNum ;
BEGIN
(* IsATTY := isatty() *)
IsATTY := FALSE
END StrIO.