Add support for recursive let binding codegen
[scheme.git] / abi.md
diff --git a/abi.md b/abi.md
index 0185ec03acc4803a0bcc45f710d19d2ab23e77e1..eafb1748dbe009d527203948dd705cbed99ce486 100644 (file)
--- a/abi.md
+++ b/abi.md
@@ -26,6 +26,19 @@ lambda code  1st        2nd       3rd
 address      captive    captive   captive   ...
 ```
 
+## note on recursive closures
+
+The following example shows a recursive lambda, that results in a
+closure that captures itself.
+```
+(let ([f (closure lambda0 (f))])
+  (f 42))
+```
+When this happens, `codegen-let` will insert `(f . 'self-captive)`
+into the environment when codegen'ing the closure. `codegen-closure`
+will then pick this up, and use it to insert its own heap address into
+its inner environment.
+
 # lambdas
 
 lambdas use the system v amd64 calling convention.