From: Alan Mackenzie <acm@muc.de>
To: emacs-devel@gnu.org
Subject: scratch/accurate-warning-pos: next steps.
Date: Mon, 10 Dec 2018 18:00:33 +0000 [thread overview]
Message-ID: <20181210180033.GC4188@ACM> (raw)
Hello, Emacs.
Here's my scheme for making further progress on the
scratch/accurate-warning-pos branch.
At the moment, it appears to display the requisite accurate source
positions in warning messages, but it slows Emacs down a little. Hence
it has not been accepted in its current form.
Following an idea from Paul, I propose to build an alternative byte-code
interpreter alongside the primary one. This second interpreter would
regard symbols with position as being EQ to the corresponding bare
symbols, just as the branch currently does when symbols-with-pos-enabled
is bound to non-nil.
C symbols in components of the second interpreter would be those of the
main one, prefixed by "BC_".
lisp.h would be modified to define alternative versions of EQ, NILP,
SYMBOLP, and XSYMBOL, and alternative versions of the INLINE functions
which call them. These would be called BC_EQ, BC_NILP, BC_SYMBOLP, and
BC_XSYMBOL.
Most of the C sources would, at build time, be fed to a preprocessor
which would analyse (almost every) C function, and write a temporary file
containing the functions foo and BC_foo next to eachother. foo would be
unchanged from the C source, BC_foo would have calls to bar modified to
BC_bar, and invocations of EQ etc., modified to BC_EQ, etc. These
preprocessor outputs would be compiled into temacs in place of the
primary C sources. The resulting temacs would, of course, be bigger than
the current temacs.
In particular, the byte code interpreter exec_byte_code in bytecode.c
would have its alternative BC_exec_byte_code.
The struct Lisp_Subr would be amended to hold three Lisp_Functions - the
currently live one, the normal one, and the BC_... one. Also a next
pointer would be introduced, chaining all the subrs together.
The .el and .elc files would not require amendment (apart from
bytecomp.el, and so on, of course).
When a byte compilation is initiated, the compiler would replace the
current live function field with the corresponding BC_ function in every
Lisp_Subr, thus switching over to the BC_... interpreter. At termination
of the compiler, an unwind-protect would restore the Lisp_Subrs to their
standard settings.
There remains the question, which C functions would get a BC_... version?
To begin with, I propose almost every C function. Only those for which a
second version would be damaging (for example, the command loop) would
remain unique. Once the mechanism is working, we could steadily reduce
the number of BC_... functions from "as many as possible" to "what is
needed ". For example, surely xdisp.c, and xterm.c would not need
duplication.
This scheme would allow accurate warning line numbers to be output,
whilst not slowing down the normal operation of Emacs. It would likely
slow down the operation of the byte compiler by several per cent, as has
been measured in the current scratch/accurate-warning-pos branch.
Comments?
--
Alan Mackenzie (Nuremberg, Germany).
next reply other threads:[~2018-12-10 18:00 UTC|newest]
Thread overview: 20+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-12-10 18:00 Alan Mackenzie [this message]
2018-12-10 18:15 ` scratch/accurate-warning-pos: next steps Eli Zaretskii
2018-12-10 18:28 ` Alan Mackenzie
2018-12-10 18:39 ` Eli Zaretskii
2018-12-10 19:35 ` Alan Mackenzie
2018-12-10 20:06 ` Eli Zaretskii
2018-12-10 21:03 ` Alan Mackenzie
2018-12-11 6:41 ` Eli Zaretskii
2018-12-11 19:21 ` Stefan Monnier
2018-12-11 19:07 ` Stefan Monnier
2018-12-10 23:54 ` Paul Eggert
2018-12-11 11:34 ` Alan Mackenzie
2018-12-11 18:05 ` Paul Eggert
2018-12-11 19:20 ` Alan Mackenzie
2018-12-11 19:59 ` Paul Eggert
2018-12-11 20:51 ` Alan Mackenzie
2018-12-11 21:11 ` Stefan Monnier
2018-12-11 21:35 ` Alan Mackenzie
2018-12-11 22:58 ` Stefan Monnier
2018-12-11 21:43 ` Paul Eggert
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=20181210180033.GC4188@ACM \
--to=acm@muc.de \
--cc=emacs-devel@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.
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs.git
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).