\ dynamic string handling 10aug99py
\ Copyright (C) 2000,2005,2007 Free Software Foundation, Inc.
\ This file is part of Gforth.
\ Gforth 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
\ of the License, or (at your option) any later version.
\ This program 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.
\ You should have received a copy of the GNU General Public License
\ along with this program. If not, see http://www.gnu.org/licenses/.
: delete ( buffer size count -- )
over min >r r@ - ( left over ) dup 0>
IF 2dup swap dup r@ + -rot swap move THEN + r> bl fill ;
[IFUNDEF] insert
: insert ( string length buffer size -- )
rot over min >r r@ - ( left over )
over dup r@ + rot move r> move ;
[THEN]
: $padding ( n -- n' )
[ 6 cells ] Literal + [ -4 cells ] Literal and ;
: $! ( addr1 u addr2 -- )
dup @ IF dup @ free throw THEN
over $padding allocate throw over ! @
over >r rot over cell+ r> move 2dup ! + cell+ bl swap c! ;
: $@len ( addr -- u ) @ @ ;
: $@ ( addr1 -- addr2 u ) @ dup cell+ swap @ ;
: $!len ( u addr -- )
over $padding over @ swap resize throw over ! @ ! ;
: $del ( addr off u -- ) >r >r dup $@ r> /string r@ delete
dup $@len r> - swap $!len ;
: $ins ( addr1 u addr2 off -- ) >r
2dup dup $@len rot + swap $!len $@ 1+ r> /string insert ;
: $+! ( addr1 u addr2 -- ) dup $@len $ins ;
: $off ( addr -- ) dup @ dup IF free throw off ELSE 2drop THEN ;
\ dynamic string handling 12dec99py
: $split ( addr u char -- addr1 u1 addr2 u2 )
>r 2dup r> scan dup >r dup IF 1 /string THEN
2swap r> - 2swap ;
: $iter ( .. $addr char xt -- .. ) >r >r
$@ BEGIN dup WHILE r@ $split i' -rot >r >r execute r> r>
REPEAT 2drop rdrop rdrop ;
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>