[gforth] / gforth / kernel / saccept.fs  

gforth: gforth/kernel/saccept.fs


1 : anton 1.1 \ a very simple accept approach
2 :    
3 : anton 1.8 \ Copyright (C) 1995,1996,1997,1998,1999,2000,2003 Free Software Foundation, Inc.
4 : anton 1.1
5 :     \ This file is part of Gforth.
6 :    
7 :     \ Gforth is free software; you can redistribute it and/or
8 :     \ modify it under the terms of the GNU General Public License
9 :     \ as published by the Free Software Foundation; either version 2
10 :     \ of the License, or (at your option) any later version.
11 :    
12 :     \ This program is distributed in the hope that it will be useful,
13 :     \ but WITHOUT ANY WARRANTY; without even the implied warranty of
14 :     \ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 :     \ GNU General Public License for more details.
16 :    
17 :     \ You should have received a copy of the GNU General Public License
18 :     \ along with this program; if not, write to the Free Software
19 : anton 1.6 \ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111, USA.
20 : anton 1.1
21 : jwilke 1.4 require ./io.fs
22 :    
23 : pazsan 1.2 : accept ( adr len -- len )
24 : anton 1.1 over + over ( start end pnt )
25 :     BEGIN
26 : pazsan 1.2 key dup #del = IF drop #bs THEN
27 : anton 1.1 dup bl u<
28 : pazsan 1.2 IF dup #cr = over #lf = or IF space drop nip swap - EXIT THEN
29 :     #bs = IF 3 pick over <>
30 :     IF 1 chars - #bs emit bl emit #bs emit ELSE bell THEN THEN
31 :     ELSE >r 2dup <> IF r> dup emit over c! char+ ELSE r> drop bell THEN
32 : anton 1.1 THEN
33 :     AGAIN ;
34 :    

CVS Admin

Powered by ViewCVS 1.0-dev
(Powered by ViewCVS)

ViewCVS and CVS Help