
 
	 
Tom's Lisp types already mentioned include integers, strings and identifiers. There are also closures, macros and errors, which are covered in later sections. Here, we discuss the list structure, which gives Lisp much of its flexibility and character.
A list is just a series of other data items (any of which may also be lists) separated by spaces and surrounded by parentheses. Lisp function calls are lists, so if you enter a list without using a tick, Tom's Lisp will attempt to evaluate it as a function call.
The basic operations on lists are car, cdr and cons. The car operation returns the head (first member) of the list. The cdr returns the balance of the list after the first item. The cons operation takes an item and a list and adds the item to front of the list.
Each operation works on its arguments and computes and returns a new list. Tom's Lisp never updates an existing list. It always creates and returns a new list. The unintuitive names car and cdr are historic. (Translation: It's the way we've always done it, and it too much trouble to change.)
The empty list is (), but it also goes by the names nil and #f, the later indicating “false”
There are several abbreviations useful when repeatedly using car and cdr. For instance,
There is also a useful utility which simply makes a list out of its arguments.
Car, cons and cdr are the fundamental list operations. Any list can be built or examined with these. As most lisps, though, Tom's Lisp does add a few extras for convenience:
| length | Return the length of a list. | 
| append | Append two or more lists together. | 
| first | Takes an integer n and a list l, and returns the first n items of list l. | 
| last | Takes an integer n and a list l, and returns the last n items of list l. | 
| first-but | Takes an integer n and a list l, and returns l, omitting the first n items. | 
| last-but | Takes an integer n and a list l, and returns l, omitting the last n items. | 
| nth | Takes an integer n and a list l, and returns the nth member of l, counting from zero. | 
Lists are built with pairs. For instance, the list
The pair is the result of cons, and the car and cdr operations extract the first and second item from the pair.