[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Guile-commits] 01/02: Add documentation for else, =>, _, ... aux syntax
From: |
Andy Wingo |
Subject: |
[Guile-commits] 01/02: Add documentation for else, =>, _, ... aux syntax |
Date: |
Thu, 19 Sep 2019 09:50:52 -0400 (EDT) |
wingo pushed a commit to branch master
in repository guile.
commit 462782af86a723cad40c505fe81a26046959f3a8
Author: Andy Wingo <address@hidden>
Date: Thu Sep 19 15:24:14 2019 +0200
Add documentation for else, =>, _, ... aux syntax
* doc/ref/api-macros.texi (Syntax Rules): Document aux syntax.
---
doc/ref/api-macros.texi | 20 ++++++++++++++++++++
1 file changed, 20 insertions(+)
diff --git a/doc/ref/api-macros.texi b/doc/ref/api-macros.texi
index 2e00369..83345a2 100644
--- a/doc/ref/api-macros.texi
+++ b/doc/ref/api-macros.texi
@@ -248,6 +248,26 @@ lawyers probably see the need here for use of
@code{literal-identifier=?} rather
than @code{free-identifier=?}, and would probably be correct. Patches
accepted.}.
+@cindex auxiliary syntax
+@cindex syntax, auxiliary
+Although literals can be unbound, usually they are bound to allow them
+to be imported, exported, and renamed. @xref{Modules}, for more
+information on imports and exports. In Guile there are a few standard
+auxiliary syntax definitions, as specified by R6RS and R7RS:
+
+@deffn {Scheme Syntax} else
+@deffnx {Scheme Syntax} =>
+@deffnx {Scheme Syntax} _
+@deffnx {Scheme Syntax} ...
+Auxiliary syntax definitions.
+
+These are defined as if with a macro that never matches, e.g.:
+
+@example
+(define-syntax else (syntax-rules ()))
+@end example
+@end deffn
+
If a pattern is not a list, vector, or an identifier, it matches as a literal,
with @code{equal?}.