Still working on lisp recipes and idioms.
I have a list like this:
((a b c) (d e f) nil (g h))
I'd like to consolidate that to one list,
(a b c d e f g h)
Seems like there oughta be a one-liner for that.
(apply #'append '((a b c) (d e f) (g h i)))
or
(loop for outer in '((a b c) (d e f) (g h i))
nconcing (loop for inner in outer collecting inner))
That's a typical homework question. Generally this operation is called FLATTEN (which flattens lists on all levels).
(mapcan #'copy-list '((a b c) (d e f) nil (g h)))
The APPLY variant has the problem that it may run into the CALL-ARGUMENTS-LIMIT when there are more sublists than CALL-ARGUMENTS-LIMIT.
See for example also http://rosettacode.org/wiki/Flatten_a_list#Common_Lisp
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With