unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
* bug#38381: 27.0.50; Bump Gnus version to 5.14, properly encode group names on disk
@ 2019-11-25 23:56 Eric Abrahamsen
  2019-11-26  0:02 ` Lars Ingebrigtsen
  0 siblings, 1 reply; 5+ messages in thread
From: Eric Abrahamsen @ 2019-11-25 23:56 UTC (permalink / raw)
  To: 38381; +Cc: larsi

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


As part of switching Gnus group names to fully-decoded strings, I left
some code (really horrible code) in place to make sure that the group
names stayed in their previous encoding in Gnus' save files, so that
people running Emacs from git builds could switch back and forth without
worrying about the save files becoming unreadable. Right now, there are
several routines in place that decode non-ascii group names on file
read, and re-encode them on file write. This only has an effect on
non-ascii group names.

Now Emacs 27.1 is on its way, and I would really like to make this
change permanent. The attached patch moves all the ugly compatibility
code into an upgrade routine as part of `gnus-convert-old-newsrc'. Users
will be prompted once to upgrade, and then the various files will be
fixed to use properly encoded group names, and you won't be able to go
back.

Again, this only affects users who had non-ascii group names to begin with.


[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: 0001-Encode-Gnus-group-names-properly-on-disk-bump-Gnus-v.patch --]
[-- Type: text/x-patch, Size: 14329 bytes --]

From 7a5194edff2d69cfcd8f5ee2bdec61bc12c1a11b Mon Sep 17 00:00:00 2001
From: Eric Abrahamsen <eric@ericabrahamsen.net>
Date: Sun, 24 Nov 2019 16:34:00 -0800
Subject: [PATCH] Encode Gnus group names properly on disk, bump Gnus version
 to 5.14

* lisp/gnus/gnus.el (gnus-version-number): Bump to 5.14 to trigger
upgrade routines.
* lisp/gnus/gnus-start.el (gnus-convert-old-newsrc): Check for new
version.
(gnus-convert-encoded-group-names,
gnus-convert-encoded-category-group-names,
gnus-convert-encoded-registry-group-names): Do a one-time conversion of
encoded group names read from various persistence files.
(gnus-read-newsrc-el-file, gnus-gnus-to-quick-newsrc-format): Stop
doing the work here.
* lisp/gnus/gnus-agent.el (gnus-category-read, gnus-category-write):
Don't check group names.
* lisp/gnus/gnus-registry.el (gnus-registry--munge-group-names):
Remove function.
(gnus-registry-save, gnus-registry-fixup-registry): Don't call it.
---
 lisp/gnus/gnus-agent.el    |  46 ++++----------
 lisp/gnus/gnus-registry.el |  50 +--------------
 lisp/gnus/gnus-start.el    | 124 +++++++++++++++++++++++++------------
 lisp/gnus/gnus.el          |   4 +-
 4 files changed, 101 insertions(+), 123 deletions(-)

diff --git a/lisp/gnus/gnus-agent.el b/lisp/gnus/gnus-agent.el
index 1f25255278..768b3beaa6 100644
--- a/lisp/gnus/gnus-agent.el
+++ b/lisp/gnus/gnus-agent.el
@@ -2721,14 +2721,6 @@ gnus-category-read
 					  '(agent-predicate agent-score-file agent-groups))))
 			   c)
 			 old-list)))))))
