From: Eli Zaretskii <eliz@gnu.org>
To: Emanuel Berg <incal@dataswamp.org>
Cc: emacs-devel@gnu.org
Subject: Re: how to speed up Lisp devel time
Date: Fri, 09 Aug 2024 10:24:49 +0300 [thread overview]
Message-ID: <86sevekvjy.fsf@gnu.org> (raw)
In-Reply-To: <87y156413v.fsf@dataswamp.org> (message from Emanuel Berg on Fri, 09 Aug 2024 09:16:52 +0200)
> From: Emanuel Berg <incal@dataswamp.org>
> Date: Fri, 09 Aug 2024 09:16:52 +0200
>
> One thing one could try is to replace boring, trivial stuff
> with non-Lisp syntax and have that embedded.
>
> For example setting up the interface.
>
> Note: Over one in five interfaces in the Emacs source uses
> Lisp and not the `interactive' format string. So it isn't just
> me. It takes _a lot_ of time setting up the interface,
> assigning default values, verifying indata, setting up
> collections for completion, and so on.
>
> Here is one example from my own code:
>
> ;; ...
> (interactive (if (numberp current-prefix-arg)
> (list current-prefix-arg)
> current-prefix-arg))
> (unless end
> (setq end 73))
> (unless step
> (setq step (min 10 (max 2 (/ end 10)))))
> (unless i
> (setq i 0))
> (unless (and (numberp i) (<= 0 i)
> (numberp end) (< 0 end)
> (numberp step) (< 0 step))
> (error "Bogus indata"))
>
> This is 402 chars!
Why do you need that? Interactive functions can supply the arguments
inside the 'interactive' spec, where no tests are needed. And
non-interactive functions need not provide defaults for each argument,
at least not usually.
And finally, Emacs does have keyword arguments and cl-defun, if and
when you need these facilities.
Just look at the Emacs sources: you will rarely if ever find such long
sequences of setting missing arguments to their defaults. That's no
accident.
next prev parent reply other threads:[~2024-08-09 7:24 UTC|newest]
Thread overview: 32+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-08-09 7:16 how to speed up Lisp devel time Emanuel Berg
2024-08-09 7:24 ` Eli Zaretskii [this message]
2024-08-09 7:39 ` Emanuel Berg
2024-08-09 10:43 ` Eli Zaretskii
2024-08-09 11:18 ` Emanuel Berg
2024-08-09 12:02 ` Eli Zaretskii
2024-08-09 13:54 ` Emanuel Berg
2024-08-09 14:58 ` Eli Zaretskii
2024-08-09 16:03 ` Emanuel Berg
2024-08-09 16:16 ` Emanuel Berg
2024-08-09 17:54 ` Eli Zaretskii
2024-08-09 18:56 ` Christopher Dimech
2024-08-09 21:57 ` Emanuel Berg
2024-08-09 21:47 ` Emanuel Berg
2024-08-09 17:27 ` Yuri Khan
2024-08-09 21:21 ` Emanuel Berg
2024-08-10 2:14 ` Emanuel Berg
2024-08-10 6:01 ` Yuri Khan
2024-08-10 6:08 ` Emanuel Berg
2024-08-10 6:44 ` Yuri Khan
2024-08-10 7:22 ` Emanuel Berg
2024-08-10 7:51 ` Emanuel Berg
2024-08-10 4:32 ` Emanuel Berg
2024-08-10 5:58 ` Eli Zaretskii
2024-08-09 14:59 ` Eduardo Ochs
2024-08-09 16:19 ` Emanuel Berg
2024-08-09 18:00 ` Eli Zaretskii
2024-08-09 18:54 ` Christopher Dimech
2024-08-09 22:17 ` Emanuel Berg
2024-08-09 22:00 ` Emanuel Berg
2024-08-09 8:24 ` Emanuel Berg
2024-08-09 10:36 ` Christopher Dimech
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
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=86sevekvjy.fsf@gnu.org \
--to=eliz@gnu.org \
--cc=emacs-devel@gnu.org \
--cc=incal@dataswamp.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.
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/emacs.git
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.