| 
									
										
										
										
											2009-05-13 17:58:01 -04:00
										 |  |  | USING: math tools.test classes.algebra words kernel sequences assocs | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | accessors eval definitions compiler.units generic strings classes | 
					
						
							|  |  |  | generic.single ;
 | 
					
						
							| 
									
										
										
										
											2009-05-13 17:58:01 -04:00
										 |  |  | IN: classes.predicate.tests | 
					
						
							| 
									
										
										
										
											2008-10-31 22:07:57 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | PREDICATE: negative < integer 0 < ;
 | 
					
						
							|  |  |  | PREDICATE: positive < integer 0 > ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { t } [ negative integer class< ] unit-test | 
					
						
							|  |  |  | { t } [ positive integer class< ] unit-test | 
					
						
							|  |  |  | { f } [ integer negative class< ] unit-test | 
					
						
							|  |  |  | { f } [ integer positive class< ] unit-test | 
					
						
							|  |  |  | { f } [ negative negative class< ] unit-test | 
					
						
							|  |  |  | { f } [ positive negative class< ] unit-test | 
					
						
							| 
									
										
										
										
											2008-11-04 03:17:22 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-31 22:07:57 -04:00
										 |  |  | GENERIC: abs ( n -- n )
 | 
					
						
							|  |  |  | M: integer abs ;
 | 
					
						
							|  |  |  | M: negative abs -1 * ;
 | 
					
						
							|  |  |  | M: positive abs ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { 10 } [ -10 abs ] unit-test | 
					
						
							|  |  |  | { 10 } [ 10 abs ] unit-test | 
					
						
							|  |  |  | { 0 } [ 0 abs ] unit-test | 
					
						
							| 
									
										
										
										
											2009-05-13 17:58:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Bug report from Bruno Deferrari | 
					
						
							|  |  |  | TUPLE: tuple-a slot ;
 | 
					
						
							|  |  |  | TUPLE: tuple-b < tuple-a ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PREDICATE: tuple-c < tuple-b slot>> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-07 23:30:57 -04:00
										 |  |  | GENERIC: ptest ( tuple -- x )
 | 
					
						
							|  |  |  | M: tuple-a ptest drop tuple-a ;
 | 
					
						
							|  |  |  | M: tuple-c ptest drop tuple-c ;
 | 
					
						
							| 
									
										
										
										
											2009-05-13 17:58:01 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { tuple-a } [ tuple-b new ptest ] unit-test | 
					
						
							|  |  |  | { tuple-c } [ tuple-b new t >>slot ptest ] unit-test | 
					
						
							| 
									
										
										
										
											2009-08-07 23:30:57 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | PREDICATE: tuple-d < tuple-a slot>> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: ptest' ( tuple -- x )
 | 
					
						
							|  |  |  | M: tuple-a ptest' drop tuple-a ;
 | 
					
						
							|  |  |  | M: tuple-d ptest' drop tuple-d ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { tuple-a } [ tuple-b new ptest' ] unit-test | 
					
						
							|  |  |  | { tuple-d } [ tuple-b new t >>slot ptest' ] unit-test | 
					
						
							| 
									
										
										
										
											2010-01-31 06:08:18 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | PREDICATE: bad-inheritance-predicate < string ;
 | 
					
						
							|  |  |  | [ | 
					
						
							|  |  |  |     "IN: classes.predicate.tests PREDICATE: bad-inheritance-predicate < bad-inheritance-predicate ;" eval( -- ) | 
					
						
							|  |  |  | ] [ error>> bad-inheritance? ] must-fail-with | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PREDICATE: bad-inheritance-predicate2 < string ;
 | 
					
						
							|  |  |  | PREDICATE: bad-inheritance-predicate3 < bad-inheritance-predicate2 ;
 | 
					
						
							|  |  |  | [ | 
					
						
							|  |  |  |     "IN: classes.predicate.tests PREDICATE: bad-inheritance-predicate2 < bad-inheritance-predicate3 ;" eval( -- ) | 
					
						
							|  |  |  | ] [ error>> bad-inheritance? ] must-fail-with | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! This must not fail | 
					
						
							|  |  |  | PREDICATE: tup < string ;
 | 
					
						
							|  |  |  | UNION: u tup ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { } [ "IN: classes.predicate.tests PREDICATE: u < tup ;" eval( -- ) ] unit-test | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Changing the metaclass of the predicate superclass should work | 
					
						
							|  |  |  | GENERIC: change-meta-test ( a -- b )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TUPLE: change-meta-test-class length ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PREDICATE: change-meta-test-predicate < change-meta-test-class length>> 2 > ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: change-meta-test-predicate change-meta-test length>> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { f } [ \ change-meta-test "methods" word-prop assoc-empty? ] unit-test | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | [ T{ change-meta-test-class f 0 } change-meta-test ] [ no-method? ] must-fail-with | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { 7 } [ T{ change-meta-test-class f 7 } change-meta-test ] unit-test | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { } [ "IN: classes.predicate.tests USE: arrays UNION: change-meta-test-class array ;" eval( -- ) ] unit-test | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Should not have changed | 
					
						
							| 
									
										
										
										
											2015-07-20 08:51:16 -04:00
										 |  |  | { change-meta-test-class } [ change-meta-test-predicate superclass-of ] unit-test | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | [ { } change-meta-test ] [ no-method? ] must-fail-with | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { 4 } [ { 1 2 3 4 } change-meta-test ] unit-test | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { } [ [ \ change-meta-test-class forget-class ] with-compilation-unit ] unit-test | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { f } [ change-meta-test-predicate class? ] unit-test | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-02 20:28:17 -04:00
										 |  |  | { t } [ \ change-meta-test "methods" word-prop assoc-empty? ] unit-test |