| 
									
										
										
										
											2008-06-03 04:04:20 -04:00
										 |  |  | ! Copyright (C) 2006 Chris Double. | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2008-08-30 11:15:09 -04:00
										 |  |  | USING: kernel help.markup help.syntax ;
 | 
					
						
							| 
									
										
										
										
											2008-06-03 04:04:20 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | IN: lists | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | { car cons cdr nil nil? list? uncons } related-words | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | HELP: cons  | 
					
						
							|  |  |  | { $values { "car" "the head of the lazy list" } { "cdr" "the tail of the lazy list" } { "cons" "a cons object" } } | 
					
						
							|  |  |  | { $description "Constructs a cons cell." } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | HELP: car | 
					
						
							|  |  |  | { $values { "cons" "a cons object" } { "car" "the first item in the list" } } | 
					
						
							|  |  |  | { $description "Returns the first item in the list." } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | HELP: cdr | 
					
						
							|  |  |  | { $values { "cons" "a cons object" } { "cdr" "a cons object" } } | 
					
						
							|  |  |  | { $description "Returns the tail of the list." } ;
 | 
					
						
							| 
									
										
										
										
											2008-06-05 04:13:51 -04:00
										 |  |  |      | 
					
						
							| 
									
										
										
										
											2008-06-03 04:04:20 -04:00
										 |  |  | HELP: nil  | 
					
						
							| 
									
										
										
										
											2008-06-05 18:53:58 -04:00
										 |  |  | { $values { "symbol" "The empty cons (+nil+)" } } | 
					
						
							|  |  |  | { $description "Returns a symbol representing the empty list" } ;
 | 
					
						
							| 
									
										
										
										
											2008-06-03 04:04:20 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | HELP: nil?  | 
					
						
							| 
									
										
										
										
											2008-08-30 11:15:09 -04:00
										 |  |  | { $values { "object" object } { "?" "a boolean" } } | 
					
						
							| 
									
										
										
										
											2008-06-03 04:04:20 -04:00
										 |  |  | { $description "Return true if the cons object is the nil cons." } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | HELP: list? ( object -- ? )
 | 
					
						
							|  |  |  | { $values { "object" "an object" } { "?" "a boolean" } } | 
					
						
							|  |  |  | { $description "Returns true if the object conforms to the list protocol." } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | { 1list 2list 3list } related-words | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | HELP: 1list | 
					
						
							|  |  |  | { $values { "obj" "an object" } { "cons" "a cons object" } } | 
					
						
							|  |  |  | { $description "Create a list with 1 element." } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | HELP: 2list | 
					
						
							|  |  |  | { $values { "a" "an object" } { "b" "an object" } { "cons" "a cons object" } } | 
					
						
							|  |  |  | { $description "Create a list with 2 elements." } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | HELP: 3list | 
					
						
							|  |  |  | { $values { "a" "an object" } { "b" "an object" } { "c" "an object" } { "cons" "a cons object" } } | 
					
						
							| 
									
										
										
										
											2008-06-03 16:28:02 -04:00
										 |  |  | { $description "Create a list with 3 elements." } ;
 | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  | HELP: lnth | 
					
						
							|  |  |  | { $values { "n" "an integer index" } { "list" "a cons object" } { "elt" "the element at the nth index" } } | 
					
						
							|  |  |  | { $description "Outputs the nth element of the list." }  | 
					
						
							|  |  |  | { $see-also llength cons car cdr } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | HELP: llength | 
					
						
							|  |  |  | { $values { "list" "a cons object" } { "n" "a non-negative integer" } } | 
					
						
							|  |  |  | { $description "Outputs the length of the list. This should not be called on an infinite list." }  | 
					
						
							|  |  |  | { $see-also lnth cons car cdr } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | HELP: uncons | 
					
						
							| 
									
										
										
										
											2008-06-05 04:13:51 -04:00
										 |  |  | { $values { "cons" "a cons object" }  { "cdr" "the tail of the list" } { "car" "the head of the list" } } | 
					
						
							| 
									
										
										
										
											2008-06-03 16:28:02 -04:00
										 |  |  | { $description "Put the head and tail of the list on the stack." } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-05 04:13:51 -04:00
										 |  |  | { leach foldl lmap>array } related-words | 
					
						
							| 
									
										
										
										
											2008-06-03 16:31:38 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | HELP: leach | 
					
						
							|  |  |  | { $values { "list" "a cons object" } { "quot" "a quotation with stack effect ( obj -- )" } } | 
					
						
							|  |  |  | { $description "Call the quotation for each item in the list." } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-05 04:13:51 -04:00
										 |  |  | HELP: foldl | 
					
						
							|  |  |  | { $values { "list" "a cons object" } { "identity" "an object" } { "quot" "a quotation with stack effect ( prev elt -- next )" } { "result" "the final result" } } | 
					
						
							|  |  |  | { $description "Combines successive elements of the list (in a left-assocative order) using a binary operation and outputs the final result." } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | HELP: foldr | 
					
						
							| 
									
										
										
										
											2008-06-03 16:31:38 -04:00
										 |  |  | { $values { "list" "a cons object" } { "identity" "an object" } { "quot" "a quotation with stack effect ( prev elt -- next )" } { "result" "the final result" } } | 
					
						
							| 
									
										
										
										
											2008-06-05 04:13:51 -04:00
										 |  |  | { $description "Combines successive elements of the list (in a right-assocative order) using a binary operation, and outputs the final result." } ;
 | 
					
						
							| 
									
										
										
										
											2008-06-03 16:31:38 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-05 04:13:51 -04:00
										 |  |  | HELP: lmap | 
					
						
							|  |  |  | { $values { "list" "a cons object" } { "quot" "a quotation with stack effect ( old -- new )" } { "result" "the final result" } } | 
					
						
							|  |  |  | { $description "Applies the quotation to each element of the list in order, collecting the new elements into a new list." } ;
 | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  | HELP: lreverse | 
					
						
							|  |  |  | { $values { "list" "a cons object" } { "newlist" "a new cons object" } } | 
					
						
							|  |  |  | { $description "Reverses the input list, outputing a new, reversed list" } ;
 | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  | HELP: list>seq     | 
					
						
							|  |  |  | { $values { "list" "a cons object" } { "array" "an array object" } } | 
					
						
							|  |  |  | { $description "Turns the given cons object into an array, maintaing order." } ;
 | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  | HELP: seq>list | 
					
						
							| 
									
										
										
										
											2008-06-05 18:53:58 -04:00
										 |  |  | { $values { "seq" "a sequence" } { "list" "a cons object" } } | 
					
						
							| 
									
										
										
										
											2008-06-05 04:13:51 -04:00
										 |  |  | { $description "Turns the given array into a cons object, maintaing order." } ;
 | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  | HELP: cons>seq | 
					
						
							|  |  |  | { $values { "cons" "a cons object" } { "array" "an array object" } } | 
					
						
							|  |  |  | { $description "Recursively turns the given cons object into an array, maintaing order and also converting nested lists." } ;
 | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  | HELP: seq>cons | 
					
						
							|  |  |  | { $values { "seq" "a sequence object" } { "cons" "a cons object" } } | 
					
						
							|  |  |  | { $description "Recursively turns the given sequence into a cons object, maintaing order and also converting nested lists." } ;
 | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  | HELP: traverse     | 
					
						
							| 
									
										
										
										
											2008-06-05 18:53:58 -04:00
										 |  |  | { $values { "list"  "a cons object" } { "pred" "a quotation with stack effect ( list/elt -- ? )" } | 
					
						
							| 
									
										
										
										
											2008-06-05 04:13:51 -04:00
										 |  |  |           { "quot" "a quotation with stack effect ( list/elt -- result)" }  { "result" "a new cons object" } } | 
					
						
							| 
									
										
										
										
											2008-06-05 14:31:43 -04:00
										 |  |  | { $description "Recursively traverses the list object, replacing any elements (which can themselves be sublists) that pred"  | 
					
						
							|  |  |  |     " returns true for with the result of applying quot to." } ;
 | 
					
						
							| 
									
										
										
										
											2008-06-05 04:13:51 -04:00
										 |  |  |      |