diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2015-11-15 08:13:42 -0800 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2015-11-20 16:17:18 -0800 |
commit | 4d2ab06904fd69c0fc7ba3c5237127726ab5c98b (patch) | |
tree | bc4b0613b7af5e914fc70e6d6b20cf1a71e0cbc1 | |
parent | 3cad8dfa357c5733c94e2a301da9184f3eb50e78 (diff) | |
download | txr-4d2ab06904fd69c0fc7ba3c5237127726ab5c98b.tar.gz txr-4d2ab06904fd69c0fc7ba3c5237127726ab5c98b.tar.bz2 txr-4d2ab06904fd69c0fc7ba3c5237127726ab5c98b.zip |
Functors: structs callable as functions.
* lib.c (generic_funcall): If an object is used as a function,
get its lambda method and call that.
* txr.1: Document functors.
-rw-r--r-- | lib.c | 3 | ||||
-rw-r--r-- | txr.1 | 30 |
2 files changed, 33 insertions, 0 deletions
@@ -4762,6 +4762,9 @@ val generic_funcall(val fun, struct args *args_in) default: callerror(fun, lit("too many arguments")); } + } else if (structp(fun)) { + fun = method(fun, lambda_s); + break; } /* fallthrough */ default: @@ -18150,6 +18150,28 @@ A structure type is associated with a static initialization function which may be used to store initial values into static slots. It is invoked when the type is created. +.NP* Functors + +A structure object can be invoked as a function, if it supports an "anonymous" +method. An anonymous method is one whose name is the +.code lambda +symbol. When arguments are applied to an object +.codn s , +the object and those arguments are passed to the +.code lambda +method. If there is no such method, the call is erroneous. + +That is to say, the following equivalences apply, except that +.code s +is evaluated only once: + +.cblk + (call s args ...) <--> s.(lambda args ...) + + [s args ...] <--> [s.lambda s args ...] + + (mapcar s list) <--> (mapcar (meth s lambda) list) +.cble .coNP Macro @ defstruct .synb @@ -18541,6 +18563,14 @@ are placed into a named .codn name . +A method named +.code lambda +allows a structure to be used as if it were a function. When arguments +are applied to the structure as if it were a function, the +.code lambda +method is invoked with those arguments, with the object itself inserted +into the leftmost argument position. + .coNP Macro @ new .synb .mets (new >> { name | >> ( name << arg *)} >> { slot << init-form }*) |