]> git.eshelyaron.com Git - emacs.git/commitdiff
* doc/misc/cl.texi (Obsolete Macros): Describe replacements for `flet'.
authorStefan Monnier <monnier@iro.umontreal.ca>
Sat, 4 May 2013 19:49:23 +0000 (15:49 -0400)
committerStefan Monnier <monnier@iro.umontreal.ca>
Sat, 4 May 2013 19:49:23 +0000 (15:49 -0400)
Fixes: debbugs:14293
doc/misc/ChangeLog
doc/misc/cl.texi

index 5e9840a86b7e2e9ae7600c069b15a34913a169b7..74b08c047143ce626b9465c135468899fd501078 100644 (file)
@@ -1,3 +1,8 @@
+2013-05-04  Stefan Monnier  <monnier@iro.umontreal.ca>
+
+       * cl.texi (Obsolete Macros): Describe replacements for `flet'
+       (bug#14293).
+
 2013-04-16  Michael Albinus  <michael.albinus@gmx.de>
 
        * tramp.texi (Frequently Asked Questions): Precise, how to define
index 83df411cb2399466c97bdeb3aa2e5595594a1630..90f8a258d23e4dc0b4e4dc70d83d67c3869b0ae0 100644 (file)
@@ -4850,10 +4850,27 @@ generated directly inside Emacs will not be caught since they make
 direct C-language calls to the message routines rather than going
 through the Lisp @code{message} function.
 
+For those cases where the dynamic scoping of @code{flet} is desired,
+@code{cl-flet} is clearly not a substitute.  The most direct replacement would
+be instead to use @code{cl-letf} to temporarily rebind @code{(symbol-function
+'@var{fun})}.  But in most cases, a better substitute is to use an advice, such
+as:
+
+@example
+(defvar my-fun-advice-enable nil)
+(add-advice '@var{fun} :around
+            (lambda (orig &rest args)
+              (if my-fun-advice-enable (do-something)
+                (apply orig args))))
+@end example
+
+so that you can then replace the @code{flet} with a simple dynamically scoped
+binding of @code{my-fun-advice-enable}.
+
 @c Bug#411.
-Note that many primitives (e.g., @code{+}) have special byte-compile
-handling.  Attempts to redefine such functions using @code{flet} will
-fail if byte-compiled.
+Note that many primitives (e.g., @code{+}) have special byte-compile handling.
+Attempts to redefine such functions using @code{flet}, @code{cl-letf}, or an
+advice will fail when byte-compiled.
 @c Or cl-flet.
 @c In such cases, use @code{labels} instead.
 @end defmac