Diff for /gforth/test/other.fs between versions 1.3 and 1.19

version 1.3, 1997/06/23 16:57:09 version 1.19, 2002/09/15 20:30:02
Line 1 Line 1
 \ various tests, especially for bugs that have been fixed  \ various tests, especially for bugs that have been fixed
   
 \ Copyright (C) 1997 Free Software Foundation, Inc.  \ Copyright (C) 1997,1998,2000 Free Software Foundation, Inc.
   
 \ This file is part of Gforth.  \ This file is part of Gforth.
   
Line 16 Line 16
   
 \ You should have received a copy of the GNU General Public License  \ You should have received a copy of the GNU General Public License
 \ along with this program; if not, write to the Free Software  \ along with this program; if not, write to the Free Software
 \ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  \ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111, USA.
   
 \ combination of marker and locals  \ combination of marker and locals
 marker foo1  marker foo1
Line 52  foo1 Line 52  foo1
   
 5 fac 120 <> throw  5 fac 120 <> throw
   
   \ TO and locals
   
   : locals-test2 ( -- )
       true dup dup dup { addr1 u1 addr2 u2 -- n }
       false TO addr1
       addr1 false <> abort" TO does not work on locals" ;
   locals-test2
   
   : locals-test3 ( -- )
       \ this should compile, but gives "invalid name argument" on gforth-0.3.0
       0 { a b } 0 to a ;
   
   \ multiple reveals (recursive)
   
   0
   : xxx recursive ;
   throw \ if the TOS is not 0, throw an error
   
 \ look for primitives  \ look for primitives
   
 ' + look 0= throw ( nt )  ' + xt>threaded look 0= throw ( nt )
 s" +" find-name <> throw  s" +" find-name <> throw
   
 \ represent  \ represent
Line 69  s" a     " 2 /string -trailing throw dro Line 87  s" a     " 2 /string -trailing throw dro
   
 0. s" 123  " drop convert drop 23. d<> throw  0. s" 123  " drop convert drop 23. d<> throw
   
   \ search
   
   name abc 2dup name xyza search throw d<> throw
   name b 2dup name abc search throw d<> throw
   
   \ only
   
   : test-only ( -- )
       get-order get-current
       0 set-current
       only
       get-current >r
       set-current set-order
       r> abort" ONLY sets current" ;
   test-only
   
   \ create-interpret/compile
   
   : my-constant ( n "name" -- )
       create-interpret/compile
       ,
   interpretation>
       @
   <interpretation
   compilation>
       @ postpone literal
   <compilation ;
   
   5 my-constant five
   five 5 <> throw
   : five' five ;
   five' 5 <> throw
   
   \ structs and alignment
   
   struct
     char% field field1
     float% field field2
   end-struct my-struct%
   
   0 field2 float% %alignment <> throw
   
   \ filenames with "//"
   
   s" //jkfklfggfld/fjsjfk/hjfdjs" open-fpath-file 2drop
   
   \ allotting negative space
   
   1 allot
   -1 allot
   
   \ unaligned input for head?
   
   here 1+ head? throw
   
   \ [compile] exit = exit
   
   : foo [compile] exit abort" '[compile] exit' broken" ;
   foo
   
   \ restore-input
   
   : test-restore-input[ ( -- )
       refill 0= abort" refill failed"
       bl word drop
       save-input
       refill 0= abort" refill failed"
       -1 ;
   
   : ]test-restore-input ( -- )
       drop restore-input abort" restore-input failed" 0 ;
   
   \ First input is skipped until the "]test-restore-input", then it is
   \ reset to just before "0 [if]"
   test-restore-input[ abort \ these aborts are skipped
   abort 0 [if]
       s" oops" 2drop ]test-restore-input abort
   [then]
   ( 0 ) throw
   
   \ the same test with CRLF newlines
   test-restore-input[ abort \ these aborts are skipped
   abort 0 [if]
       s" oops" 2drop ]test-restore-input abort
   [then]
   ( 0 ) throw
   
 \ comments across several lines  \ comments across several lines
   
 ( fjklfjlas;d  ( fjklfjlas;d
 abort" ( does not work across lines"  abort" ( does not work across lines"
 )  )
   
 s" ( testing ( without delimited by newline in non-files" evaluate  s" ( testing ( without being delimited by newline in non-files" evaluate
   
 \ last test!  \ last test!
 \ testing '(' without ')' at end-of-file  \ testing '(' without ')' at end-of-file

Removed from v.1.3  
changed lines
  Added in v.1.19


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