+;; (let (gt ret)
+;; (dolist (ccs '(=gt-pj-1
+;; =gt-pj-2
+;; =gt-pj-3
+;; =gt-pj-4
+;; =gt-pj-5
+;; =gt-pj-6
+;; =gt-pj-7
+;; =gt-pj-8
+;; =gt-pj-9
+;; =gt-pj-10
+;; =gt-pj-11))
+;; (map-char-attribute
+;; (lambda (c v)
+;; (when (setq gt (encode-char c '=gt))
+;; (put-char-attribute c '=gt gt)
+;; (put-char-attribute (decode-char ccs v) '=gt gt))
+;; nil)
+;; ccs)))
+
+;; (let (ret)
+;; (dolist (feature
+;; (let (dest)
+;; (dolist (feature (char-attribute-list))
+;; (when (string-match "\\*sources\\($\\|@[^\\*]+$\\)"
+;; (symbol-name feature))
+;; (setq dest (cons feature dest))))
+;; dest))
+;; (map-char-attribute
+;; (lambda (c v)
+;; (when (setq ret (memq 'shinjigen-1 v))
+;; (setcar ret 'shinjigen@1ed))
+;; (when (setq ret (memq 'shinjigen-2 v))
+;; (setcar ret 'shinjigen@rev))
+;; nil)
+;; feature)))
+
+;; (map-char-attribute
+;; (lambda (c v)
+;; (when (eq (encode-char c '=shinjigen@rev) v)
+;; (put-char-attribute c '=shinjigen v)
+;; (remove-char-attribute c '=shinjigen@1ed)
+;; (remove-char-attribute c '=shinjigen@rev)
+;; )
+;; nil)
+;; '=shinjigen@1ed)
+
+;; (let (ret)
+;; (dolist (feature
+;; (let (dest)
+;; (dolist (feature (char-attribute-list))
+;; (when (string-match "\\*sources\\($\\|@[^\\*]+$\\)"
+;; (symbol-name feature))
+;; (setq dest (cons feature dest))))
+;; dest))
+;; (map-char-attribute
+;; (lambda (c v)
+;; (cond ((setq ret (memq 'shinjigen@1ed v))
+;; (when (memq 'shinjigen@rev ret)
+;; (setcar ret 'shinjigen)
+;; (delq 'shinjigen@rev ret)
+;; ))
+;; ((setq ret (memq 'shinjigen@rev v))
+;; (when (memq 'shinjigen@1ed ret)
+;; (setcar ret 'shinjigen)
+;; (delq 'shinjigen@1ed ret)
+;; )))
+;; nil)
+;; feature)))
+
+(dolist (ccs '(=jis-x0208 =jis-x0208@1990))
+ (map-char-attribute
+ (lambda (c v)
+ (unless (eq (encode-char c '=jis-x0213-1@2000) v)
+ (put-char-attribute c '=jis-x0213-1 v))
+ nil)
+ ccs))
+
+(with-temp-buffer
+ (buffer-disable-undo)
+ (insert-file-contents "../etc/char-data/JX3-JX1-rep-diff.txt")
+ (goto-char (point-min))
+ (let (ku ten char code ucs rep-char)
+ (while (re-search-forward "^1-\\([0-9]+\\)-\\([0-9]+\\)[ \t]+" nil t)
+ (setq ku (string-to-number (match-string 1))
+ ten (string-to-number (match-string 2)))
+ (setq char (make-char '=jis-x0213-1@2000 (+ ku 32)(+ ten 32)))
+ (setq code (encode-char char '=jis-x0213-1@2000))
+ (setq ucs (encode-char char '=ucs@jis/2000))
+ (setq rep-char (decode-char '==jis-x0213-1@2000 code))
+ (cond
+ ((or (eq char rep-char)
+ (null rep-char))
+ (put-char-attribute char '=jis-x0213-1@2000 code)
+ (remove-char-attribute char '=jis-x0213-1)
+ (remove-char-attribute char '=jis-x0213-1@2004)
+ (remove-char-attribute char '=ucs@jis)
+ (remove-char-attribute char '=ucs@jis/2004)
+ (when (setq char (decode-char '=jis-x0213-1@2004 code))
+ (unless (eq (encode-char char '=ucs@jis/2004) ucs)
+ (put-char-attribute char '=ucs@jis/2004 ucs)))
+ )
+ (rep-char
+ (put-char-attribute rep-char '==jis-x0213-1@2000 code)
+ (remove-char-attribute rep-char '==jis-x0213-1)
+ (remove-char-attribute rep-char '==jis-x0213-1@2004)
+ (setq ucs (or (encode-char rep-char '==ucs@jis/2000)
+ ucs))
+ (remove-char-attribute rep-char '==ucs@jis)
+ (remove-char-attribute rep-char '==ucs@jis/2004)
+ (when (setq rep-char (decode-char '==jis-x0213-1@2004 code))
+ (unless (eq (encode-char rep-char '==ucs@jis/2004) ucs)
+ (put-char-attribute rep-char '==ucs@jis/2004 ucs)))
+ ))
+ (unless (eq code #x332A)
+ (when (setq char (decode-char '=>jis-x0208@1997 code 'defined-only))
+ (unless (eq (encode-char char '=>>jis-x0208) code)
+ (unless (eq (encode-char char '=+>jis-x0208) code)
+ (put-char-attribute char '=>jis-x0208 code)
+ (remove-char-attribute char '=>jis-x0208@1997)))))
+ )))
+
+(map-char-attribute
+ (lambda (c v)
+ (unless (eq (encode-char c '=>jis-x0213-1) v)
+ (put-char-attribute c '=>jis-x0213-1 v))
+ nil)
+ '=>jis-x0208)
+
+(let (dg-chr)
+ (map-char-attribute
+ (lambda (c v)
+ (when (setq dg-chr (decode-char '===jis-x0213-1@2000 v))
+ (unless (eq c dg-chr)
+ (put-char-attribute dg-chr '===hanyo-denshi/jc v)))
+ nil)
+ '==hanyo-denshi/jc)
+ (map-char-attribute
+ (lambda (c v)
+ (when (setq dg-chr (decode-char '===jis-x0213-2 v))
+ (unless (eq c dg-chr)
+ (put-char-attribute dg-chr '===hanyo-denshi/jd v)))
+ nil)
+ '==hanyo-denshi/jd)
+ )
+