| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | USING: arrays math parser tools.test kernel generic words | 
					
						
							| 
									
										
										
										
											2008-12-15 02:40:50 -05:00
										 |  |  | io.streams.string namespaces classes effects source-files assocs | 
					
						
							|  |  |  | sequences strings io.files io.pathnames definitions | 
					
						
							|  |  |  | continuations sorting classes.tuple compiler.units debugger | 
					
						
							| 
									
										
										
										
											2008-12-17 23:29:32 -05:00
										 |  |  | vocabs vocabs.loader accessors eval combinators lexer | 
					
						
							| 
									
										
										
										
											2009-04-22 08:05:00 -04:00
										 |  |  | vocabs.parser words.symbol multiline source-files.errors | 
					
						
							| 
									
										
										
										
											2009-05-13 23:15:48 -04:00
										 |  |  | tools.crossref grouping ;
 | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  | IN: parser.tests | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | [ | 
					
						
							| 
									
										
										
										
											2007-12-21 21:18:24 -05:00
										 |  |  |     [ 1 [ 2 [ 3 ] 4 ] 5 ] | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |     [ "1\n[\n2\n[\n3\n]\n4\n]\n5" eval( -- a b c ) ] | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-21 21:18:24 -05:00
										 |  |  |     [ t t f f ] | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |     [ "t t f f" eval( -- ? ? ? ? ) ] | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-21 21:18:24 -05:00
										 |  |  |     [ "hello world" ] | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |     [ "\"hello world\"" eval( -- string ) ] | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-21 21:18:24 -05:00
										 |  |  |     [ "\n\r\t\\" ] | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |     [ "\"\\n\\r\\t\\\\\"" eval( -- string ) ] | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ "hello world" ] | 
					
						
							|  |  |  |     [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: parser.tests : hello ( -- str ) \"hello world\" ;" | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |         eval( -- ) "USE: parser.tests hello" eval( -- string ) | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ ] | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |     [ "! This is a comment, people." eval( -- ) ] | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ! Test escapes | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-21 21:18:24 -05:00
										 |  |  |     [ " " ] | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |     [ "\"\\u000020\"" eval( -- string ) ] | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-21 21:18:24 -05:00
										 |  |  |     [ "'" ] | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |     [ "\"\\u000027\"" eval( -- string ) ] | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ! Test EOL comments in multiline strings. | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |     [ "Hello" ] [ "#! This calls until-eol.\n\"Hello\"" eval( -- string ) ] unit-test | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     [ word ] [ \ f class ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ! Test stack effect parsing | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     : effect-parsing-test ( a b -- c ) + ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ t ] [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         "effect-parsing-test" "parser.tests" lookup | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         \ effect-parsing-test eq?
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ T{ effect f { "a" "b" } { "c" } f } ] | 
					
						
							|  |  |  |     [ \ effect-parsing-test "declared-effect" word-prop ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     : baz ( a b -- * ) 2array throw ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ t ] | 
					
						
							| 
									
										
										
										
											2008-09-02 02:55:36 -04:00
										 |  |  |     [ \ baz "declared-effect" word-prop terminated?>> ] | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |     [ ] [ "IN: parser.tests USE: math : effect-parsing-test ( a b -- d ) - ;" eval( -- ) ] unit-test | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     [ t ] [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         "effect-parsing-test" "parser.tests" lookup | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         \ effect-parsing-test eq?
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ T{ effect f { "a" "b" } { "d" } f } ] | 
					
						
							|  |  |  |     [ \ effect-parsing-test "declared-effect" word-prop ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ! Funny bug | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |     [ 2 ] [ "IN: parser.tests : \0. ( -- x ) 2 ; \0." eval( -- n ) ] unit-test | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |     [ "IN: parser.tests : missing-- ( a b ) ;" eval( -- ) ] must-fail | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ! These should throw errors | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |     [ "HEX: zzz" eval( -- obj ) ] must-fail | 
					
						
							|  |  |  |     [ "OCT: 999" eval( -- obj ) ] must-fail | 
					
						
							|  |  |  |     [ "BIN: --0" eval( -- obj ) ] must-fail | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     DEFER: foo | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |     "IN: parser.tests USING: math prettyprint ; SYNTAX: foo 2 2 + . ;" eval( -- ) | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |     [ ] [ "USE: parser.tests foo" eval( -- ) ] unit-test | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |     "IN: parser.tests USING: math prettyprint ; : foo ( -- ) 2 2 + . ;" eval( -- ) | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     [ t ] [ | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |         "USE: parser.tests \\ foo" eval( -- word ) | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         "foo" "parser.tests" lookup eq?
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ! Test smudging | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ 1 ] [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: parser.tests : smudge-me ( -- ) ;" <string-reader> "foo" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         parse-stream drop
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-02 02:55:36 -04:00
										 |  |  |         "foo" source-file definitions>> first assoc-size
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |     [ t ] [ "smudge-me" "parser.tests" lookup >boolean ] unit-test | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: parser.tests : smudge-me-more ( -- ) ;" <string-reader> "foo" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |     [ t ] [ "smudge-me-more" "parser.tests" lookup >boolean ] unit-test | 
					
						
							|  |  |  |     [ f ] [ "smudge-me" "parser.tests" lookup >boolean ] unit-test | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     [ 3 ] [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: parser.tests USING: math strings ; GENERIC: smudge-me ( a -- b ) M: integer smudge-me ; M: string smudge-me ;" <string-reader> "foo" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         parse-stream drop
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-02 02:55:36 -04:00
										 |  |  |         "foo" source-file definitions>> first assoc-size
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ 1 ] [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         "IN: parser.tests USING: arrays ; M: array smudge-me ;" <string-reader> "bar" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         parse-stream drop
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-02 02:55:36 -04:00
										 |  |  |         "bar" source-file definitions>> first assoc-size
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ 2 ] [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: parser.tests USING: math strings ; GENERIC: smudge-me ( a -- b ) M: integer smudge-me ;" <string-reader> "foo" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         parse-stream drop
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-02 02:55:36 -04:00
										 |  |  |         "foo" source-file definitions>> first assoc-size
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] unit-test | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     [ t ] [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         array "smudge-me" "parser.tests" lookup order memq? | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] unit-test | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     [ t ] [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         integer "smudge-me" "parser.tests" lookup order memq? | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] unit-test | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     [ f ] [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         string "smudge-me" "parser.tests" lookup order memq? | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         "IN: parser.tests USE: math 2 2 +" <string-reader> "a" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     [ t ] [ | 
					
						
							|  |  |  |         "a" <pathname> \ + usage member?
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         "IN: parser.tests USE: math 2 2 -" <string-reader> "a" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     [ f ] [ | 
					
						
							|  |  |  |         "a" <pathname> \ + usage member?
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							|  |  |  |         "a" source-files get delete-at
 | 
					
						
							|  |  |  |         2 [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |             "IN: parser.tests DEFER: x : y ( -- ) x ; : x ( -- ) y ;" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |             <string-reader> "a" parse-stream drop
 | 
					
						
							|  |  |  |         ] times
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     "a" source-files get delete-at
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-06 14:47:19 -05:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: parser.tests : x ( -- ) ; : y ( -- * ) 3 throw ; this is an error" | 
					
						
							| 
									
										
										
										
											2008-02-06 14:47:19 -05:00
										 |  |  |         <string-reader> "a" parse-stream | 
					
						
							| 
									
										
										
										
											2008-06-25 05:06:18 -04:00
										 |  |  |     ] [ source-file-error? ] must-fail-with | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     [ t ] [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         "y" "parser.tests" lookup >boolean
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ f ] [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: parser.tests : x ( -- ) ;" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         <string-reader> "a" parse-stream drop
 | 
					
						
							|  |  |  |          | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         "y" "parser.tests" lookup | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ! Test new forward definition logic | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: axx : axx ( -- ) ;" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         <string-reader> "axx" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "USE: axx IN: bxx : bxx ( -- ) ; : cxx ( -- ) axx bxx ;" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         <string-reader> "bxx" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ! So we move the bxx word to axx... | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: axx : axx ( -- ) ; : bxx ( -- ) ;" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         <string-reader> "axx" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ t ] [ "bxx" "axx" lookup >boolean ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ! And reload the file that uses it... | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "USE: axx IN: bxx ( -- ) : cxx ( -- ) axx bxx ;" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         <string-reader> "bxx" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     ! And hope not to get a forward-error! | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ! Turning a generic into a non-generic could cause all | 
					
						
							|  |  |  |     ! kinds of funnyness | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: ayy USE: kernel GENERIC: ayy ( a -- b ) M: object ayy ;" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         <string-reader> "ayy" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: ayy USE: kernel : ayy ( -- ) ;" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         <string-reader> "ayy" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: azz TUPLE: my-class ; GENERIC: a-generic ( a -- b )" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         <string-reader> "azz" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							|  |  |  |         "USE: azz M: my-class a-generic ;" | 
					
						
							|  |  |  |         <string-reader> "azz-2" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: azz GENERIC: a-generic ( a -- b )" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         <string-reader> "azz" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							|  |  |  |         "USE: azz USE: math M: integer a-generic ;" | 
					
						
							|  |  |  |         <string-reader> "azz-2" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2009-04-17 13:45:57 -04:00
										 |  |  |         "IN: parser.tests : <bogus-error> ( -- ) ; : bogus ( -- error ) <bogus-error> ;" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         <string-reader> "bogus-error" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2009-04-17 13:45:57 -04:00
										 |  |  |         "IN: parser.tests TUPLE: bogus-error ; C: <bogus-error> bogus-error : bogus ( -- error ) <bogus-error> ;" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         <string-reader> "bogus-error" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ! Problems with class predicates -vs- ordinary words | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         "IN: parser.tests TUPLE: killer ;" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         <string-reader> "removing-the-predicate" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         "IN: parser.tests GENERIC: killer? ( a -- b )" | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         <string-reader> "removing-the-predicate" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     [ t ] [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         "killer?" "parser.tests" lookup >boolean
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-06 14:47:19 -05:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: parser.tests TUPLE: another-pred-test ; GENERIC: another-pred-test? ( a -- b )" | 
					
						
							| 
									
										
										
										
											2008-02-06 14:47:19 -05:00
										 |  |  |         <string-reader> "removing-the-predicate" parse-stream | 
					
						
							| 
									
										
										
										
											2008-06-25 05:06:18 -04:00
										 |  |  |     ] [ error>> error>> error>> redefine-error? ] must-fail-with | 
					
						
							| 
									
										
										
										
											2007-12-21 21:18:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-06 14:47:19 -05:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         "IN: parser.tests TUPLE: class-redef-test ; TUPLE: class-redef-test ;" | 
					
						
							| 
									
										
										
										
											2008-02-06 14:47:19 -05:00
										 |  |  |         <string-reader> "redefining-a-class-1" parse-stream | 
					
						
							| 
									
										
										
										
											2008-06-25 05:06:18 -04:00
										 |  |  |     ] [ error>> error>> error>> redefine-error? ] must-fail-with | 
					
						
							| 
									
										
										
										
											2007-12-21 21:18:24 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         "IN: parser.tests TUPLE: class-redef-test ; SYMBOL: class-redef-test" | 
					
						
							| 
									
										
										
										
											2007-12-21 21:18:24 -05:00
										 |  |  |         <string-reader> "redefining-a-class-2" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-06 14:47:19 -05:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: parser.tests TUPLE: class-redef-test ; SYMBOL: class-redef-test : class-redef-test ( -- ) ;" | 
					
						
							| 
									
										
										
										
											2008-02-06 14:47:19 -05:00
										 |  |  |         <string-reader> "redefining-a-class-3" parse-stream drop
 | 
					
						
							| 
									
										
										
										
											2008-06-25 05:06:18 -04:00
										 |  |  |     ] [ error>> error>> error>> redefine-error? ] must-fail-with | 
					
						
							| 
									
										
										
										
											2007-12-21 21:18:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-22 15:47:10 -05:00
										 |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         "IN: parser.tests TUPLE: class-fwd-test ;" | 
					
						
							| 
									
										
										
										
											2007-12-22 15:47:10 -05:00
										 |  |  |         <string-reader> "redefining-a-class-3" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-06 14:47:19 -05:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         "IN: parser.tests \\ class-fwd-test" | 
					
						
							| 
									
										
										
										
											2008-02-06 14:47:19 -05:00
										 |  |  |         <string-reader> "redefining-a-class-3" parse-stream drop
 | 
					
						
							| 
									
										
										
										
											2008-06-25 05:06:18 -04:00
										 |  |  |     ] [ error>> error>> error>> no-word-error? ] must-fail-with | 
					
						
							| 
									
										
										
										
											2007-12-21 21:18:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-22 15:47:10 -05:00
										 |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         "IN: parser.tests TUPLE: class-fwd-test ; SYMBOL: class-fwd-test" | 
					
						
							| 
									
										
										
										
											2007-12-22 15:47:10 -05:00
										 |  |  |         <string-reader> "redefining-a-class-3" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-06 14:47:19 -05:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |         "IN: parser.tests \\ class-fwd-test" | 
					
						
							| 
									
										
										
										
											2008-02-06 14:47:19 -05:00
										 |  |  |         <string-reader> "redefining-a-class-3" parse-stream drop
 | 
					
						
							| 
									
										
										
										
											2008-06-25 05:06:18 -04:00
										 |  |  |     ] [ error>> error>> error>> no-word-error? ] must-fail-with | 
					
						
							| 
									
										
										
										
											2007-12-25 18:10:05 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-06 14:47:19 -05:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: parser.tests : foo ( -- ) ; TUPLE: foo ;" | 
					
						
							| 
									
										
										
										
											2008-02-06 14:47:19 -05:00
										 |  |  |         <string-reader> "redefining-a-class-4" parse-stream drop
 | 
					
						
							| 
									
										
										
										
											2008-06-25 05:06:18 -04:00
										 |  |  |     ] [ error>> error>> error>> redefine-error? ] must-fail-with | 
					
						
							| 
									
										
										
										
											2008-02-06 20:23:39 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |         "IN: parser.tests : foo ( x y -- z ) 1 2 ; : bar ( a -- b ) ;" eval( -- ) | 
					
						
							| 
									
										
										
										
											2008-02-06 20:23:39 -05:00
										 |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |         "IN: parser.tests : foo ( x y -- z) 1 2 ; : bar ( a -- b ) ;" eval( -- ) | 
					
						
							| 
									
										
										
										
											2008-02-06 20:23:39 -05:00
										 |  |  |     ] must-fail | 
					
						
							| 
									
										
										
										
											2007-12-28 21:45:16 -05:00
										 |  |  | ] with-file-vocabs | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-24 19:40:09 -05:00
										 |  |  | [ ] [ | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |     "IN: parser.tests USE: kernel PREDICATE: foo < object ( x -- y ) ;" eval( -- ) | 
					
						
							| 
									
										
										
										
											2007-12-24 19:40:09 -05:00
										 |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ t ] [ | 
					
						
							| 
									
										
										
										
											2008-03-01 17:00:45 -05:00
										 |  |  |     "foo?" "parser.tests" lookup word eq?
 | 
					
						
							| 
									
										
										
										
											2007-12-24 19:40:09 -05:00
										 |  |  | ] unit-test | 
					
						
							| 
									
										
										
										
											2008-02-24 01:26:54 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | [ ] [ | 
					
						
							| 
									
										
										
										
											2008-03-18 22:43:29 -04:00
										 |  |  |     [ | 
					
						
							|  |  |  |         "redefining-a-class-5" forget-source | 
					
						
							|  |  |  |         "redefining-a-class-6" forget-source | 
					
						
							|  |  |  |         "redefining-a-class-7" forget-source | 
					
						
							|  |  |  |     ] with-compilation-unit | 
					
						
							| 
									
										
										
										
											2008-02-24 01:26:54 -05:00
										 |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-18 22:43:29 -04:00
										 |  |  | 2 [ | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: parser.tests TUPLE: foo ; GENERIC: foo ( a -- b )" | 
					
						
							| 
									
										
										
										
											2008-03-18 22:43:29 -04:00
										 |  |  |         <string-reader> "redefining-a-class-5" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							| 
									
										
										
										
											2008-02-24 01:26:54 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-18 22:43:29 -04:00
										 |  |  |     [ ] [ | 
					
						
							|  |  |  |         "IN: parser.tests M: f foo ;" | 
					
						
							|  |  |  |         <string-reader> "redefining-a-class-6" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							| 
									
										
										
										
											2008-02-24 01:26:54 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-18 22:43:29 -04:00
										 |  |  |     [ f ] [ f "foo" "parser.tests" lookup execute ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: parser.tests TUPLE: foo ; GENERIC: foo ( a -- b )" | 
					
						
							| 
									
										
										
										
											2008-03-18 22:43:29 -04:00
										 |  |  |         <string-reader> "redefining-a-class-5" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							| 
									
										
										
										
											2008-02-24 01:26:54 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-18 22:43:29 -04:00
										 |  |  |     [ f ] [ f "foo" "parser.tests" lookup execute ] unit-test | 
					
						
							| 
									
										
										
										
											2008-02-24 01:26:54 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-18 22:43:29 -04:00
										 |  |  |     [ ] [ | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  |         "IN: parser.tests TUPLE: foo ; GENERIC: foo ( a -- b )" | 
					
						
							| 
									
										
										
										
											2008-02-24 01:26:54 -05:00
										 |  |  |     <string-reader> "redefining-a-class-7" parse-stream drop
 | 
					
						
							| 
									
										
										
										
											2008-03-18 22:43:29 -04:00
										 |  |  |     ] unit-test | 
					
						
							| 
									
										
										
										
											2008-02-24 01:26:54 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-18 22:43:29 -04:00
										 |  |  |     [ f ] [ f "foo" "parser.tests" lookup execute ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							|  |  |  |         "IN: parser.tests TUPLE: foo ;" | 
					
						
							|  |  |  |         <string-reader> "redefining-a-class-7" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							| 
									
										
										
										
											2008-02-24 01:26:54 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-18 22:43:29 -04:00
										 |  |  |     [ t ] [ "foo" "parser.tests" lookup symbol? ] unit-test | 
					
						
							|  |  |  | ] times
 | 
					
						
							| 
									
										
										
										
											2008-02-26 22:03:14 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-16 21:11:36 -04:00
										 |  |  | [ "vocab:parser/test/assert-depth.factor" run-file ] must-fail | 
					
						
							| 
									
										
										
										
											2008-03-13 07:38:09 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 2 [ | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							|  |  |  |         "IN: parser.tests DEFER: d-f-s d-f-s SYMBOL: d-f-s d-f-s" | 
					
						
							|  |  |  |         <string-reader> "d-f-s-test" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							|  |  |  |         "IN: parser.tests DEFER: d-f-s d-f-s FORGET: d-f-s SYMBOL: d-f-s d-f-s" | 
					
						
							|  |  |  |         <string-reader> "d-f-s-test" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [ ] [ | 
					
						
							|  |  |  |         "IN: parser.tests DEFER: d-f-s d-f-s SYMBOL: d-f-s d-f-s" | 
					
						
							|  |  |  |         <string-reader> "d-f-s-test" parse-stream drop
 | 
					
						
							|  |  |  |     ] unit-test | 
					
						
							|  |  |  | ] times
 | 
					
						
							| 
									
										
										
										
											2008-03-18 18:46:25 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-20 18:58:35 -04:00
										 |  |  | [ ] [ | 
					
						
							|  |  |  |     [ "this-better-not-exist" forget-vocab ] with-compilation-unit | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |     "USE: this-better-not-exist" eval( -- ) | 
					
						
							| 
									
										
										
										
											2008-03-20 18:58:35 -04:00
										 |  |  | ] must-fail | 
					
						
							| 
									
										
										
										
											2008-04-25 02:54:42 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  | [ ": foo ;" eval( -- ) ] [ error>> error>> no-current-vocab? ] must-fail-with | 
					
						
							| 
									
										
										
										
											2008-05-01 22:49:23 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  | [ 92 ] [ "CHAR: \\" eval( -- n ) ] unit-test | 
					
						
							|  |  |  | [ 92 ] [ "CHAR: \\\\" eval( -- n ) ] unit-test | 
					
						
							| 
									
										
										
										
											2008-05-10 16:56:30 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | [ ] [ | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         "IN: parser.tests" | 
					
						
							| 
									
										
										
										
											2009-04-17 13:45:57 -04:00
										 |  |  |         "USING: math arrays kernel ;" | 
					
						
							|  |  |  |         "GENERIC: change-combination ( obj a -- b )" | 
					
						
							|  |  |  |         "M: integer change-combination 2drop 1 ;" | 
					
						
							|  |  |  |         "M: array change-combination 2drop 2 ;" | 
					
						
							| 
									
										
										
										
											2008-05-10 16:56:30 -04:00
										 |  |  |     } "\n" join <string-reader> "change-combination-test" parse-stream drop
 | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ ] [ | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         "IN: parser.tests" | 
					
						
							| 
									
										
										
										
											2009-04-17 13:45:57 -04:00
										 |  |  |         "USING: math arrays kernel ;" | 
					
						
							|  |  |  |         "GENERIC# change-combination 1 ( obj a -- b )" | 
					
						
							|  |  |  |         "M: integer change-combination 2drop 1 ;" | 
					
						
							|  |  |  |         "M: array change-combination 2drop 2 ;" | 
					
						
							| 
									
										
										
										
											2008-05-10 16:56:30 -04:00
										 |  |  |     } "\n" join <string-reader> "change-combination-test" parse-stream drop
 | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ 2 ] [ | 
					
						
							|  |  |  |     "change-combination" "parser.tests" lookup | 
					
						
							|  |  |  |     "methods" word-prop assoc-size
 | 
					
						
							|  |  |  | ] unit-test | 
					
						
							| 
									
										
										
										
											2008-05-23 18:33:57 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-28 20:34:18 -04:00
										 |  |  | [ ] [ | 
					
						
							| 
									
										
										
										
											2008-05-23 18:33:57 -04:00
										 |  |  |     2 [ | 
					
						
							| 
									
										
										
										
											2008-05-26 06:44:33 -04:00
										 |  |  |         "IN: parser.tests DEFER: twice-fails FORGET: twice-fails MIXIN: twice-fails" | 
					
						
							| 
									
										
										
										
											2008-05-28 20:34:18 -04:00
										 |  |  |         <string-reader> "twice-fails-test" parse-stream drop
 | 
					
						
							| 
									
										
										
										
											2008-05-23 18:33:57 -04:00
										 |  |  |     ] times
 | 
					
						
							|  |  |  | ] unit-test | 
					
						
							| 
									
										
										
										
											2008-05-26 06:44:33 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | [ [ ] ] [ | 
					
						
							| 
									
										
										
										
											2009-04-17 13:45:57 -04:00
										 |  |  |     "IN: parser.tests : staging-problem-test-1 ( -- a ) 1 ; : staging-problem-test-2 ( -- a ) staging-problem-test-1 ;" | 
					
						
							| 
									
										
										
										
											2008-05-26 06:44:33 -04:00
										 |  |  |     <string-reader> "staging-problem-test" parse-stream | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ t ] [ "staging-problem-test-1" "parser.tests" lookup >boolean ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ t ] [ "staging-problem-test-2" "parser.tests" lookup >boolean ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ [ ] ] [ | 
					
						
							| 
									
										
										
										
											2009-04-17 13:45:57 -04:00
										 |  |  |     "IN: parser.tests << : staging-problem-test-1 ( -- a ) 1 ; >> : staging-problem-test-2 ( -- a ) staging-problem-test-1 ;" | 
					
						
							| 
									
										
										
										
											2008-05-26 06:44:33 -04:00
										 |  |  |     <string-reader> "staging-problem-test" parse-stream | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ t ] [ "staging-problem-test-1" "parser.tests" lookup >boolean ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ t ] [ "staging-problem-test-2" "parser.tests" lookup >boolean ] unit-test | 
					
						
							| 
									
										
										
										
											2008-05-28 20:43:01 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  | [ "DEFER: blahy" eval( -- ) ] [ error>> error>> no-current-vocab? ] must-fail-with | 
					
						
							| 
									
										
										
										
											2008-06-25 04:25:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | [ | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  |     "IN: parser.tests SYNTAX: blahy ; FORGET: blahy" eval( -- ) | 
					
						
							| 
									
										
										
										
											2008-06-25 04:25:08 -04:00
										 |  |  | ] [ | 
					
						
							|  |  |  |     error>> staging-violation? | 
					
						
							|  |  |  | ] must-fail-with | 
					
						
							| 
									
										
										
										
											2008-11-02 04:10:27 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Bogus error message | 
					
						
							| 
									
										
										
										
											2008-12-17 23:29:32 -05:00
										 |  |  | DEFER: blahy | 
					
						
							| 
									
										
										
										
											2008-11-02 04:10:27 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  | [ "IN: parser.tests USE: kernel TUPLE: blahy < tuple ; : blahy ( -- ) ; TUPLE: blahy < tuple ; : blahy ( -- ) ;" eval( -- ) ] | 
					
						
							| 
									
										
										
										
											2008-12-17 23:29:32 -05:00
										 |  |  | [ error>> error>> def>> \ blahy eq? ] must-fail-with | 
					
						
							| 
									
										
										
										
											2008-11-21 01:18:25 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  | [ "CHAR: \\u9999999999999" eval( -- n ) ] must-fail | 
					
						
							| 
									
										
										
										
											2008-12-17 19:10:01 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | SYMBOLS: a b c ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ a ] [ a ] unit-test | 
					
						
							|  |  |  | [ b ] [ b ] unit-test | 
					
						
							|  |  |  | [ c ] [ c ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | DEFER: blah | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  | [ ] [ "IN: parser.tests GENERIC: blah ( -- )" eval( -- ) ] unit-test | 
					
						
							|  |  |  | [ ] [ "IN: parser.tests SYMBOLS: blah ;" eval( -- ) ] unit-test | 
					
						
							| 
									
										
										
										
											2008-12-17 19:10:01 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | [ f ] [ \ blah generic? ] unit-test | 
					
						
							|  |  |  | [ t ] [ \ blah symbol? ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-17 23:29:32 -05:00
										 |  |  | DEFER: blah1 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  | [ "IN: parser.tests SINGLETONS: blah1 blah1 blah1 ;" eval( -- ) ] | 
					
						
							| 
									
										
										
										
											2008-12-17 23:29:32 -05:00
										 |  |  | [ error>> error>> def>> \ blah1 eq? ] | 
					
						
							| 
									
										
										
										
											2008-12-17 19:10:01 -05:00
										 |  |  | must-fail-with | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | IN: qualified.tests.foo | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  | : x ( -- a ) 1 ;
 | 
					
						
							|  |  |  | : y ( -- a ) 5 ;
 | 
					
						
							| 
									
										
										
										
											2008-12-17 19:10:01 -05:00
										 |  |  | IN: qualified.tests.bar | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  | : x ( -- a ) 2 ;
 | 
					
						
							|  |  |  | : y ( -- a ) 4 ;
 | 
					
						
							| 
									
										
										
										
											2008-12-17 19:10:01 -05:00
										 |  |  | IN: qualified.tests.baz | 
					
						
							| 
									
										
										
										
											2009-03-23 01:34:02 -04:00
										 |  |  | : x ( -- a ) 3 ;
 | 
					
						
							| 
									
										
										
										
											2008-12-17 19:10:01 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | QUALIFIED: qualified.tests.foo | 
					
						
							|  |  |  | QUALIFIED: qualified.tests.bar | 
					
						
							|  |  |  | [ 1 2 3 ] [ qualified.tests.foo:x qualified.tests.bar:x x ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | QUALIFIED-WITH: qualified.tests.bar p | 
					
						
							|  |  |  | [ 2 ] [ p:x ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | RENAME: x qualified.tests.baz => y | 
					
						
							|  |  |  | [ 3 ] [ y ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | FROM: qualified.tests.baz => x ;
 | 
					
						
							|  |  |  | [ 3 ] [ x ] unit-test | 
					
						
							|  |  |  | [ 3 ] [ y ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | EXCLUDE: qualified.tests.bar => x ;
 | 
					
						
							|  |  |  | [ 3 ] [ x ] unit-test | 
					
						
							|  |  |  | [ 4 ] [ y ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-07 01:42:43 -05:00
										 |  |  | ! Two similar bugs | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Replace : def with something in << >> | 
					
						
							| 
									
										
										
										
											2009-03-16 01:05:43 -04:00
										 |  |  | /* [ [ ] ] [ | 
					
						
							| 
									
										
										
										
											2009-03-06 20:48:04 -05:00
										 |  |  |     "IN: parser.tests : was-once-a-word-bug ( -- ) ;" | 
					
						
							|  |  |  |     <string-reader> "was-once-a-word-test" parse-stream | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ t ] [ "was-once-a-word-bug" "parser.tests" lookup >boolean ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ [ ] ] [ | 
					
						
							|  |  |  |     "IN: parser.tests USE: words << \"was-once-a-word-bug\" \"parser.tests\" create [ ] (( -- )) define-declared >>" | 
					
						
							|  |  |  |     <string-reader> "was-once-a-word-test" parse-stream | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-16 01:05:43 -04:00
										 |  |  | [ t ] [ "was-once-a-word-bug" "parser.tests" lookup >boolean ] unit-test */ | 
					
						
							| 
									
										
										
										
											2009-03-07 01:42:43 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Replace : def with DEFER: | 
					
						
							|  |  |  | [ [ ] ] [ | 
					
						
							|  |  |  |     "IN: parser.tests : is-not-deferred ( -- ) ;" | 
					
						
							|  |  |  |     <string-reader> "is-not-deferred" parse-stream | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ t ] [ "is-not-deferred" "parser.tests" lookup >boolean ] unit-test | 
					
						
							|  |  |  | [ f ] [ "is-not-deferred" "parser.tests" lookup deferred? ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ [ ] ] [ | 
					
						
							|  |  |  |     "IN: parser.tests DEFER: is-not-deferred" | 
					
						
							|  |  |  |     <string-reader> "is-not-deferred" parse-stream | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ t ] [ "is-not-deferred" "parser.tests" lookup >boolean ] unit-test | 
					
						
							|  |  |  | [ t ] [ "is-not-deferred" "parser.tests" lookup deferred? ] unit-test | 
					
						
							| 
									
										
										
										
											2009-05-13 23:15:48 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Forward-reference resolution case iterated using list in the wrong direction | 
					
						
							|  |  |  | [ [ ] ] [ | 
					
						
							|  |  |  |     "IN: parser.tests.forward-ref-1 DEFER: x DEFER: y" | 
					
						
							|  |  |  |     <string-reader> "forward-ref-1" parse-stream | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ [ ] ] [ | 
					
						
							|  |  |  |     "IN: parser.tests.forward-ref-2 DEFER: x DEFER: y" | 
					
						
							|  |  |  |     <string-reader> "forward-ref-2" parse-stream | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ [ ] ] [ | 
					
						
							| 
									
										
										
										
											2009-05-16 01:29:21 -04:00
										 |  |  |     "IN: parser.tests.forward-ref-3 FROM: parser.tests.forward-ref-1 => x y ; FROM: parser.tests.forward-ref-2 => x y ; : z ( -- ) x y ;" | 
					
						
							| 
									
										
										
										
											2009-05-13 23:15:48 -04:00
										 |  |  |     <string-reader> "forward-ref-3" parse-stream | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ t ] [ | 
					
						
							|  |  |  |     "z" "parser.tests.forward-ref-3" lookup def>> [ vocabulary>> ] map all-equal? | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ [ ] ] [ | 
					
						
							| 
									
										
										
										
											2009-05-16 01:29:21 -04:00
										 |  |  |     "FROM: parser.tests.forward-ref-1 => x y ; FROM: parser.tests.forward-ref-2 => x y ; IN: parser.tests.forward-ref-3 : x ( -- ) ; : z ( -- ) x y ;" | 
					
						
							| 
									
										
										
										
											2009-05-13 23:15:48 -04:00
										 |  |  |     <string-reader> "forward-ref-3" parse-stream | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ f ] [ | 
					
						
							|  |  |  |     "z" "parser.tests.forward-ref-3" lookup def>> [ vocabulary>> ] map all-equal? | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ [ ] ] [ | 
					
						
							| 
									
										
										
										
											2009-05-16 01:29:21 -04:00
										 |  |  |     "IN: parser.tests.forward-ref-3 FROM: parser.tests.forward-ref-1 => x y ; FROM: parser.tests.forward-ref-2 => x y ; : z ( -- ) x y ;" | 
					
						
							| 
									
										
										
										
											2009-05-13 23:15:48 -04:00
										 |  |  |     <string-reader> "forward-ref-3" parse-stream | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ t ] [ | 
					
						
							|  |  |  |     "z" "parser.tests.forward-ref-3" lookup def>> [ vocabulary>> ] map all-equal? | 
					
						
							| 
									
										
										
										
											2009-05-16 10:34:42 -04:00
										 |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ [ dup ] ] [ | 
					
						
							|  |  |  |     "USE: kernel dup" <string-reader> "unuse-test" parse-stream | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ | 
					
						
							|  |  |  |     "dup" <string-reader> "unuse-test" parse-stream | 
					
						
							|  |  |  | ] [ error>> error>> error>> no-word-error? ] must-fail-with | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ | 
					
						
							|  |  |  |     "USE: kernel UNUSE: kernel dup" <string-reader> "unuse-test" parse-stream | 
					
						
							| 
									
										
										
										
											2009-05-22 02:59:50 -04:00
										 |  |  | ] [ error>> error>> error>> no-word-error? ] must-fail-with | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ ] [ [ "vocabs.loader.test.l" forget-vocab ] with-compilation-unit ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ | 
					
						
							|  |  |  |     [ "vocabs.loader.test.l" use-vocab ] must-fail | 
					
						
							|  |  |  |     [ f ] [ "vocabs.loader.test.l" manifest get search-vocab-names>> key? ] unit-test | 
					
						
							|  |  |  |     [ ] [ "vocabs.loader.test.l" unuse-vocab ] unit-test | 
					
						
							|  |  |  |     [ f ] [ "vocabs.loader.test.l" manifest get search-vocab-names>> key? ] unit-test     | 
					
						
							|  |  |  | ] with-file-vocabs |