* bug#65338: 30.0.50; bibtex: Long url field value and bibtex-font-lock-url-regexp
@ 2023-08-16 10:22 Visuwesh
2023-08-16 17:15 ` Roland Winkler
0 siblings, 1 reply; 8+ messages in thread
From: Visuwesh @ 2023-08-16 10:22 UTC (permalink / raw)
To: 65338; +Cc: roland winkler
X-Debbugs-Cc: Roland Winkler <winkler@gnu.org>
I have a bibtex entry that has a long URL
@Misc{DelhiPlasmaPyrlosis,
author = {Central Pollution Control Board, India},
title = {Study on Plastic Waste Disposal through ``Plasma
Pyrolysis Technology''},
month = {oct},
year = 2016,
note = {\url{https://cpcb.nic.in/displaypdf.php?id=cGxhc3RpY3dhc3RlL1BsYXNtYS1QeXJvbHlzaXMtZmluYWwtUmVwb3J0LTIxLTExLTE2LnBkZg},
last checked on 15/08/2023.},
file = {papers/delhiplasmapyrlosis.pdf},
url = {https://cpcb.nic.in/displaypdf.php?id=cGxhc3RpY3dhc3RlL1BsYXNtYS1QeXJvbHlzaXMtZmluYWwtUmVwb3J0LTIxLTExLTE2LnBkZg}
}
When I fill the entry with C-c C-q, url lines becomes
url =
{https://cpcb.nic.in/displaypdf.php?id=cGxhc3RpY3dhc3RlL1BsYXNtYS1QeXJvbHlzaXMtZmluYWwtUmVwb3J0LTIxLTExLTE2LnBkZg}
This however breaks the buttonisation since the second character class
in bibtex-font-lock-url-regexp does not include newline, only space and
tab. If I add a newline as below, then the url field value is
buttonised as expected. Should this be done in bibtex-mode.el as well?
diff --git a/lisp/textmodes/bibtex.el b/lisp/textmodes/bibtex.el
index 394f80f47e..96597ba8fb 100644
--- a/lisp/textmodes/bibtex.el
+++ b/lisp/textmodes/bibtex.el
@@ -1845,7 +1845,7 @@ bibtex-font-lock-url-regexp
;; Assume that field names begin at the beginning of a line.
(concat "^[ \t]*"
(regexp-opt (delete-dups (mapcar #'caar bibtex-generate-url-list)) t)
- "[ \t]*=[ \t]*")
+ "[ \t]*=[ \t\n]*")
"Regexp for `bibtex-font-lock-url' derived from `bibtex-generate-url-list'.")
(defvar bibtex-string-empty-key nil
In GNU Emacs 30.0.50 (build 8, x86_64-pc-linux-gnu, X toolkit, Xaw
scroll bars) of 2023-08-10 built on astatine
Repository revision: 65f71ca9aaa1587284293e2e34a0e28ee6b42380
Repository branch: master
Windowing system distributor 'The X.Org Foundation', version 11.0.12101007
System Description: Debian GNU/Linux trixie/sid
Configured using:
'configure --with-sound=alsa --with-x-toolkit=lucid --with-json
--without-xaw3d --without-gconf --without-libsystemd --without-cairo'
Configured features:
ACL DBUS FREETYPE GIF GLIB GMP GNUTLS GPM GSETTINGS HARFBUZZ JPEG JSON
LIBOTF LIBSELINUX LIBXML2 MODULES NOTIFY INOTIFY PDUMPER PNG RSVG
SECCOMP SOUND SQLITE3 THREADS TIFF TOOLKIT_SCROLL_BARS WEBP X11 XDBE XFT
XIM XINPUT2 XPM LUCID ZLIB
Important settings:
value of $LC_MONETARY: ta_IN.UTF-8
value of $LC_NUMERIC: ta_IN.UTF-8
value of $LANG: en_GB.UTF-8
locale-coding-system: utf-8-unix
Major mode: ELisp/l
Minor modes in effect:
pdf-virtual-global-minor-mode: t
TeX-PDF-mode: t
reveal-mode: t
outline-minor-mode: t
recentf-mode: t
server-mode: t
paredit-mode: t
eros-mode: t
flymake-mode: t
sow-mode: t
pdf-occur-global-minor-mode: t
vz/random-frame-background-mode: t
minibuffer-depth-indicate-mode: t
repeat-mode: t
display-time-mode: t
display-battery-mode: t
delete-selection-mode: t
xterm-mouse-mode: t
straight-use-package-mode: t
straight-package-neutering-mode: t
tooltip-mode: t
global-eldoc-mode: t
eldoc-mode: t
show-paren-mode: t
electric-indent-mode: t
mouse-wheel-mode: t
use-hard-newlines: t
tab-bar-history-mode: t
tab-bar-mode: t
file-name-shadow-mode: t
global-font-lock-mode: t
font-lock-mode: t
undelete-frame-mode: t
transient-mark-mode: t
auto-composition-mode: t
auto-encryption-mode: t
auto-compression-mode: t
abbrev-mode: t
Load-path shadows:
None found.
Features:
(org-num ob-ditaa ob-plantuml org-clock org-colview org-crypt org-ctags
org-habit org-mouse org-plot org-protocol url-misc bibtex-style
pcmpl-unix gnus-draft latexenc preview reporter desktop tex-buf
font-latex tex-mode org-capture doct pdf-virtual hippie-exp dash
completion display-line-numbers wdired grep msb shadow emacsbug
cus-start loadhist ox-odt rng-loc rng-uri rng-parse rng-match rng-dt
rng-util rng-pttrn nxml-parse nxml-ns nxml-enc xmltok nxml-util ox-latex
ox-icalendar org-agenda ox-html table ox-ascii ox-publish ox timezone
inspector latex-mode-expansions latex latex-flymake tex-ispell tex-style
tex crm shr-color org-pdftools org-noter org-element org-persist
avl-tree oc-basic help-at-pt calccomp calc-aent calc-units calc-menu
calc-ext calc calc-loaddefs rect calc-macs flyspell ispell ecomplete
ement-tabulated-room-list ement ement-notify notifications ement-room
dns ement-room-list ement-lib ement-api ement-structs plz ement-macros
taxy-magit-section magit-section benchmark taxy svg-lib persist lacarte
ffap misc tabify man image-file image-converter find-dired rfc2104
tramp-cmds tramp-cache time-stamp nnfolder pdf-sync pdf-annot facemenu
pdf-outline pdf-links the-org-mode-expansions ob-gnuplot ob-fortran
ob-python python-el-fgallina-expansions python compat compat-macs ob-C
ob-shell ob-racket async ob-async cdlatex texmathp org-attach org-id
org-refile ol-eww ol-rmail ol-mhe ol-irc ol-info ol-gnus nnselect
ol-docview doc-view ol-bibtex bibtex ol-bbdb ol-w3m ol-doi org-link-doi
org-tempo ol-man org ob ob-tangle ob-ref ob-lob ob-table ob-exp
org-macro org-src ob-comint org-pcomplete org-list org-footnote
org-faces org-entities ob-emacs-lisp ob-core ob-eval org-cycle org-table
ol org-fold org-fold-core org-keys oc org-loaddefs org-version
org-compat org-macs pdf-history icomplete autoload loaddefs-gen dabbrev
log-edit add-log term/xterm xterm goto-addr pixel-scroll cua-base edebug
thai-util thai-word cc-mode-expansions cc-mode cc-fonts cc-guess
cc-menus cc-cmds cc-styles cc-align cc-engine cc-vars cc-defs apropos
glyphless-mode frameset typo inline mule-util expand-region
text-mode-expansions er-basic-expansions expand-region-core
expand-region-custom avy smerge-mode reveal image-crop descr-text
cl-print view mines cookie1 gamegrid url-http url-gw url-cache url-auth
eww url-queue mm-url dired-aux gnus-dired shell-command+ face-remap sort
gnus-cite flow-fill mm-archive mail-extr textsec uni-scripts
idna-mapping ucs-normalize uni-confusable textsec-check gnus-async
gnus-bcklg qp gnus-ml shortdoc comp comp-cstr help-fns radix-tree etags
fileloop generator imenu-xref xref pulse color misearch multi-isearch
sh-script smie treesit network-stream nsm nndraft nnmh nndoc nnmaildir
nnagent nnml executable nnnil gnus-agent gnus-srvr gnus-score score-mode
nnvirtual gnus-msg gnus-art mm-uu mml2015 mm-view mml-smime smime gnutls
dig nntp gnus-cache gnus-sum shr pixel-fill kinsoku url-file svg
gnus-group gnus-undo gnus-start gnus-dbus gnus-cloud nnimap nnmail
mail-source utf7 nnoo gnus-spec gnus-int gnus-range message sendmail
yank-media puny rfc822 mml mml-sec epa epg rfc6068 epg-config mm-decode
mm-bodies mm-encode mail-parse rfc2231 rfc2047 rfc2045 ietf-drums
mailabbrev gmm-utils mailheader gnus-win gnus nnheader gnus-util
mail-utils range mm-util mail-prsvr noutline outline bug-reference
cursor-sensor recentf tree-widget vc-backup log-view pcvs-util vc diff
vc-git diff-mode vc-dispatcher server paredit edmacro kmacro eros
checkdoc lisp-mnt flymake-proc flymake project warnings thingatpt
wordel-autoloads mines-autoloads sokoban-autoloads ement-autoloads
svg-lib-autoloads taxy-magit-section-autoloads magit-section-autoloads
dash-autoloads taxy-autoloads persist-autoloads plz-autoloads
nov-autoloads esxml-autoloads kv-autoloads transmission-autoloads
csv-mode-autoloads lua-mode-autoloads nix-mode-autoloads
gnuplot-autoloads go-mode-autoloads racket-mode-autoloads eros-autoloads
writegood-mode-autoloads siege-mode-autoloads paredit-autoloads
puni-autoloads expand-region-autoloads filladapt-autoloads compose
scroll-other-window org-pdftools-autoloads org-noter-autoloads
change-env-autoloads math-delimiters-autoloads doct-autoloads
ob-async-autoloads async-autoloads emacs-ob-racket-autoloads
valign-autoloads cdlatex-autoloads auctex-autoloads tex-site tempo
pdf-occur ibuf-ext ibuffer ibuffer-loaddefs tablist advice
tablist-filter semantic/wisent/comp semantic/wisent
semantic/wisent/wisent semantic/util-modes semantic/util semantic
semantic/tag semantic/lex semantic/fw mode-local cedet pdf-isearch
let-alist pdf-misc imenu pdf-tools package browse-url url url-proxy
url-privacy url-expand url-methods url-history url-cookie
generate-lisp-file url-domsuf url-util mailcap url-handlers url-parse
url-vars compile cus-edit wid-edit pdf-view jka-compr pdf-cache pdf-info
tq pdf-util pdf-macs image-mode dired-x dired dired-loaddefs exif
pdf-tools-autoloads tablist-autoloads typo-autoloads mb-depth repeat
visual-fill-autoloads olivetti-autoloads time battery filenotify dom
tamil99 quail disp-table lacarte-autoloads shell-command-plus-autoloads
icons delsel easy-mmode xt-mouse cus-load avy-autoloads skeleton
icalendar diary-lib diary-loaddefs cal-menu calendar cal-loaddefs
dired-du-autoloads finder-inf filecache imenu-xref-autoloads ert ewoc
debug backtrace find-func dbus xml derived chemtable-autoloads
molar-mass-autoloads vc-backup-autoloads compat-autoloads
saveplace-pdf-view saveplace tramp-sh tramp trampver tramp-integration
files-x tramp-message tramp-compat xdg shell pcomplete comint ansi-osc
ring parse-time iso8601 time-date format-spec auth-source eieio
eieio-core password-cache json map byte-opt ansi-color tramp-loaddefs
bookmark text-property-search pp saveplace-pdf-view-autoloads rx pcase
inspector-autoloads xr-autoloads straight-autoloads cl-seq info cl-extra
help-mode straight subr-x cl-macs gv cl-loaddefs cl-lib bytecomp
byte-compile vz-nh-theme vz-options-theme rmc iso-transl tooltip cconv
eldoc paren electric uniquify ediff-hook vc-hooks lisp-float-type
elisp-mode mwheel term/x-win x-win term/common-win x-dnd touch-screen
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 nadvice seq
simple cl-generic indonesian philippine 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 abbrev obarray oclosure cl-preloaded button
loaddefs theme-loaddefs faces cus-face macroexp files window
text-properties overlay sha1 md5 base64 format env code-pages mule
custom widget keymap hashtable-print-readable backquote threads dbusbind
inotify dynamic-setting system-font-setting font-render-setting
x-toolkit xinput2 x multi-tty move-toolbar make-network-process emacs)
Memory information:
((conses 16 4499264 2547716) (symbols 48 87286 1764)
(strings 32 460793 70392) (string-bytes 1 340659943)
(vectors 16 178164) (vector-slots 8 3544067 991149)
(floats 8 235970 8725) (intervals 56 415515 9073) (buffers 984 303))
^ permalink raw reply related [flat|nested] 8+ messages in thread
* bug#65338: 30.0.50; bibtex: Long url field value and bibtex-font-lock-url-regexp
2023-08-16 10:22 bug#65338: 30.0.50; bibtex: Long url field value and bibtex-font-lock-url-regexp Visuwesh
@ 2023-08-16 17:15 ` Roland Winkler
2023-08-17 2:18 ` Visuwesh
0 siblings, 1 reply; 8+ messages in thread
From: Roland Winkler @ 2023-08-16 17:15 UTC (permalink / raw)
To: Visuwesh; +Cc: 65338
On Wed, Aug 16 2023, Visuwesh wrote:
> When I fill the entry with C-c C-q, url lines becomes
>
> url =
> {https://cpcb.nic.in/displaypdf.php?id=cGxhc3RpY3dhc3RlL1BsYXNtYS1QeXJvbHlzaXMtZmluYWwtUmVwb3J0LTIxLTExLTE2LnBkZg}
The patch you propose may be reasonable, temporary workaround. The
deeper, not all trivial bug is #45720 that I filed because of the above
linebreak introduced by fill-region-as-paragraph.
^ permalink raw reply [flat|nested] 8+ messages in thread
* bug#65338: 30.0.50; bibtex: Long url field value and bibtex-font-lock-url-regexp
2023-08-16 17:15 ` Roland Winkler
@ 2023-08-17 2:18 ` Visuwesh
2023-08-17 5:57 ` Eli Zaretskii
0 siblings, 1 reply; 8+ messages in thread
From: Visuwesh @ 2023-08-17 2:18 UTC (permalink / raw)
To: Roland Winkler; +Cc: 65338
[புதன் ஆகஸ்ட் 16, 2023] Roland Winkler wrote:
> On Wed, Aug 16 2023, Visuwesh wrote:
>> When I fill the entry with C-c C-q, url lines becomes
>>
>> url =
>> {https://cpcb.nic.in/displaypdf.php?id=cGxhc3RpY3dhc3RlL1BsYXNtYS1QeXJvbHlzaXMtZmluYWwtUmVwb3J0LTIxLTExLTE2LnBkZg}
>
> The patch you propose may be reasonable, temporary workaround. The
> deeper, not all trivial bug is #45720 that I filed because of the above
> linebreak introduced by fill-region-as-paragraph.
Ah, so the issue is in fill.el... I could never find a fix myself, I
will patch `bibtex-font-lock-url-regexp' in my local checkout and call
it a day.
^ permalink raw reply [flat|nested] 8+ messages in thread
* bug#65338: 30.0.50; bibtex: Long url field value and bibtex-font-lock-url-regexp
2023-08-17 2:18 ` Visuwesh
@ 2023-08-17 5:57 ` Eli Zaretskii
2023-08-17 8:56 ` Visuwesh
0 siblings, 1 reply; 8+ messages in thread
From: Eli Zaretskii @ 2023-08-17 5:57 UTC (permalink / raw)
To: Visuwesh; +Cc: 65338, winkler
> Cc: 65338@debbugs.gnu.org
> From: Visuwesh <visuweshm@gmail.com>
> Date: Thu, 17 Aug 2023 07:48:51 +0530
>
> [புதன் ஆகஸ்ட் 16, 2023] Roland Winkler wrote:
>
> > On Wed, Aug 16 2023, Visuwesh wrote:
> >> When I fill the entry with C-c C-q, url lines becomes
> >>
> >> url =
> >> {https://cpcb.nic.in/displaypdf.php?id=cGxhc3RpY3dhc3RlL1BsYXNtYS1QeXJvbHlzaXMtZmluYWwtUmVwb3J0LTIxLTExLTE2LnBkZg}
> >
> > The patch you propose may be reasonable, temporary workaround. The
> > deeper, not all trivial bug is #45720 that I filed because of the above
> > linebreak introduced by fill-region-as-paragraph.
>
> Ah, so the issue is in fill.el... I could never find a fix myself, I
> will patch `bibtex-font-lock-url-regexp' in my local checkout and call
> it a day.
Should this bug be closed, then?
^ permalink raw reply [flat|nested] 8+ messages in thread
* bug#65338: 30.0.50; bibtex: Long url field value and bibtex-font-lock-url-regexp
2023-08-17 5:57 ` Eli Zaretskii
@ 2023-08-17 8:56 ` Visuwesh
2023-08-20 5:39 ` Roland Winkler
0 siblings, 1 reply; 8+ messages in thread
From: Visuwesh @ 2023-08-17 8:56 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: 65338, winkler
On 17 August 2023 11:27:23 GMT+05:30, Eli Zaretskii <eliz@gnu.org> wrote:
>Should this bug be closed, then?
If Roland thinks the "band-aid" patch shouldn't be applied, I have no problem with it and the bug can be closed.
^ permalink raw reply [flat|nested] 8+ messages in thread
* bug#65338: 30.0.50; bibtex: Long url field value and bibtex-font-lock-url-regexp
2023-08-17 8:56 ` Visuwesh
@ 2023-08-20 5:39 ` Roland Winkler
2023-08-20 6:53 ` Eli Zaretskii
0 siblings, 1 reply; 8+ messages in thread
From: Roland Winkler @ 2023-08-20 5:39 UTC (permalink / raw)
To: Visuwesh; +Cc: Eli Zaretskii, 65338
On Thu, Aug 17 2023, Visuwesh wrote:
> On 17 August 2023 11:27:23 GMT+05:30, Eli Zaretskii <eliz@gnu.org> wrote:
>
>>Should this bug be closed, then?
>
> If Roland thinks the "band-aid" patch shouldn't be applied, I have no problem with it and the bug can be closed.
Actually, I think: the patch should be applied, then closed
(and I can do that in a few days).
Most likely, the reported problem shows up in the context of the
currently buggy formatting by fill-region-as-paragraph. But BibTeX
itself does not require any particular formatting, and different people
have different preferences. So the patch for
bibtex-font-lock-url-regexp may also make others happy in situations
I have no clue about (while it should not break anything).
^ permalink raw reply [flat|nested] 8+ messages in thread
* bug#65338: 30.0.50; bibtex: Long url field value and bibtex-font-lock-url-regexp
2023-08-20 5:39 ` Roland Winkler
@ 2023-08-20 6:53 ` Eli Zaretskii
2023-08-23 2:53 ` Roland Winkler
0 siblings, 1 reply; 8+ messages in thread
From: Eli Zaretskii @ 2023-08-20 6:53 UTC (permalink / raw)
To: Roland Winkler; +Cc: 65338, visuweshm
> From: Roland Winkler <winkler@gnu.org>
> Cc: Eli Zaretskii <eliz@gnu.org>, 65338@debbugs.gnu.org
> Date: Sun, 20 Aug 2023 00:39:32 -0500
>
> On Thu, Aug 17 2023, Visuwesh wrote:
> > On 17 August 2023 11:27:23 GMT+05:30, Eli Zaretskii <eliz@gnu.org> wrote:
> >
> >>Should this bug be closed, then?
> >
> > If Roland thinks the "band-aid" patch shouldn't be applied, I have no problem with it and the bug can be closed.
>
> Actually, I think: the patch should be applied, then closed
> (and I can do that in a few days).
Yes, please do, and thanks.
^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2023-08-23 2:53 UTC | newest]
Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2023-08-16 10:22 bug#65338: 30.0.50; bibtex: Long url field value and bibtex-font-lock-url-regexp Visuwesh
2023-08-16 17:15 ` Roland Winkler
2023-08-17 2:18 ` Visuwesh
2023-08-17 5:57 ` Eli Zaretskii
2023-08-17 8:56 ` Visuwesh
2023-08-20 5:39 ` Roland Winkler
2023-08-20 6:53 ` Eli Zaretskii
2023-08-23 2:53 ` Roland Winkler
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).