GNU bug report logs -
#35250
Add simplest Advice example possible first
Previous Next
Reported by: 積丹尼 Dan Jacobson <jidanni <at> jidanni.org>
Date: Fri, 12 Apr 2019 22:49:03 UTC
Severity: wishlist
Tags: fixed
Fixed in version 27.1
Done: Lars Ingebrigtsen <larsi <at> gnus.org>
Bug is archived. No further changes may be made.
Full log
View this message in rfc822 format
積丹尼 Dan Jacobson <jidanni <at> jidanni.org> writes:
> (info "(elisp) Advising Functions") starts out with a complicated
> example.
>
> For example, in order to trace the calls to the process filter of a
> process PROC, you could use:
>
> (defun my-tracing-function (proc string)
> (message "Proc %S received %S" proc string))
>
> (add-function :before (process-filter PROC) #'my-tracing-function)
>
> Please first add the simplest example possible:
>
> Function A prints "a".
>
> Make it print "ab" from now on.
I've never used nadvice before, and I have to say that I found that
section a bit confusing, too, because my immediate response was (like
Dan's) to say "well, it should be trivial to make an advice that just
modifies the output", so I thought "well, :around has to be it".
But it isn't, :around is the super-flexible one:
(defun my-foo (x)
(* x 2))
(defun my-advice (old-fun x)
(+ (funcall old-fun x) 1))
(advice-add 'my-foo :around #'my-advice)
(my-foo 3)
=> 7
Instead :filter-return is it, and it's the one mentioned last. So I'm
adding this to the manual as an example first:
(defun my-double (x)
(* x 2))
(defun my-increase (x)
(+ x 1))
(advice-add 'my-double :filter-return #'my-increase)
(my-double 3)
7
--
(domestic pets only, the antidote for overdose, milk.)
bloggy blog: http://lars.ingebrigtsen.no
This bug report was last modified 6 years and 36 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.