-	   ;; Possibly decode group names.
-	   (dolist (cat list)
-	     (setf (alist-get 'agent-groups cat)
-		   (mapcar (lambda (g)
-			     (if (string-match-p "[^[:ascii:]]" g)
-				 (decode-coding-string g 'utf-8-emacs)
-			       g))
-			   (alist-get 'agent-groups cat))))
 	   list)
          (list (gnus-agent-cat-make 'default 'short)))))
 
@@ -2736,31 +2728,19 @@ gnus-category-write
   "Write the category alist."
   (setq gnus-category-predicate-cache nil
 	gnus-category-group-cache nil)
-  ;; Temporarily encode non-ascii group names when saving to file,
-  ;; pending an upgrade of Gnus' file formats.
-  (let ((gnus-category-alist
-	 (mapcar (lambda (cat)
-		   (setf (alist-get 'agent-groups cat)
-			 (mapcar (lambda (g)
-				   (if (multibyte-string-p g)
-				       (encode-coding-string g 'utf-8-emacs)
-				     g))
-				 (alist-get 'agent-groups cat)))
-		   cat)
-		 (copy-tree gnus-category-alist))))
-   (gnus-make-directory (nnheader-concat gnus-agent-directory "lib"))
-   (with-temp-file (nnheader-concat gnus-agent-directory "lib/categories")
-     ;; This prin1 is temporary.  It exists so that people can revert
-     ;; to an earlier version of gnus-agent.
-     (prin1 (mapcar (lambda (c)
-		      (list (car c)
-			    (cdr (assoc 'agent-predicate c))
-			    (cdr (assoc 'agent-score-file c))
-			    (cdr (assoc 'agent-groups c))))
-                    gnus-category-alist)
-            (current-buffer))
-     (newline)
-     (prin1 gnus-category-alist (current-buffer)))))
+  (gnus-make-directory (nnheader-concat gnus-agent-directory "lib"))
+  (with-temp-file (nnheader-concat gnus-agent-directory "lib/categories")
+    ;; This prin1 is temporary.  It exists so that people can revert
+    ;; to an earlier version of gnus-agent.
+    (prin1 (mapcar (lambda (c)
+		     (list (car c)
+			   (cdr (assoc 'agent-predicate c))
+			   (cdr (assoc 'agent-score-file c))
+			   (cdr (assoc 'agent-groups c))))
+                   gnus-category-alist)
+           (current-buffer))
+    (newline)
+    (prin1 gnus-category-alist (current-buffer))))
 
 (defun gnus-category-edit-predicate (category)
   "Edit the predicate for CATEGORY."
diff --git a/lisp/gnus/gnus-registry.el b/lisp/gnus/gnus-registry.el
index e6fb382c2f..7691e3e916 100644
--- a/lisp/gnus/gnus-registry.el
+++ b/lisp/gnus/gnus-registry.el
@@ -266,47 +266,7 @@ gnus-registry-sort-by-creation-time
 
 ;; Remove this from the save routine (and fix it to only decode) at
 ;; next Gnus version bump.
-(defun gnus-registry--munge-group-names (db &optional encode)
-  "Encode/decode group names in DB, before saving or after loading.
-Encode names if ENCODE is non-nil, otherwise decode."
-  (let ((datahash (slot-value db 'data))
-	(grouphash (registry-lookup-secondary db 'group))
-	reset-pairs)
-    (when (hash-table-p grouphash)
-      (maphash
-       (lambda (group-name val)
-	 (if encode
-	     (when (multibyte-string-p group-name)
-	       (remhash group-name grouphash)
-	       (puthash (encode-coding-string group-name 'utf-8-emacs)
-			val grouphash))
-	   (when (string-match-p "[^[:ascii:]]" group-name)
-	     (remhash group-name grouphash)
-	     (puthash (decode-coding-string group-name 'utf-8-emacs) val grouphash))))
-       grouphash))
-    (maphash
-     (lambda (id data)
-       (let ((groups (cdr-safe (assq 'group data))))
-	 (when (seq-some (lambda (g)
-			   (if encode
-			       (multibyte-string-p g)
-			     (string-match-p "[^[:ascii:]]" g)))
-			 groups)
-	   ;; Create a replacement DATA.
-	   (push (list id (cons (cons 'group (mapcar
-			   (lambda (g)
-			     (funcall
-			      (if encode
-				  #'encode-coding-string
-				#'decode-coding-string)
-			      g 'utf-8-emacs))
-			   groups))
-				(assq-delete-all 'group data)))
-		 reset-pairs))))
-     datahash)
-    (pcase-dolist (`(,id ,data) reset-pairs)
-      (remhash id datahash)
-      (puthash id data datahash))))
+
 
 (defun gnus-registry-fixup-registry (db)
   (when db
@@ -325,8 +285,7 @@ gnus-registry-fixup-registry
                     '(mark group keyword)))
       (when (not (equal old (oref db tracked)))
         (gnus-message 9 "Reindexing the Gnus registry (tracked change)")
-        (registry-reindex db))
-      (gnus-registry--munge-group-names db)))
+        (registry-reindex db))))
   db)
 
 (defun gnus-registry-make-db (&optional file)
@@ -410,11 +369,6 @@ gnus-registry-save
                   (registry-size db) file)
     (registry-prune
      db gnus-registry-default-sort-function)
-    ;; Write a clone of the database with non-ascii group names
-    ;; encoded as 'utf-8.  Let-bind `gnus-registry-db' so that
-    ;; functions in the munging process work on our clone.
-    (let ((gnus-registry-db clone))
-     (gnus-registry--munge-group-names clone 'encode))
     ;; TODO: call (gnus-string-remove-all-properties v) on all elements?
     (eieio-persistent-save clone file)
     (gnus-message 5 "Saving Gnus registry (size %d) to %s...done"
diff --git a/lisp/gnus/gnus-start.el b/lisp/gnus/gnus-start.el
index e142c438ee..776f60f972 100644
--- a/lisp/gnus/gnus-start.el
+++ b/lisp/gnus/gnus-start.el
@@ -36,6 +36,10 @@
 (autoload 'gnus-agent-save-local "gnus-agent")
 (autoload 'gnus-agent-possibly-alter-active "gnus-agent")
 (declare-function gnus-group-decoded-name "gnus-group" (string))
+(declare-function eieio-object-p "eieio-core" (obj))
+(declare-function slot-value "eieio" (obj slot))
+(declare-function registry-lookup-secondary "registry"
+		  (db tracksym &optional create))
 
 (eval-when-compile (require 'cl-lib))
 
@@ -43,6 +47,9 @@ gnus-agent-covered-methods
 (defvar gnus-agent-file-loading-local)
 (defvar gnus-agent-file-loading-cache)
 (defvar gnus-topic-alist)
+(defvar gnus-category-alist)
+(defvar gnus-registry-enabled)
+(defvar gnus-registry-db)
 
 (defcustom gnus-startup-file (nnheader-concat gnus-home-directory ".newsrc")
   "Your `.newsrc' file.
@@ -1824,17 +1831,13 @@ gnus-make-hashtable-from-newsrc-alist
 		    gnus-newsrc-alist
 		  (cons (list "dummy.group" 0 nil) alist))))
     (while alist
-      (setq info (car alist))
+      (setq info (car alist)
+	    gname (car info))
       ;; Make the same select-methods identical Lisp objects.
       (when (setq method (gnus-info-method info))
 	(if (setq rest (member method methods))
 	    (gnus-info-set-method info (car rest))
 	  (push method methods)))
-      ;; Check for encoded group names and decode them.
-      (when (string-match-p "[^[:ascii:]]" (setq gname (car info)))
-	(let ((decoded (gnus-group-decoded-name gname)))
-	 (setf gname decoded
-	       (car info) decoded)))
       ;; Check for duplicates.
       (if (gethash gname gnus-newsrc-hashtb)
 	  ;; Remove this entry from the alist.
@@ -2295,7 +2298,9 @@ gnus-convert-old-newsrc
                         ("Gnus v5.10.7"        "legacy-gnus-agent"
                          gnus-agent-unlist-expire-days)
                         ("Gnus v5.10.7"        "legacy-gnus-agent"
-                         gnus-agent-unhook-expire-days)))
+                         gnus-agent-unhook-expire-days)
+			("Gnus v5.14" nil
+			 gnus-convert-encoded-group-names)))
               #'car-less-than-car)))
         ;; Skip converters older than the file version
         (while (and converters (>= fcv (caar converters)))
@@ -2369,6 +2374,78 @@ gnus-convert-old-ticks
 	    (nconc (gnus-uncompress-range dormant)
 		   (gnus-uncompress-range ticked)))))))))
 
+(defun gnus-convert-encoded-group-names (_converting-to)
+  "Decode encoded group names.
+Non-ascii group names were previously stored on disk as encoded
+bytes.  This conversion makes sure names are encoded/decoded
+properly."
+  (setq gnus-group-list
+	;; Edit group names in `gnus-group-list', and incidentally
+	;; edit them in `gnus-newsrc-hashtb' and `gnus-newsrc-alist',
+	;; as well.
+	(mapcar
+	 (lambda (gname)
+	   (if (string-match-p "[^[:ascii:]]" gname)
+	       (let ((decoded (gnus-group-decoded-name gname))
+		     (entry (gethash gname gnus-newsrc-hashtb)))
+		 ;; First doctor the entry -- this will also touch
+		 ;; `gnus-newsrc-alist'.
+		 (setcar (nth 1 entry) decoded)
+		 ;; Then re-hash.
+		 (remhash gname gnus-newsrc-hashtb)
+		 (puthash decoded entry gnus-newsrc-hashtb)
+		 decoded)
+	     gname))
+	 gnus-group-list))
+  (add-hook 'gnus-agent-mode-hook #'gnus-convert-encoded-category-group-names)
+  (add-hook 'gnus-started-hook #'gnus-convert-encoded-registry-group-names))
+
+(defun gnus-convert-encoded-category-group-names ()
+  "Possibly decode group names stored in the agent category."
+  (when gnus-category-alist
+    (mapc (lambda (category)
+	    (setf (alist-get 'agent-groups category)
+		  (mapcar (lambda (g)
+			    (if (string-match-p "[^[:ascii:]]" g)
+				(decode-coding-string g 'utf-8-emacs)
+			      g))
+			  (alist-get 'agent-groups category))))
+	  gnus-category-alist)))
+
+(defun gnus-convert-encoded-registry-group-names ()
+  "Possibly decode group names in the Gnus registry file."
+  (when (and (featurep 'gnus-registry)
+	     gnus-registry-enabled
+	     (eieio-object-p gnus-registry-db))
+    (let ((datahash (slot-value gnus-registry-db 'data))
+	  (grouphash (registry-lookup-secondary gnus-registry-db 'group))
+	  reset-pairs)
+      (when (hash-table-p grouphash)
+	(maphash
+	 (lambda (group-name val)
+	   (when (string-match-p "[^[:ascii:]]" group-name)
+	     (remhash group-name grouphash)
+	     (puthash (decode-coding-string group-name 'utf-8-emacs) val grouphash)))
+	 grouphash))
+      (maphash
+       (lambda (id data)
+	 (let ((groups (cdr-safe (assq 'group data))))
+	   (when (seq-some (lambda (g)
+			     (string-match-p "[^[:ascii:]]" g))
+			   groups)
+	     ;; Create a replacement DATA.
+	     (push (list id (cons (cons 'group (mapcar
+						(lambda (g)
+						  (decode-coding-string
+						   g 'utf-8-emacs))
+						groups))
+				  (assq-delete-all 'group data)))
+		   reset-pairs))))
+       datahash)
+      (pcase-dolist (`(,id ,data) reset-pairs)
+	(remhash id datahash)
+	(puthash id data datahash)))))
+
 (defun gnus-load (file)
   "Load FILE, but in such a way that read errors can be reported."
   (with-temp-buffer
@@ -2403,17 +2480,6 @@ gnus-read-newsrc-el-file
 	(when gnus-newsrc-assoc
 	  (setq gnus-newsrc-alist gnus-newsrc-assoc))))
     (gnus-make-hashtable-from-newsrc-alist)
-    (when gnus-topic-alist
-      (setq gnus-topic-alist
-	    (mapcar
-	     (lambda (elt)
-	       (cons (car elt)
-		     (mapcar (lambda (g)
-			       (if (string-match-p "[^[:ascii:]]" g)
-				   (gnus-group-decoded-name g)
-				 g))
-			     (cdr elt))))
-	     gnus-topic-alist)))
     (when (file-newer-than-file-p file ding-file)
       ;; Old format quick file
       (gnus-message 5 "Reading %s..." file)
@@ -2878,8 +2944,6 @@ gnus-gnus-to-quick-newsrc-format
 		  (delete "dummy.group" gnus-group-list)))
     (let* ((print-quoted t)
            (print-readably t)
-           (print-escape-multibyte nil)
-           (print-escape-nonascii t)
            (print-length nil)
            (print-level nil)
 	   (print-circle nil)
@@ -2895,26 +2959,6 @@ gnus-gnus-to-quick-newsrc-format
 		  ;; Remove the `gnus-killed-list' from the list of variables
 		  ;; to be saved, if required.
 		  (delq 'gnus-killed-list (copy-sequence gnus-variable-list)))))
-	   ;; Encode group names in `gnus-newsrc-alist' and
-	   ;; `gnus-topic-alist' in order to keep newsrc.eld files
-	   ;; compatible with older versions of Gnus.  At some point,
-	   ;; if/when a new version of Gnus is released, stop doing
-	   ;; this and move the corresponding decode in
-	   ;; `gnus-read-newsrc-el-file' into a conversion routine.
-	   (gnus-newsrc-alist
-	    (mapcar (lambda (info)
-		      (cons (encode-coding-string (car info) 'utf-8-emacs)
-			    (cdr info)))
-		    gnus-newsrc-alist))
-	   (gnus-topic-alist
-	    (when (memq 'gnus-topic-alist variables)
-	     (mapcar (lambda (elt)
-		       (cons (car elt) ; Topic name
-			     (mapcar (lambda (g)
-				       (encode-coding-string
-					g 'utf-8-emacs))
-				     (cdr elt))))
-		     gnus-topic-alist)))
 	   variable)
       ;; Insert the variables into the file.
       (while variables
diff --git a/lisp/gnus/gnus.el b/lisp/gnus/gnus.el
index 0673ac15f6..90b70e0923 100644
--- a/lisp/gnus/gnus.el
+++ b/lisp/gnus/gnus.el
@@ -6,7 +6,7 @@
 ;; Author: Masanobu UMEDA <umerin@flab.flab.fujitsu.junet>
 ;;	Lars Magne Ingebrigtsen <larsi@gnus.org>
 ;; Keywords: news, mail
-;; Version: 5.13
+;; Version: 5.14
 
 ;; This file is part of GNU Emacs.
 
@@ -292,7 +292,7 @@ gnus-fun
   :link '(custom-manual "(gnus)Exiting Gnus")
   :group 'gnus)
 
-(defconst gnus-version-number "5.13"
+(defconst gnus-version-number "5.14"
   "Version number for this version of Gnus.")
 
 (defconst gnus-version (format "Gnus v%s" gnus-version-number)
-- 
2.24.0


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

* bug#38381: 27.0.50; Bump Gnus version to 5.14, properly encode group names on disk
  2019-11-25 23:56 bug#38381: 27.0.50; Bump Gnus version to 5.14, properly encode group names on disk Eric Abrahamsen
@ 2019-11-26  0:02 ` Lars Ingebrigtsen
  2019-11-26  0:50   ` Eric Abrahamsen
  0 siblings, 1 reply; 5+ messages in thread
From: Lars Ingebrigtsen @ 2019-11-26  0:02 UTC (permalink / raw)
  To: Eric Abrahamsen; +Cc: 38381

Eric Abrahamsen <eric@ericabrahamsen.net> writes:

> Now Emacs 27.1 is on its way, and I would really like to make this
> change permanent. The attached patch moves all the ugly compatibility
> code into an upgrade routine as part of `gnus-convert-old-newsrc'. Users
> will be prompted once to upgrade, and then the various files will be
> fixed to use properly encoded group names, and you won't be able to go
> back.

I don't think that's a good idea.  The .newsrc.eld file should remain
backwards compatible -- people do move back and forth between newer and
older versions of Emacs.

-- 
(domestic pets only, the antidote for overdose, milk.)
   bloggy blog: http://lars.ingebrigtsen.no





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

* bug#38381: 27.0.50; Bump Gnus version to 5.14, properly encode group names on disk
  2019-11-26  0:02 ` Lars Ingebrigtsen
@ 2019-11-26  0:50   ` Eric Abrahamsen
  2019-11-26  1:11     ` Lars Ingebrigtsen
  0 siblings, 1 reply; 5+ messages in thread
From: Eric Abrahamsen @ 2019-11-26  0:50 UTC (permalink / raw)
  To: Lars Ingebrigtsen; +Cc: 38381

Lars Ingebrigtsen <larsi@gnus.org> writes:

> Eric Abrahamsen <eric@ericabrahamsen.net> writes:
>
>> Now Emacs 27.1 is on its way, and I would really like to make this
>> change permanent. The attached patch moves all the ugly compatibility
>> code into an upgrade routine as part of `gnus-convert-old-newsrc'. Users
>> will be prompted once to upgrade, and then the various files will be
>> fixed to use properly encoded group names, and you won't be able to go
>> back.
>
> I don't think that's a good idea.  The .newsrc.eld file should remain
> backwards compatible -- people do move back and forth between newer and
> older versions of Emacs.

Okay, but there is a whole upgrade mechanism in place that's
specifically for upgrading the .newsrc.eld file to a new version, so
this wouldn't be the first time it's happened.

That said, the current situation seems to be working fine; if we've got
to keep it, we've got to keep it. I'd like to keep this bug report open,
though.

Eric





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

* bug#38381: 27.0.50; Bump Gnus version to 5.14, properly encode group names on disk
  2019-11-26  0:50   ` Eric Abrahamsen
@ 2019-11-26  1:11     ` Lars Ingebrigtsen
  2019-11-26  4:26       ` Eric Abrahamsen
  0 siblings, 1 reply; 5+ messages in thread
From: Lars Ingebrigtsen @ 2019-11-26  1:11 UTC (permalink / raw)
  To: Eric Abrahamsen; +Cc: 38381

Eric Abrahamsen <eric@ericabrahamsen.net> writes:

> Okay, but there is a whole upgrade mechanism in place that's
> specifically for upgrading the .newsrc.eld file to a new version, so
> this wouldn't be the first time it's happened.

It's only been used once, back in...  what...  1996?  (There's other
converters for agentey stuff, but that's not very impactful.)  And if I
remember correctly, it wasn't backwards-incompatible...  just
forwards-incompatible.

> That said, the current situation seems to be working fine; if we've got
> to keep it, we've got to keep it. I'd like to keep this bug report open,
> though.

If we're not going to do conversion like that, I don't see much point in
keeping the bug report open?

-- 
(domestic pets only, the antidote for overdose, milk.)
   bloggy blog: http://lars.ingebrigtsen.no





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

* bug#38381: 27.0.50; Bump Gnus version to 5.14, properly encode group names on disk
  2019-11-26  1:11     ` Lars Ingebrigtsen
@ 2019-11-26  4:26       ` Eric Abrahamsen
  0 siblings, 0 replies; 5+ messages in thread
From: Eric Abrahamsen @ 2019-11-26  4:26 UTC (permalink / raw)
  To: Lars Ingebrigtsen; +Cc: 38381

Lars Ingebrigtsen <larsi@gnus.org> writes:

> Eric Abrahamsen <eric@ericabrahamsen.net> writes:
>
>> Okay, but there is a whole upgrade mechanism in place that's
>> specifically for upgrading the .newsrc.eld file to a new version, so
>> this wouldn't be the first time it's happened.
>
> It's only been used once, back in...  what...  1996?  (There's other
> converters for agentey stuff, but that's not very impactful.)  And if I
> remember correctly, it wasn't backwards-incompatible...  just
> forwards-incompatible.
>
>> That said, the current situation seems to be working fine; if we've got
>> to keep it, we've got to keep it. I'd like to keep this bug report open,
>> though.
>
> If we're not going to do conversion like that, I don't see much point in
> keeping the bug report open?

One can hope...

Never mind.





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

end of thread, other threads:[~2019-11-26  4:26 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2019-11-25 23:56 bug#38381: 27.0.50; Bump Gnus version to 5.14, properly encode group names on disk Eric Abrahamsen
2019-11-26  0:02 ` Lars Ingebrigtsen
2019-11-26  0:50   ` Eric Abrahamsen
2019-11-26  1:11     ` Lars Ingebrigtsen
2019-11-26  4:26       ` Eric Abrahamsen

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).