| 
									
										
										
										
											2008-07-20 05:24:37 -04:00
										 |  |  | IN: stack-checker.transforms.tests | 
					
						
							|  |  |  | USING: sequences stack-checker.transforms tools.test math kernel | 
					
						
							| 
									
										
										
										
											2009-04-10 08:08:16 -04:00
										 |  |  | quotations stack-checker stack-checker.errors accessors combinators words arrays | 
					
						
							| 
									
										
										
										
											2008-07-20 05:24:37 -04:00
										 |  |  | classes classes.tuple ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-22 05:21:15 -04:00
										 |  |  | : compose-n ( quot n -- ) "OOPS" throw ;
 | 
					
						
							| 
									
										
										
										
											2009-04-20 22:15:19 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | << | 
					
						
							| 
									
										
										
										
											2009-04-22 05:21:15 -04:00
										 |  |  | : compose-n-quot ( word n -- quot' ) <repetition> >quotation ;
 | 
					
						
							| 
									
										
										
										
											2008-07-20 05:24:37 -04:00
										 |  |  | \ compose-n [ compose-n-quot ] 2 define-transform | 
					
						
							| 
									
										
										
										
											2009-04-20 22:15:19 -04:00
										 |  |  | \ compose-n t "no-compile" set-word-prop | 
					
						
							|  |  |  | >> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-20 05:24:37 -04:00
										 |  |  | : compose-n-test ( a b c -- x ) 2 \ + compose-n ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ 6 ] [ 1 2 3 compose-n-test ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TUPLE: color r g b ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | C: <color> color | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : cleave-test ( color -- r g b )
 | 
					
						
							|  |  |  |     { [ r>> ] [ g>> ] [ b>> ] } cleave ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | { 1 3 } [ cleave-test ] must-infer-as | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ 1 2 3 ] [ 1 2 3 <color> cleave-test ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ 1 2 3 ] [ 1 2 3 <color> \ cleave-test def>> call ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : 2cleave-test ( a b -- c d e ) { [ 2array ] [ + ] [ - ] } 2cleave ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ { 1 2 } 3 -1 ] [ 1 2 2cleave-test ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ { 1 2 } 3 -1 ] [ 1 2 \ 2cleave-test def>> call ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : spread-test ( a b c -- d e f ) { [ sq ] [ neg ] [ recip ] } spread ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ 16 -3 1/6 ] [ 4 3 6 spread-test ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ 16 -3 1/6 ] [ 4 3 6 \ spread-test def>> call ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ fixnum instance? ] must-infer | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : bad-new-test ( -- obj ) V{ } new ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ bad-new-test ] must-infer | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ bad-new-test ] must-fail | 
					
						
							| 
									
										
										
										
											2009-02-06 05:38:54 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Corner case if macro expansion calls 'infer', found by Doug | 
					
						
							|  |  |  | DEFER: smart-combo ( quot -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \ smart-combo [ infer [ ] curry ] 1 define-transform | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ [ "a" "b" "c" ] smart-combo ] must-infer | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ [ [ "a" "b" ] smart-combo "c" ] smart-combo ] must-infer | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : very-smart-combo ( quot -- ) smart-combo ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ [ "a" "b" "c" ] very-smart-combo ] must-infer | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ [ [ "a" "b" ] very-smart-combo "c" ] very-smart-combo ] must-infer | 
					
						
							| 
									
										
										
										
											2009-02-06 11:21:55 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Caveat found by Doug | 
					
						
							|  |  |  | DEFER: curry-folding-test ( quot -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \ curry-folding-test [ length \ drop <repetition> >quotation ] 1 define-transform | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | { 3 0 } [ [ 1 2 3 ] curry-folding-test ] must-infer-as | 
					
						
							|  |  |  | { 3 0 } [ 1 [ 2 3 ] curry curry-folding-test ] must-infer-as | 
					
						
							| 
									
										
										
										
											2009-03-21 04:10:21 -04:00
										 |  |  | { 3 0 } [ [ 1 2 ] 3 [ ] curry compose curry-folding-test ] must-infer-as | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : member?-test ( a -- ? ) { 1 2 3 10 7 58 } member? ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ f ] [ 1.0 member?-test ] unit-test | 
					
						
							| 
									
										
										
										
											2009-04-10 08:08:16 -04:00
										 |  |  | [ t ] [ \ member?-test def>> first [ member?-test ] all? ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Macro expansion should throw its own type of error | 
					
						
							|  |  |  | : bad-macro ( -- ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \ bad-macro [ "OOPS" throw ] 0 define-transform | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ [ bad-macro ] infer ] [ inference-error? ] must-fail-with |