From: bojohan+news@dd.chalmers.se (Johan Bockgård)
To: help-gnu-emacs@gnu.org
Subject: Re: Elisp questions... where to ask?
Date: Sat, 15 Dec 2007 11:56:01 +0100 [thread overview]
Message-ID: <yoijaboc9qgu.fsf@remote1.student.chalmers.se> (raw)
In-Reply-To: 08f8db25-aed0-460c-a990-ebc1ec05b2a3@b1g2000pra.googlegroups.com
Santanu <thisissantanu@gmail.com> writes:
> I wrote the following piece of code in the scratch buffer:
> ---------------------------------------------------------------------------------
> (define-skeleton test1
> "Prompt for name"
> "name:" str ? (test2)) <Ctrl+x, Ctrl+e>
>
> (define-skeleton test2
> "Prompt for surname"
> "surname:" str) <Ctrl+x, Ctrl+e>
>
> (test1) <Ctrl+x, Ctrl+e> santanu chatterjee
> ---------------------------------------------------------------------------------
> Now when I run the test1 function, and give "santanu" and
> "chatterjee" as the inputs to the two prompts, I get the result
> as shown above. But that happens in Emacs 21.x. But in
> Emacs 22.x and above, this creates some kind of infinite
> recursion, and I am placed in a debug buffer.
>
> Can you reproduce the same thing in your system? If so,
> could you let me know what exactly should be done to make
> this run in emacs 22.x and above. I tried to go through the
> emacs NEWS for 22.x and I did find some things related to
> skeleton.el, but due to my lack of knowledge of elisp, I could
> not make out much from it.
This seems to be a bug in skeleton. There was a change made to
skeleton-proxy-new
;; Return non-nil to tell expand-abbrev that expansion has happened.
;; Otherwise the no-self-insert is ignored.
t)
but skeleton-internal-1 is not prepared to handle `t' returned from a
subskeleton.
This seems to do the right thing:
*** skeleton.el.~1.51.~ 2007-08-14 19:24:04.000000000 +0200
--- skeleton.el 2007-12-15 11:28:36.000000000 +0100
***************
*** 424,429 ****
--- 424,430 ----
(skeleton-internal-list element (car literal))
(setq literal (cdr literal)))))
((null element))
+ ((eq t element))
(t (skeleton-internal-1 (eval element) t recursive))))
\f
;; Maybe belongs into simple.el or elsewhere
--
Johan Bockgård
next prev parent reply other threads:[~2007-12-15 10:56 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-12-15 6:30 Elisp questions... where to ask? Santanu
2007-12-15 10:56 ` Johan Bockgård [this message]
2007-12-17 6:10 ` Santanu
2007-12-17 6:59 ` Santanu
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.gnu.org/software/emacs/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=yoijaboc9qgu.fsf@remote1.student.chalmers.se \
--to=bojohan+news@dd.chalmers.se \
--cc=help-gnu-emacs@gnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).