| 
									
										
										
										
											2009-02-24 00:28:02 -05:00
										 |  |  | ! Copyright (C) 2007, 2009 Slava Pestov, Daniel Ehrenberg. | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2008-12-08 01:10:24 -05:00
										 |  |  | USING: math kernel memoize tools.test parser generalizations | 
					
						
							| 
									
										
										
										
											2009-03-11 18:33:54 -04:00
										 |  |  | prettyprint io.streams.string sequences eval namespaces see ;
 | 
					
						
							| 
									
										
										
										
											2008-04-26 00:17:08 -04:00
										 |  |  | IN: memoize.tests | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | MEMO: fib ( m -- n )
 | 
					
						
							|  |  |  |     dup 1 <= [ drop 1 ] [ dup 1 - fib swap 2 - fib + ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ 89 ] [ 10 fib ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  | [ "USING: kernel math memoize generalizations ; IN: memoize.tests MEMO: x ( a b c d e -- f g h i j ) [ 1+ ] 4 ndip ;" eval( -- ) ] must-fail | 
					
						
							| 
									
										
										
										
											2008-05-28 19:17:58 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | MEMO: see-test ( a -- b ) reverse ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ "USING: memoize sequences ;\nIN: memoize.tests\nMEMO: see-test ( a -- b ) reverse ;\n" ] | 
					
						
							|  |  |  | [ [ \ see-test see ] with-string-writer ] | 
					
						
							|  |  |  | unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-17 16:49:21 -04:00
										 |  |  | [ ] [ "IN: memoize.tests : fib ( -- ) ;" eval( -- ) ] unit-test | 
					
						
							| 
									
										
										
										
											2008-05-28 19:17:58 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | [ "IN: memoize.tests\n: fib ( -- ) ;\n" ] [ [ \ fib see ] with-string-writer ] unit-test | 
					
						
							| 
									
										
										
										
											2009-02-24 00:28:02 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | [ sq ] (( a -- b )) memoize-quot "q" set
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [ 9 ] [ 3 "q" get call ] unit-test |