Diff for /gforth/search.fs between versions 1.9 and 1.10

version 1.9, 1999/03/29 22:52:29 version 1.10, 1999/05/22 20:03:53
Line 65  Variable slowvoc   0 slowvoc ! Line 65  Variable slowvoc   0 slowvoc !
   \G onto the top of the search order stack.    \G onto the top of the search order stack.
   Create wordlist drop  DOES> context ! ;    Create wordlist drop  DOES> context ! ;
   
   : check-maxvp ( n -- )
       maxvp > -49 and throw ;
   
   : push-order ( wid -- ) \ gforth
       \g Push @var{wid} on the search order.
       vp @ 1+ dup check-maxvp vp! context ! ;
   
 : also  ( -- ) \ search ext  : also  ( -- ) \ search ext
   \G Perform a @code{DUP} on the search order stack. Usually used prior    \G Perform a @code{DUP} on the search order stack. Usually used prior
   \G to @code{Forth}, @code{definitions} etc.    \G to @code{Forth}, @code{definitions} etc.
   context @ vp @ 1+ dup maxvp > abort" Vocstack full"    context @ push-order ;
   vp! context ! ;  
   
 : previous ( -- ) \ search ext  : previous ( -- ) \ search ext
   \G Perform a @code{DROP} on the search order stack, thereby removing the wid at the    \G Perform a @code{DROP} on the search order stack, thereby removing the wid at the
   \G top of the (search order) stack from the search order.    \G top of the (search order) stack from the search order.
   vp @ 1- dup 0= abort" Vocstack empty" vp! ;    vp @ 1- dup 0= -50 and throw vp! ;
   
 \ vocabulary find                                      14may93py  \ vocabulary find                                      14may93py
   
Line 156  lookup ! \ our dictionary search order b Line 162  lookup ! \ our dictionary search order b
   vp @ 0 ?DO  vp cell+ I cells + @  LOOP  vp @ ;    vp @ 0 ?DO  vp cell+ I cells + @  LOOP  vp @ ;
   
 : set-order  ( widn .. wid1 n -- ) \ thisone- search  : set-order  ( widn .. wid1 n -- ) \ thisone- search
   \G If @var{n}=0, empty the search order.      \G If @var{n}=0, empty the search order.  If @var{n}=-1, set the
   \G If @var{n}=-1, set the search order to the implementation-defined minimum search      \G search order to the implementation-defined minimum search order
   \G order (for Gforth, this is the word list @code{Root}). Otherwise, replace the      \G (for Gforth, this is the word list @code{Root}). Otherwise,
   \G existing search order with the @var{n} wid entries such that @var{wid1} represents the      \G replace the existing search order with the @var{n} wid entries
   \G word list that will be searched first and @var{widn} represents the word list that      \G such that @var{wid1} represents the word list that will be
   \G will be searched last.      \G searched first and @var{widn} represents the word list that will
   dup -1 = IF  drop Only exit  THEN  dup vp!      \G be searched last.
   ?dup IF  1- FOR  vp cell+ I cells + !  NEXT  THEN ;      dup -1 = IF
           drop only exit
       THEN
       dup check-maxvp
       dup vp!
       ?dup IF 1- FOR vp cell+ I cells + !  NEXT THEN ;
   
 : seal ( -- ) \ gforth  : seal ( -- ) \ gforth
   \G Remove all word lists from the search order stack other than the word    \G Remove all word lists from the search order stack other than the word

Removed from v.1.9  
changed lines
  Added in v.1.10


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>