| 
									
										
										
										
											2008-12-09 05:21:50 -05:00
										 |  |  | USING: tools.test math kernel sequences lists promises monads ;
 | 
					
						
							| 
									
										
										
										
											2009-05-16 01:29:21 -04:00
										 |  |  | FROM: monads => do ;
 | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  | IN: monads.tests | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { 5 } [ 1 identity-monad return [ 4 + ] fmap run-identity ] unit-test | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  | [ "OH HAI" identity-monad fail ] must-fail | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { 666 } [ | 
					
						
							| 
									
										
										
										
											2013-03-24 04:38:25 -04:00
										 |  |  |     111 <just> [ 6 * ] fmap [ ] [ "OOPS" throw ] if-maybe | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { nothing } [ | 
					
						
							| 
									
										
										
										
											2013-03-24 04:38:25 -04:00
										 |  |  |     111 <just> [ maybe-monad fail ] bind | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { 100 } [ | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  |     5 either-monad return [ 10 * ] [ 20 * ] if-either | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { T{ left f "OOPS" } } [ | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  |     5 either-monad return >>= [ drop "OOPS" either-monad fail ] swap call
 | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { { 10 20 30 } } [ | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  |     { 1 2 3 } [ 10 * ] fmap | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { { } } [ | 
					
						
							| 
									
										
										
										
											2012-07-19 04:51:07 -04:00
										 |  |  |     { 1 2 3 } [ drop "OOPS" array-monad fail ] bind | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { 5 } [ | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  |     5 state-monad return "initial state" run-st | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { 8 } [ | 
					
						
							| 
									
										
										
										
											2012-07-19 04:51:07 -04:00
										 |  |  |     5 state-monad return [ 3 + state-monad return ] bind | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  |     "initial state" run-st | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { 8 } [ | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  |     5 state-monad return >>= | 
					
						
							|  |  |  |     [ 3 + state-monad return ] swap call
 | 
					
						
							|  |  |  |     "initial state" run-st | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { 11 } [ | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  |     f state-monad return >>= | 
					
						
							|  |  |  |     [ drop get-st ] swap call
 | 
					
						
							|  |  |  |     11 run-st | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { 15 } [ | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  |     f state-monad return
 | 
					
						
							| 
									
										
										
										
											2012-07-19 04:51:07 -04:00
										 |  |  |     [ drop get-st ] bind | 
					
						
							|  |  |  |     [ 4 + put-st ] bind | 
					
						
							|  |  |  |     [ drop get-st ] bind | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  |     11 run-st | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { 15 } [ | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  |     { | 
					
						
							|  |  |  |         [ f return-st ] | 
					
						
							|  |  |  |         [ drop get-st ] | 
					
						
							|  |  |  |         [ 4 + put-st ] | 
					
						
							|  |  |  |         [ drop get-st ] | 
					
						
							|  |  |  |     } do
 | 
					
						
							|  |  |  |     11 run-st | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { nothing } [ | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2013-03-24 04:38:25 -04:00
										 |  |  |         [ "hi" <just> ] | 
					
						
							|  |  |  |         [ " bye" append <just> ] | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  |         [ drop nothing ] | 
					
						
							| 
									
										
										
										
											2013-03-24 04:38:25 -04:00
										 |  |  |         [ reverse <just> ] | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  |     } do
 | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | LAZY: nats-from ( n -- list )
 | 
					
						
							| 
									
										
										
										
											2009-08-13 20:21:44 -04:00
										 |  |  |     dup 1 + nats-from cons ;
 | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-16 21:11:36 -04:00
										 |  |  | : nats ( -- list ) 0 nats-from ;
 | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { 3 } [ | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  |     { | 
					
						
							|  |  |  |         [ nats ] | 
					
						
							|  |  |  |         [ dup 3 = [ list-monad return ] [ list-monad fail ] if ] | 
					
						
							|  |  |  |     } do car | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { 9/11 } [ | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  |     { | 
					
						
							|  |  |  |         [ ask ] | 
					
						
							|  |  |  |     } do 9/11 run-reader | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { 8 } [ | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  |     { | 
					
						
							|  |  |  |         [ ask ] | 
					
						
							|  |  |  |         [ 3 + reader-monad return ] | 
					
						
							|  |  |  |     } do
 | 
					
						
							|  |  |  |     5 run-reader | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { 6 } [ | 
					
						
							| 
									
										
										
										
											2012-07-19 04:51:07 -04:00
										 |  |  |     f reader-monad return [ drop ask ] bind [ 1 + ] local 5 run-reader | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { f { 1 2 3 } } [ | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  |     5 writer-monad return
 | 
					
						
							| 
									
										
										
										
											2012-07-19 04:51:07 -04:00
										 |  |  |     [ drop { 1 2 3 } tell ] bind | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  |     run-writer | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { T{ identity f 7 } } | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  | [ | 
					
						
							|  |  |  |     4 identity-monad return
 | 
					
						
							|  |  |  |     [ 3 + ] identity-monad return
 | 
					
						
							|  |  |  |     identity-monad apply | 
					
						
							|  |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { nothing } [ | 
					
						
							| 
									
										
										
										
											2013-03-24 04:38:25 -04:00
										 |  |  |     5 <just> nothing maybe-monad apply | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  | ] unit-test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:39:59 -04:00
										 |  |  | { T{ just f 15 } } [ | 
					
						
							| 
									
										
										
										
											2013-03-24 04:38:25 -04:00
										 |  |  |     5 <just> [ 10 + ] <just> maybe-monad apply | 
					
						
							| 
									
										
										
										
											2008-05-03 05:44:02 -04:00
										 |  |  | ] unit-test |