* bug#51621: 29.0.50; bibtex.el biblatex "2.1.3 Non-standard Types" support
@ 2021-11-05 23:35 Leonard Lausen
2021-11-07 3:37 ` Roland Winkler
` (2 more replies)
0 siblings, 3 replies; 11+ messages in thread
From: Leonard Lausen @ 2021-11-05 23:35 UTC (permalink / raw)
To: 51621; +Cc: winkler
biblatex types such as @audio, @music, @review from section 2.1.3 of the
biblatex documentation are not considered by bibtex.el's biblatex
dialect implementation. The standard styles treat these types (with
exceptions) like @misc. An example of an exception is @review, which is
a more specific variant of the @article type.
I think the types are called non-standard, because the standard
bibliography styles provide no bibliography drivers for these types, but
these types are known to the default data model and will be happily
accepted by biber.
The impact is that emacs will not recognize entries of those types as
valid entries, and prevent referencing them via org-cite or applying
operations such as bibtex-clean-entry.
To reproduce run `emacs -Q`. Then switch to `bibtex-mode` and set
`(bibtex-set-dialect 'biblatex t)`. Finally paste (taken from
https://tex.stackexchange.com/a/435059/106845)
@audio{Smith2018,
author={Stacey Vanek Smith and Stanley Plotkin},
title={The Economics of Vaccines},
howpublished={NPR},
organization={Planet Money}
month=6,
year=2010,
series={Planet Money},
url={https://www.npr.org/templates/transcript/transcript.php?storyId=616926505}
}
and navigate the cursor into the @audio entry. Then execute `M-x
bibtex-clean-entry` and observe "Not inside a BibTex entry" error
message.
Would it make sense to add support for these types to bibtex.el?
In GNU Emacs 29.0.50 (build 1, x86_64-pc-linux-gnu, GTK+ Version 3.24.29, cairo version 1.16.0)
of 2021-11-05 built on leonard-xps13
Repository revision: 37632dae180e9d5196ef01343fefa9234c5f05b9
Repository branch: feature/pgtk
Repository: https://github.com/leezu/emacs
Windowing system distributor 'System Description: Gentoo/Linux
Configured using:
'configure --with-cairo --with-x-toolkit=no --with-pgtk --with-modules
--with-native-compilation --prefix=/home/leonard/local'
Configured features:
ACL CAIRO DBUS FREETYPE GIF GLIB GMP GNUTLS GPM GSETTINGS HARFBUZZ JPEG
JSON LCMS2 LIBOTF LIBSYSTEMD LIBXML2 MODULES NATIVE_COMP NOTIFY INOTIFY
PDUMPER PGTK PNG RSVG SECCOMP SOUND THREADS TIFF TOOLKIT_SCROLL_BARS XIM
GTK3 ZLIB
Important settings:
value of $LC_COLLATE: C
value of $LC_CTYPE: zh_CN.UTF-8
value of $LANG: en_US.UTF-8
locale-coding-system: utf-8-unix
Major mode: BibTeX
Minor modes in effect:
tooltip-mode: t
global-eldoc-mode: t
show-paren-mode: t
electric-indent-mode: t
mouse-wheel-mode: t
tool-bar-mode: t
menu-bar-mode: t
file-name-shadow-mode: t
global-font-lock-mode: t
font-lock-mode: t
blink-cursor-mode: t
auto-composition-mode: t
auto-encryption-mode: t
auto-compression-mode: t
line-number-mode: t
indent-tabs-mode: t
transient-mark-mode: t
Load-path shadows:
None found.
Features:
(shadow sort mail-extr emacsbug message rmc puny dired dired-loaddefs
rfc822 mml mml-sec epa derived epg rfc6068 epg-config gnus-util rmail
rmail-loaddefs auth-source cl-seq eieio eieio-core cl-macs
eieio-loaddefs password-cache json map text-property-search seq gv
byte-opt bytecomp byte-compile cconv mm-decode mm-bodies mm-encode
mail-parse rfc2231 mailabbrev gmm-utils mailheader sendmail rfc2047
rfc2045 ietf-drums mm-util mail-prsvr mail-utils bibtex iso8601
time-date subr-x help-mode cl-loaddefs cl-lib china-util iso-transl
tooltip eldoc paren electric uniquify ediff-hook vc-hooks
lisp-float-type elisp-mode mwheel term/pgtk-win pgtk-win term/common-win
tool-bar dnd fontset image regexp-opt fringe tabulated-list replace
newcomment text-mode lisp-mode prog-mode register page tab-bar menu-bar
rfn-eshadow isearch easymenu timer select scroll-bar mouse jit-lock
font-lock syntax font-core term/tty-colors frame minibuffer cl-generic
cham georgian utf-8-lang misc-lang vietnamese tibetan thai tai-viet lao
korean japanese eucjp-ms cp51932 hebrew greek romanian slovak czech
european ethiopic indian cyrillic chinese composite emoji-zwj charscript
charprop case-table epa-hook jka-cmpr-hook help simple abbrev obarray
cl-preloaded nadvice button loaddefs faces cus-face macroexp files
window text-properties overlay sha1 md5 base64 format env code-pages
mule custom widget hashtable-print-readable backquote threads dbusbind
inotify dynamic-setting system-font-setting font-render-setting cairo
move-toolbar gtk x-toolkit pgtk lcms2 multi-tty make-network-process
native-compile emacs)
Memory information:
((conses 16 86191 6454)
(symbols 48 7175 0)
(strings 32 24675 1427)
(string-bytes 1 773743)
(vectors 16 15122)
(vector-slots 8 363616 15516)
(floats 8 24 48)
(intervals 56 325 0)
(buffers 992 10))
^ permalink raw reply [flat|nested] 11+ messages in thread
* bug#51621: 29.0.50; bibtex.el biblatex "2.1.3 Non-standard Types" support
2021-11-05 23:35 bug#51621: 29.0.50; bibtex.el biblatex "2.1.3 Non-standard Types" support Leonard Lausen
@ 2021-11-07 3:37 ` Roland Winkler
2024-12-01 4:33 ` Leo Stein
2024-12-02 14:05 ` Roland Winkler
2 siblings, 0 replies; 11+ messages in thread
From: Roland Winkler @ 2021-11-07 3:37 UTC (permalink / raw)
To: Leonard Lausen; +Cc: 51621
On Fri, Nov 05 2021, Leonard Lausen wrote:
> Would it make sense to add support for these types to bibtex.el?
I myself do not use biblatex. But it seems to me that the sheer number
of entry types supported by biblatex gets overwhelming and inefficient
for users that may use only a subset of all biblatex entry types. Could
it make sense to break down the list of biblatex entry types into two
customizable subsets such that commands like bibtex-entry and the menu
"Entry-Types" list only the "important" entry types, whereas functions
like bibtex-validate accept the complete set of entry types supported by
biblatex?
Roland
^ permalink raw reply [flat|nested] 11+ messages in thread
* bug#51621: 29.0.50; bibtex.el biblatex "2.1.3 Non-standard Types" support
2021-11-05 23:35 bug#51621: 29.0.50; bibtex.el biblatex "2.1.3 Non-standard Types" support Leonard Lausen
2021-11-07 3:37 ` Roland Winkler
@ 2024-12-01 4:33 ` Leo Stein
2024-12-02 14:05 ` Roland Winkler
2 siblings, 0 replies; 11+ messages in thread
From: Leo Stein @ 2024-12-01 4:33 UTC (permalink / raw)
To: leonard, 51621
[-- Attachment #1: Type: text/plain, Size: 1479 bytes --]
Hi,
I wanted to raise a bug report but found this earlier one from 3 years ago
that was almost the same as my own. I was confused about why BibTeX-mode
was happily fontifying a doi=... field within a @software entry, and
attaching a button to it, but I could not follow the URL — because
BibTeX-mode thinks @software is not an allowed type within the "BibTeX"
"dialect". So, bibtex-parse-entry returns nil. This is because the regex
bibtex-entry-head is built from all "valid" entry types of the "dialect".
However, there is no reason @software, or any other type of entry, should
be an "invalid" entry in a bibtex file. It's the purview of whatever bibtex
style (defined in a .bst file) to determine what to do with different
entries. Some bst's default to passing things along to the @misc entry
type. But, I count 7 different bst's in the 2024 TeXLive tree that define a
@software type, and I'm sure there are many more custom types (e.g. the TeX
User's Group's tugboat.bst defines an entry type for @ctan , i.e. to cite
an entry on the Comprehensive TeX Archive Network).
I'm starting to think that the "dialect" design within bibtex.el was
confused about bibtex vs. biblatex (this is pretty confusing, as we can see
here: https://tex.stackexchange.com/q/25701/34063). However, I'm not sure
what is the correct solution. At the very least, bibtex.el should be more
permissive about what entry types get parsed by bibtex-parse-entry.
Best
Leo
[-- Attachment #2: Type: text/html, Size: 1767 bytes --]
^ permalink raw reply [flat|nested] 11+ messages in thread
* bug#51621: 29.0.50; bibtex.el biblatex "2.1.3 Non-standard Types" support
2021-11-05 23:35 bug#51621: 29.0.50; bibtex.el biblatex "2.1.3 Non-standard Types" support Leonard Lausen
2021-11-07 3:37 ` Roland Winkler
2024-12-01 4:33 ` Leo Stein
@ 2024-12-02 14:05 ` Roland Winkler
2024-12-02 17:23 ` Leo Stein
2025-01-02 5:59 ` Roland Winkler
2 siblings, 2 replies; 11+ messages in thread
From: Roland Winkler @ 2024-12-02 14:05 UTC (permalink / raw)
To: 51621; +Cc: Leo Stein, Leonard Lausen
> I'm starting to think that the "dialect" design within bibtex.el was
> confused about bibtex vs. biblatex (this is pretty confusing, as we
> can see here: https://tex.stackexchange.com/q/25701/34063). However,
> I'm not sure what is the correct solution. At the very least,
> bibtex.el should be more permissive about what entry types get parsed
> by bibtex-parse-entry.
The range of "acceptable" entry types needs to be compatible with the
BibTeX style files that one wants to use. Certainly, these style files
can be modified to handle any entry types you like. But I am not sure
it makes sense to extend the defaults of bibtex.el beyond the defaults
defined by BibTeX and / or biblatex. If you want to use the full range
of entry types defined by biblatex, you may be served better by making
biblatex your default dialect of bibtex-mode. (I find it useful if
bibtex-mode keeps track of the entry types known to a dialect.)
I am currently working on a patch for bibtex-mode that will make it
easier for users to customize the entry types known by a dialect,
including the possibility to define aliases for entry types. This patch
should be installed on master in a few weeks. (I want to test it
first.)
PS: My reading of the above thread on stackexchange is that it will not
make everyone happy if the distinction between old BibTeX and new
biblatex gets blurred by bibtex-mode.
^ permalink raw reply [flat|nested] 11+ messages in thread
* bug#51621: 29.0.50; bibtex.el biblatex "2.1.3 Non-standard Types" support
2024-12-02 14:05 ` Roland Winkler
@ 2024-12-02 17:23 ` Leo Stein
2024-12-03 20:37 ` Roland Winkler
2025-01-02 5:59 ` Roland Winkler
1 sibling, 1 reply; 11+ messages in thread
From: Leo Stein @ 2024-12-02 17:23 UTC (permalink / raw)
To: Roland Winkler; +Cc: Leonard Lausen, 51621
[-- Attachment #1: Type: text/plain, Size: 2676 bytes --]
Dear Roland,
First of all, thanks for maintaining this very handy mode!
On Mon, Dec 2, 2024 at 8:05 AM Roland Winkler <winkler@gnu.org> wrote:
> > I'm starting to think that the "dialect" design within bibtex.el was
> > confused about bibtex vs. biblatex (this is pretty confusing, as we
> > can see here: https://tex.stackexchange.com/q/25701/34063). However,
> > I'm not sure what is the correct solution. At the very least,
> > bibtex.el should be more permissive about what entry types get parsed
> > by bibtex-parse-entry.
>
> The range of "acceptable" entry types needs to be compatible with the
> BibTeX style files that one wants to use. Certainly, these style files
> can be modified to handle any entry types you like. But I am not sure
> it makes sense to extend the defaults of bibtex.el beyond the defaults
> defined by BibTeX and / or biblatex.
I really wish this was more permissive. Looking at a .bib file, we have no
way of knowing the biblio style that it's going to be set with. We also
have no way of knowing whether the user is going to parse it with bibtex or
biber.
> If you want to use the full range
> of entry types defined by biblatex, you may be served better by making
> biblatex your default dialect of bibtex-mode. (I find it useful if
> bibtex-mode keeps track of the entry types known to a dialect.)
>
I am still missing something... as far as I can tell, the "dialect" is just
controlling which entries are valid. Is that right? But this is not within
the purview of whether we use bibtex, or biber+biblatex. It depends on the
biblio style that the user wants to use for setting their bibliography.
>
> I am currently working on a patch for bibtex-mode that will make it
> easier for users to customize the entry types known by a dialect,
> including the possibility to define aliases for entry types. This patch
> should be installed on master in a few weeks. (I want to test it
> first.)
>
I'm happy to hear that there will be future improvements. I sincerely
request that parsing of entries be made more permissive — not restricted to
a list of entry types, or relying on the user to make some customizations
[I think most users are not going to discover that it's possible
to customize this].
>
> PS: My reading of the above thread on stackexchange is that it will not
> make everyone happy if the distinction between old BibTeX and new
> biblatex gets blurred by bibtex-mode.
>
Again I don't understand why bibtex-mode is making a distinction. The
syntax of the .bib is identical whether the user wants to use bibtex or
biber+biblatex.
Best,
Leo
[-- Attachment #2: Type: text/html, Size: 3745 bytes --]
^ permalink raw reply [flat|nested] 11+ messages in thread
* bug#51621: 29.0.50; bibtex.el biblatex "2.1.3 Non-standard Types" support
2024-12-02 17:23 ` Leo Stein
@ 2024-12-03 20:37 ` Roland Winkler
2024-12-03 21:12 ` Leo Stein
0 siblings, 1 reply; 11+ messages in thread
From: Roland Winkler @ 2024-12-03 20:37 UTC (permalink / raw)
To: Leo Stein; +Cc: Leonard Lausen, 51621
On Mon, Dec 02 2024, Leo Stein wrote:
> I really wish this was more permissive. Looking at a .bib file, we
> have no way of knowing the biblio style that it's going to be set
> with. We also have no way of knowing whether the user is going to
> parse it with bibtex or biber.
The user needs to know whether she wants to use a bib file with BibTeX
or biblatex and use entry types these programs can handle. Bibtex-mode
cannot be blamed for this.
> I am still missing something... as far as I can tell, the "dialect" is
> just controlling which entries are valid. Is that right? But this is
> not within the purview of whether we use bibtex, or biber+biblatex. It
> depends on the biblio style that the user wants to use for setting
> their bibliography.
Beyond the defaults documented for BibTeX and biblatex, you are free to
write your own bst style files, and you are free to customize
bibtex-mode to your liking. Everything we discuss here refers only to
user options of bibtex-mode.
The defaults of bibtex-mode match the defaults specified in the
documentation of BibTeX and biblatex. It would be confusing for users
of bibtex-mode to deviate from that.
> I'm happy to hear that there will be future improvements.
The goal is to facilitate the customization of bibtex-mode. I see no
reason to change the defaults of user variables.
> I sincerely request that parsing of entries be made more permissive —
> not restricted to a list of entry types, or relying on the user to
> make some customizations [I think most users are not going to discover
> that it's possible to customize this].
It is a basic aspect of Emacs that users can customize its behavior.
But Emacs cannot (yet) read the mind of its users and foresee the
customizations they want.
I have heard rumors that reading the users' mind will become a user
option in Emacs 42. (But I do not know whether this option will be
enabled by default.)
^ permalink raw reply [flat|nested] 11+ messages in thread
* bug#51621: 29.0.50; bibtex.el biblatex "2.1.3 Non-standard Types" support
2024-12-03 20:37 ` Roland Winkler
@ 2024-12-03 21:12 ` Leo Stein
0 siblings, 0 replies; 11+ messages in thread
From: Leo Stein @ 2024-12-03 21:12 UTC (permalink / raw)
To: Roland Winkler; +Cc: Leonard Lausen, 51621
[-- Attachment #1: Type: text/plain, Size: 3131 bytes --]
On Tue, Dec 3, 2024 at 2:37 PM Roland Winkler <winkler@gnu.org> wrote:
> On Mon, Dec 02 2024, Leo Stein wrote:
> > I really wish this was more permissive. Looking at a .bib file, we
> > have no way of knowing the biblio style that it's going to be set
> > with. We also have no way of knowing whether the user is going to
> > parse it with bibtex or biber.
>
> The user needs to know whether she wants to use a bib file with BibTeX
> or biblatex and use entry types these programs can handle. Bibtex-mode
> cannot be blamed for this.
>
We are both re-hashing the same points. I will say again that both bibtex
and biber+biblatex can handle any types of entries. I think the more
flexible approach is to permissive about entry types, and allow
bibtex-parse-entry to parse an entry of any type, not just a fixed list of
default types from (i) btxdoc.pdf, a piece of documentation from 1988; and
(ii) biblatex.pdf, the documentation for a latex package, not the parser,
biber, which indeed allows any entry type.
>
> > I am still missing something... as far as I can tell, the "dialect" is
> > just controlling which entries are valid. Is that right? But this is
> > not within the purview of whether we use bibtex, or biber+biblatex. It
> > depends on the biblio style that the user wants to use for setting
> > their bibliography.
>
> Beyond the defaults documented for BibTeX and biblatex, you are free to
> write your own bst style files, and you are free to customize
> bibtex-mode to your liking. Everything we discuss here refers only to
> user options of bibtex-mode.
>
> The defaults of bibtex-mode match the defaults specified in the
> documentation of BibTeX and biblatex. It would be confusing for users
> of bibtex-mode to deviate from that.
>
You don't understand why you say it would be confusing. Just like emacs can
not read users' minds, I don't see how you can be sure about what would be
confusing. There are common entry types, e.g. @software, which are in very
wide use with standard bibtex.
>
> > I'm happy to hear that there will be future improvements.
>
> The goal is to facilitate the customization of bibtex-mode. I see no
> reason to change the defaults of user variables.
>
> > I sincerely request that parsing of entries be made more permissive —
> > not restricted to a list of entry types, or relying on the user to
> > make some customizations [I think most users are not going to discover
> > that it's possible to customize this].
>
> It is a basic aspect of Emacs that users can customize its behavior.
> But Emacs cannot (yet) read the mind of its users and foresee the
> customizations they want.
>
> I have heard rumors that reading the users' mind will become a user
> option in Emacs 42. (But I do not know whether this option will be
> enabled by default.)
>
You don't have to try to read my mind — I am trying to make my mind known
to the devs by emailing this list. I continue to strongly request
that bibtex-parse-entry should be more permissive about parsing types than
a predefined list from 1988.
[-- Attachment #2: Type: text/html, Size: 3916 bytes --]
^ permalink raw reply [flat|nested] 11+ messages in thread
* bug#51621: 29.0.50; bibtex.el biblatex "2.1.3 Non-standard Types" support
2024-12-02 14:05 ` Roland Winkler
2024-12-02 17:23 ` Leo Stein
@ 2025-01-02 5:59 ` Roland Winkler
2025-01-06 19:49 ` Leo Stein
1 sibling, 1 reply; 11+ messages in thread
From: Roland Winkler @ 2025-01-02 5:59 UTC (permalink / raw)
To: 51621; +Cc: Leo Stein, Leonard Lausen
On Mon, Dec 02 2024, Roland Winkler wrote:
> I am currently working on a patch for bibtex-mode that will make it
> easier for users to customize the entry types known by a dialect,
> including the possibility to define aliases for entry types. This
> patch should be installed on master in a few weeks. (I want to test
> it first.)
I added new variables bibtex-BibTeX-aux-entry-alist and
bibtex-biblatex-aux-entry-alist that should facilitate the customization
of entry types. Also, these variables now accept aliases. Please try
it out.
commit b26418694e8
^ permalink raw reply [flat|nested] 11+ messages in thread
* bug#51621: 29.0.50; bibtex.el biblatex "2.1.3 Non-standard Types" support
2025-01-02 5:59 ` Roland Winkler
@ 2025-01-06 19:49 ` Leo Stein
2025-01-13 5:56 ` Roland Winkler
0 siblings, 1 reply; 11+ messages in thread
From: Leo Stein @ 2025-01-06 19:49 UTC (permalink / raw)
To: Roland Winkler; +Cc: Leonard Lausen, 51621
[-- Attachment #1: Type: text/plain, Size: 1668 bytes --]
Dear Roland,
Happy new year! I'm glad you are adding more customization. 1. Why is the
standard value of bibtex-BibTeX-aux-entry-alist given as '(("Conference"
"Article in Conference Proceedings" "InProceedings")) ? 2. I still don't
understand the point of making a distinction between "dialects". As I've
tried to emphasize before, which fields are accepted is under the purview
of the bst (for bibtex) or bbx/cbx/lbx file (for biber+biblatex) that the
user will eventually use. That can't be inferred from the contents of a
.bib file; in fact, a .bib file could be used in multiple different
projects with different bst/bbx/cbx/lbx files, all of which allow for
different fields. I still maintain that the best approach is to be
permissive about *parsing* entries in bibtex-parse-entry. That is a
different question from the contents of templates provided by C-c C-e
[KEY], for which of course the mode must know about the structure of each
given entry.
Best
Leo
On Thu, Jan 2, 2025 at 12:00 AM Roland Winkler <winkler@gnu.org> wrote:
> On Mon, Dec 02 2024, Roland Winkler wrote:
> > I am currently working on a patch for bibtex-mode that will make it
> > easier for users to customize the entry types known by a dialect,
> > including the possibility to define aliases for entry types. This
> > patch should be installed on master in a few weeks. (I want to test
> > it first.)
>
> I added new variables bibtex-BibTeX-aux-entry-alist and
> bibtex-biblatex-aux-entry-alist that should facilitate the customization
> of entry types. Also, these variables now accept aliases. Please try
> it out.
>
> commit b26418694e8
>
[-- Attachment #2: Type: text/html, Size: 2110 bytes --]
^ permalink raw reply [flat|nested] 11+ messages in thread
* bug#51621: 29.0.50; bibtex.el biblatex "2.1.3 Non-standard Types" support
2025-01-06 19:49 ` Leo Stein
@ 2025-01-13 5:56 ` Roland Winkler
2025-01-18 3:05 ` Leo Stein
0 siblings, 1 reply; 11+ messages in thread
From: Roland Winkler @ 2025-01-13 5:56 UTC (permalink / raw)
To: Leo Stein; +Cc: Leonard Lausen, 51621
On Mon, Jan 06 2025, Leo Stein wrote:
> I'm glad you are adding more customization. 1. Why is the standard
> value of bibtex-BibTeX-aux-entry-alist given as '(("Conference"
> "Article in Conference Proceedings" "InProceedings")) ? 2. I still
> don't understand the point of making a distinction between
> "dialects". As I've tried to emphasize before, which fields are
> accepted is under the purview of the bst (for bibtex) or bbx/cbx/lbx
> file (for biber+biblatex) that the user will eventually use. That
> can't be inferred from the contents of a .bib file; in fact, a .bib
> file could be used in multiple different projects with different
> bst/bbx/cbx/lbx files, all of which allow for different fields. I
> still maintain that the best approach is to be permissive about
> *parsing* entries in bibtex-parse-entry. That is a different question
> from the contents of templates provided by C-c C-e [KEY], for which of
> course the mode must know about the structure of each given entry.
I was looking at this again. In theory, this is all (more or less)
straightforward. In real life, BibTeX is tricky because
"there is no formal specification of the language. This means that
users exploring the arcane corners of the language are largely on
their own, and programmers implementing their own parsers are
completely on their own---except for observing the behaviour of the
original implementation."
This quote is taken from the most accurate documentation of the
BibTeX "language" I am aware of,
https://metacpan.org/dist/Text-BibTeX/view/btparse/doc/bt_language.pod
This documentation was written by the author of btparse, which is the
BibTeX parser used by biber / biblatex. So these problems are the same
under conventional BibTeX and biblatex.
Emacs bibtex-mode needs to come up with its own parser, for which it
follows a conservative approach that explicitly defines valid entries.
Agreed, this approach is not perfect. But trying to do better is an
arduous undertaking full of hidden pitfalls.
^ permalink raw reply [flat|nested] 11+ messages in thread
* bug#51621: 29.0.50; bibtex.el biblatex "2.1.3 Non-standard Types" support
2025-01-13 5:56 ` Roland Winkler
@ 2025-01-18 3:05 ` Leo Stein
0 siblings, 0 replies; 11+ messages in thread
From: Leo Stein @ 2025-01-18 3:05 UTC (permalink / raw)
To: Roland Winkler; +Cc: Leonard Lausen, 51621
[-- Attachment #1: Type: text/plain, Size: 3486 bytes --]
Dear Roland,
That web site looks quite good, thanks for sending the link. This spurred
me on to see what bibtex's own documentation looks like. CTAN contains the
bibtex.web source file in biblio/bibtex/base. That is ultimately the
specification of how bibtex parses, and also generates its documentation,
which is available in e.g. TeXLive at the
path texmf-dist/doc/generic/knuth-pdf/bibtex/bibtex.pdf .
There we can see that when parsing an entry, if the entry type is found in
a hash that's populated from a bst file, the bool type_exists is set to
true. Otherwise, type_exists is set to false. The only thing that happens
when type_exists is false is generating a warning message (see Sec. 273).
It is *not an error* to use a type that is not defined in a bst file
(which, again, I emphasize, BibTeX-mode has no way of knowing).
How about this proposal? Can BibTeX-mode have a (customizable) boolean
variable, something like bibtex-parse-permissively? If this flag is nil,
BibTeX-mode would operate as it does right now. If this flag is t (or maybe
just non-nil?), then bibtex-parse-entry would parse entries just according
to the regexps on the nice web site you sent — that is, ignoring the value
of bibtex-entry-alist.
Best,
Leo
On Sun, Jan 12, 2025 at 11:56 PM Roland Winkler <winkler@gnu.org> wrote:
> On Mon, Jan 06 2025, Leo Stein wrote:
> > I'm glad you are adding more customization. 1. Why is the standard
> > value of bibtex-BibTeX-aux-entry-alist given as '(("Conference"
> > "Article in Conference Proceedings" "InProceedings")) ? 2. I still
> > don't understand the point of making a distinction between
> > "dialects". As I've tried to emphasize before, which fields are
> > accepted is under the purview of the bst (for bibtex) or bbx/cbx/lbx
> > file (for biber+biblatex) that the user will eventually use. That
> > can't be inferred from the contents of a .bib file; in fact, a .bib
> > file could be used in multiple different projects with different
> > bst/bbx/cbx/lbx files, all of which allow for different fields. I
> > still maintain that the best approach is to be permissive about
> > *parsing* entries in bibtex-parse-entry. That is a different question
> > from the contents of templates provided by C-c C-e [KEY], for which of
> > course the mode must know about the structure of each given entry.
>
> I was looking at this again. In theory, this is all (more or less)
> straightforward. In real life, BibTeX is tricky because
>
> "there is no formal specification of the language. This means that
> users exploring the arcane corners of the language are largely on
> their own, and programmers implementing their own parsers are
> completely on their own---except for observing the behaviour of the
> original implementation."
>
> This quote is taken from the most accurate documentation of the
> BibTeX "language" I am aware of,
>
> https://metacpan.org/dist/Text-BibTeX/view/btparse/doc/bt_language.pod
>
> This documentation was written by the author of btparse, which is the
> BibTeX parser used by biber / biblatex. So these problems are the same
> under conventional BibTeX and biblatex.
>
> Emacs bibtex-mode needs to come up with its own parser, for which it
> follows a conservative approach that explicitly defines valid entries.
> Agreed, this approach is not perfect. But trying to do better is an
> arduous undertaking full of hidden pitfalls.
>
[-- Attachment #2: Type: text/html, Size: 4207 bytes --]
^ permalink raw reply [flat|nested] 11+ messages in thread
end of thread, other threads:[~2025-01-18 3:05 UTC | newest]
Thread overview: 11+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2021-11-05 23:35 bug#51621: 29.0.50; bibtex.el biblatex "2.1.3 Non-standard Types" support Leonard Lausen
2021-11-07 3:37 ` Roland Winkler
2024-12-01 4:33 ` Leo Stein
2024-12-02 14:05 ` Roland Winkler
2024-12-02 17:23 ` Leo Stein
2024-12-03 20:37 ` Roland Winkler
2024-12-03 21:12 ` Leo Stein
2025-01-02 5:59 ` Roland Winkler
2025-01-06 19:49 ` Leo Stein
2025-01-13 5:56 ` Roland Winkler
2025-01-18 3:05 ` Leo Stein
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).