all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
* bug#46933: Possible bugs in filepos-to-bufferpos / bufferpos-to-filepos
@ 2021-03-04 21:21 Gregory Heytings
  2021-03-21 15:27 ` Eli Zaretskii
  0 siblings, 1 reply; 19+ messages in thread
From: Gregory Heytings @ 2021-03-04 21:21 UTC (permalink / raw)
  To: 46933

[-- Attachment #1: Type: text/plain, Size: 5308 bytes --]


(Disclaimer: I have no knowledge whatsoever about the ISO-2022-JP 
encoding, and although this looks like a bug, I'm not sure this is 
actually a bug; I report this at the suggesion of Eli in bug#46859.)

I downloaded the file [1], and converted it to the ISO-2022-JP encoding 
with iconv -t iso-2022-jp one.txt > iso-2022-jp.txt.  The resulting file 
is attached to this bug report.  It ends with two CRLFs, at byte offsets 
2993 and 2995.  However, after emacs -Q iso-2022-jp.txt, with M-: 
(goto-char (filepos-to-bufferpos POS 'exact)) we get:

POS = 2991, 2992: last but one visible character (HIRAGANA LETTER RU)
POS = 2993, 2994: last visible character (IDEOGRAPHIC FULL STOP)
POS = 2995, 2996: first CRLF
POS = 2997: second CRLF
POS = 2998: point-max
POS = 2999: first CRLF
POS = 3000, 3001: second CRLF
POS >= 3002: point-max

I would have expected:

POS = 2989, 2990: last but one visible character (HIRAGANA LETTER RU)
POS = 2991, 2992: last visible character (IDEOGRAPHIC FULL STOP)
POS = 2993, 2994: first CRLF
POS = 2995, 2996: second CRLF
POS >= 2997: point-max

The opposite operation M-: (bufferpos-to-filepos (- (point) POS) 'exact) 
apparently also has bugs; its return values are not coherent with the 
above ones:

POS = 0: 3003
POS = 1: 3001
POS = 2: 2999
POS = 3 (IDEOGRAPHIC FULL STOP): 2997
POS = 4 (HIRAGANA LETTER RU): 2995

I would have expected:

POS = 0: 2997
POS = 1: 2995
POS = 2: 2993
POS = 3 (IDEOGRAPHIC FULL STOP): 2991
POS = 4 (HIRAGANA LETTER RU): 2989

[1] https://darza.com/ecbackend/vendor/symfony/mime/Tests/Fixtures/samples/charsets/iso-2022-jp/one.txt

In GNU Emacs 27.1 (build 1, x86_64-pc-linux-gnu, GTK+ Version 3.24.23, cairo version 1.16.0)
  of 2020-11-08, modified by Debian built on x86-ubc-01
Windowing system distributor 'The X.Org Foundation', version 11.0.12010000
System Description: Debian GNU/Linux bullseye/sid

Configured using:
  'configure --build x86_64-linux-gnu --prefix=/usr
  --sharedstatedir=/var/lib --libexecdir=/usr/lib
  --localstatedir=/var/lib --infodir=/usr/share/info
  --mandir=/usr/share/man --enable-libsystemd --with-pop=yes
  --enable-locallisppath=/etc/emacs:/usr/local/share/emacs/27.1/site-lisp:/usr/local/share/emacs/site-lisp:/usr/share/emacs/27.1/site-lisp:/usr/share/emacs/site-lisp
  --with-sound=alsa --without-gconf --with-mailutils --build
  x86_64-linux-gnu --prefix=/usr --sharedstatedir=/var/lib
  --libexecdir=/usr/lib --localstatedir=/var/lib
  --infodir=/usr/share/info --mandir=/usr/share/man --enable-libsystemd
  --with-pop=yes
  --enable-locallisppath=/etc/emacs:/usr/local/share/emacs/27.1/site-lisp:/usr/local/share/emacs/site-lisp:/usr/share/emacs/27.1/site-lisp:/usr/share/emacs/site-lisp
  --with-sound=alsa --without-gconf --with-mailutils --with-cairo
  --with-x=yes --with-x-toolkit=gtk3 --with-toolkit-scroll-bars
  'CFLAGS=-g -O2
  -fdebug-prefix-map=/build/emacs-6jKC2B/emacs-27.1+1=. -fstack-protector-strong
  -Wformat -Werror=format-security -Wall' 'CPPFLAGS=-Wdate-time
  -D_FORTIFY_SOURCE=2' LDFLAGS=-Wl,-z,relro'

Configured features:
XPM JPEG TIFF GIF PNG RSVG CAIRO SOUND GPM DBUS GSETTINGS GLIB NOTIFY
INOTIFY ACL LIBSELINUX GNUTLS LIBXML2 FREETYPE HARFBUZZ M17N_FLT LIBOTF
ZLIB TOOLKIT_SCROLL_BARS GTK3 X11 XDBE XIM MODULES THREADS LIBSYSTEMD
JSON PDUMPER LCMS2 GMP

Important settings:
   value of $LANG: en_US.UTF-8
   locale-coding-system: utf-8-unix

Major mode: Lisp Interaction

Minor modes in effect:
   tooltip-mode: t
   global-eldoc-mode: t
   eldoc-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
   transient-mark-mode: t

Load-path shadows:
None found.

Features:
(shadow sort mail-extr emacsbug message rmc puny dired dired-loaddefs
format-spec rfc822 mml easymenu mml-sec password-cache epa derived epg
epg-config gnus-util rmail rmail-loaddefs text-property-search time-date
subr-x seq byte-opt gv bytecomp byte-compile cconv mm-decode mm-bodies
mm-encode mail-parse rfc2231 mailabbrev gmm-utils mailheader cl-loaddefs
cl-lib sendmail rfc2047 rfc2045 ietf-drums mm-util mail-prsvr mail-utils
tooltip eldoc electric uniquify ediff-hook vc-hooks lisp-float-type
mwheel term/x-win x-win term/common-win x-dnd tool-bar dnd fontset image
regexp-opt fringe tabulated-list replace newcomment text-mode elisp-mode
lisp-mode prog-mode register page tab-bar menu-bar rfn-eshadow isearch
timer select scroll-bar mouse jit-lock font-lock syntax facemenu
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 charscript charprop
case-table epa-hook jka-cmpr-hook help simple abbrev obarray
cl-preloaded nadvice loaddefs button faces cus-face macroexp files
text-properties overlay sha1 md5 base64 format env code-pages mule
custom widget hashtable-print-readable backquote threads dbusbind
inotify lcms2 dynamic-setting system-font-setting font-render-setting
cairo move-toolbar gtk x-toolkit x multi-tty make-network-process emacs)

[-- Attachment #2: Type: text/plain, Size: 2997 bytes --]

ISO-2022-JP^[$B$O!"%$%s%?!<%M%C%H>e^[(B(^[$BFC$KEE;R%a!<%k^[(B)^[$B$J$I$G;H$o$l$kF|K\$NJ8;zMQ$NJ8;zId9f2=J}<0!#^[(BISO/IEC 2022^[$B$N%(%9%1!<%W%7!<%1%s%9$rMxMQ$7$FJ8;z=89g$r@Z$jBX$($k^[(B7^[$B%S%C%H$N%3!<%I$G$"$k$3$H$rFCD'$H$9$k^[(B (^[$B%"%J%&%s%95!G=$N%(%9%1!<%W%7!<%1%s%9$O>JN,$5$l$k^[(B)^[$B!#B/$K!V^[(BJIS^[$B%3!<%I!W$H8F$P$l$k$3$H$b$"$k!#^[(B

^[$B35MW^[(B
^[$BF|K\8lI=5-$X$NMxMQ$,A[Dj$5$l$F$$$kJ8;z%3!<%I$G$"$j!"F|K\8l$NMxMQ$5$l$k%M%C%H%o!<%/$K$*$$$F!"F|K\$N5,3J$r1~MQ$7$?$b$N$G$"$k!#$^$?J8;z=89g$H$7$F$O!"F|K\8l$GMQ$$$i$l$k4A;z!"$R$i$,$J!"%+%?%+%J$O$b$A$m$s!"%i%F%sJ8;z!"%.%j%7%"J8;z!"%-%j%kJ8;z$J$I$b4^$s$G$*$j!"3X=Q$d;:6H$NJ,Ln$G$NMxMQ$b9MN8$?$b$N$H$J$C$F$$$k!#5,3JL>$K!"^[(BISO^[$B$NF|K\8l$N8@8l%3!<%I$G$"$k^[(Bja^[$B$G$O$J$/!"9q!&CO0hL>%3!<%I$N^[(BJP^[$B$,<($5$l$F$$$k$f$($s$G$"$k!#^[(B
^[$BJ8;z=89g$H$7$F^[(BJIS X 0201^[$B$N^[(BC0^[$B=89g!J@)8fJ8;z!K!"^[(BJIS X 0201^[$B$N%i%F%sJ8;z=89g!"^[(BISO 646^[$B$N9q:]4p=`HG?^7AJ8;z!"^[(BJIS X 0208^[$B$N^[(B1978^[$BG/HG!J^[(BJIS C 6226-1978^[$B!K$H^[(B1983^[$BG/$*$h$S^[(B1990^[$BG/HG$,MxMQ$G$-$k!#^[(BJIS X 0201^[$B$NJR2>L>J8;z=89g$OMxMQ$G$-$J$$!#^[(B1986^[$BG/0J9_!"F|K\$NEE;R%a!<%k$GMQ$$$i$l$F$-$?^[(BJUNET^[$B%3!<%I$r!"B<0f=c!&^[(BMark Crispin^[$B!&^[(BErik van der Poel^[$B$,^[(B1993^[$BG/$K^[(BRFC^[$B2=$7$?$b$N^[(B(RFC 1468)^[$B!#8e$K^[(BJIS X 0208:1997^[$B$NImB0=q^[(B2^[$B$H$7$F^[(BJIS^[$B$K5,Dj$5$l$?!#^[(BMIME^[$B$K$*$1$kJ8;zId9f2=J}<0$N<1JLMQ$NL>A0$H$7$F^[(B IANA ^[$B$KEPO?$5$l$F$$$k!#^[(B
^[$B$J$*!"Id9f2=$N;EMM$K$D$$$F$O^[(BISO/IEC 2022#ISO-2022-JP^[$B$b;2>H!#^[(B

ISO-2022-JP^[$B$HHsI8=`E*3HD%;HMQ^[(B
^[$B!V^[(BJIS^[$B%3!<%I!W!J$^$?$O!V^[(BISO-2022-JP^[$B!W!K$H$$$&%3!<%IL>$N5,Dj2<$G$O!"$=$N;EMMDL$j$N;HMQ$,5a$a$i$l$k!#$7$+$7!"^[(BWindows OS^[$B>e$G$O!"<B:]$K$O^[(BCP932^[$B%3!<%I^[(B (Microsoft^[$B$K$h$k^[(BShift JIS^[$B$r3HD%$7$?0!<o!#^[(BISO-2022-JP^[$B5,Dj30J8;z$,DI2C$5$l$F$$$k!#!K$K$h$kFH<+3HD%!J$NJ8;z!K$rCG$j$J$/;H$&%"%W%j%1!<%7%g%s$,B?$$!#$3$NNc$H$7$F^[(BInternet Explorer^[$B$d^[(BOutlook Express^[$B$,$"$k!#$^$?!"^[(BEmEditor^[$B!"=(4]%(%G%#%?$d^[(BThunderbird^[$B$N$h$&$J^[(BMicrosoft^[$B<R0J30$N^[(BWindows^[$B%"%W%j%1!<%7%g%s$G$bF1MM$N>l9g$,$"$k!#$3$N>l9g!"^[(BISO-2022-JP^[$B$NHO0O30$NJ8;z$r;H$C$F$7$^$&$H!"0[$J$k@=IJ4V$G$OL$Dj5AITL@J8;z$H$7$FG'<1$5$l$k$+!"$b$7$/$OJ8;z2=$1$r5/$3$9860x$H$J$k!#$=$N$?$a!"^[(BWindows^[$BMQ$NEE;R%a!<%k%/%i%$%"%s%H$G$"$C$F$bFH<+3HD%$NJ8;z$r;HMQ$9$k$H7Y9p$r=P$7$?$j!"$"$($F;H$($J$$$h$&$K@)8B$7$F$$$k$b$N$bB8:_$9$k!#$5$i$K$O^[(BISO-2022-JP^[$B$NHO0OFb$G$"$C$F$b^[(BCP932^[$B$OHsI8=`J8;z!J^[(BFULLWIDTH TILDE^[$BEy!K$r;}$D$N$GJ8;z2=$1$N860x$K$J$jF@$k!#^[(B
^[$B$^$?!"Id9f2=J}<0L>$r^[(BISO-2022-JP^[$B$H$7$F$$$k$N$K!"J8;z=89g$H$7$F$O^[(BJIS X 0212 (^[$B$$$o$f$kJd=u4A;z^[(B) ^[$B$d^[(BJIS X 0201^[$B$NJR2>L>J8;z=89g^[(B (^[$B$$$o$f$kH>3Q%+%J^[(B) ^[$B$r$bId9f2=$7$F$$$kNc$,$"$k$,!"^[(BISO-2022-JP^[$B$G$O$3$l$i$NJ8;z$r5vMF$7$F$$$J$$!#$3$l$i$NId9f2=$OFH<+3HD%$N<BAu$G$"$j!"Cf$K$O^[(BISO/IEC 2022^[$B$N;EMM$K=`5r$9$i$7$F$$$J$$$b$N$b$"$k^[(B[2]^[$B!#=>$C$F<u?.B&$NEE;R%a!<%k%/%i%$%"%s%H$,$3$l$i$NFH<+3HD%$KBP1~$7$F$$$J$$>l9g!"$=$NJ8;z$"$k$$$O$=$NJ8;z$r4^$`9T!";~$K$O%F%-%9%HA4BN$,J8;z2=$1$9$k$3$H$,$"$k!#^[(B


^ permalink raw reply	[flat|nested] 19+ messages in thread

end of thread, other threads:[~2022-06-22 13:11 UTC | newest]

Thread overview: 19+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2021-03-04 21:21 bug#46933: Possible bugs in filepos-to-bufferpos / bufferpos-to-filepos Gregory Heytings
2021-03-21 15:27 ` Eli Zaretskii
2021-03-27  5:38   ` handa
2021-03-27  7:54     ` Eli Zaretskii
2021-03-27 13:23       ` handa
2021-03-27 13:54         ` Eli Zaretskii
2021-03-28 14:29           ` handa
2021-03-28 14:51             ` Eli Zaretskii
2021-04-01 15:14               ` handa
2021-04-01 15:25                 ` Eli Zaretskii
2021-04-01 15:32                 ` Eli Zaretskii
2021-04-03 16:12                   ` handa
2022-06-20  0:59                     ` Lars Ingebrigtsen
2022-06-20 11:52                       ` Eli Zaretskii
2022-06-21 10:40                         ` Lars Ingebrigtsen
2022-06-21 12:14                           ` Eli Zaretskii
2022-06-22  4:17                             ` Lars Ingebrigtsen
2022-06-22 13:11                               ` Eli Zaretskii
2021-03-27 14:24     ` Gregory Heytings

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.