;;; char-db-util.el --- Character Database utility -*- coding: utf-8-er; -*-
;; Copyright (C) 1998,1999,2000,2001,2002,2003,2004,2005,2006,2007,
-;; 2008,2009,2010,2011,2012,2013,2014,2015,2016 MORIOKA Tomohiko.
+;; 2008,2009,2010,2011,2012,2013,2014,2015,2016,2017 MORIOKA Tomohiko.
;; Author: MORIOKA Tomohiko <tomo@kanji.zinbun.kyoto-u.ac.jp>
;; Keywords: CHISE, Character Database, ISO/IEC 10646, UCS, Unicode, MULE.
==hanyo-denshi/jb
==hanyo-denshi/jc
==hanyo-denshi/ft
+ ==hanyo-denshi/ia
==hanyo-denshi/ib
==hanyo-denshi/hg
==hanyo-denshi/jt
==hanyo-denshi/ks
+ ==hanyo-denshi/tk
=gt
=gt-k
=daikanwa
=ucs-var-002
=ucs-var-003
=ucs-var-004
+ =ucs-var-005
+ =ucs-var-006
+ =ucs-var-008
=ucs-var-010
=ucs-itaiji-001
=ucs-itaiji-002
=ucs-itaiji-004
=ucs-itaiji-005
=ucs-itaiji-006
+ =ucs-itaiji-007
=ucs-itaiji-008
+ =ucs-itaiji-009
+ =ucs-itaiji-011
+ =>ucs-itaiji-001
+ =>ucs-itaiji-002
+ =>ucs-itaiji-003
+ =>ucs-itaiji-004
+ =>ucs-itaiji-005
+ =>ucs-itaiji-006
+ =>ucs-itaiji-007
+ =big5-cdp-var-001
+ =big5-cdp-var-002
=big5-cdp-var-003
=big5-cdp-var-004
=big5-cdp-var-005
- =>ucs@iwds-1))
+ =big5-cdp-itaiji-001
+ =big5-cdp-itaiji-002
+ =big5-cdp-itaiji-003
+ =>big5-cdp-itaiji-001
+ =>ucs@iwds-1
+ =>ucs@component
+ ==ucs@gb
+ =ucs@gb
+ =ucs@JP/hanazono))
;;; @ char-db formatters
(setq strokes value)))
(setq attributes (delq 'kangxi-strokes attributes))
)
- (when (and (memq 'japanese-radical attributes)
- (setq value (get-char-attribute char 'japanese-radical)))
- (unless (eq value radical)
- (insert (format "(japanese-radical\t . %S)\t; %c%s"
- value
- (ideographic-radical value)
- line-breaking))
- (or radical
- (setq radical value)))
- (setq attributes (delq 'japanese-radical attributes))
- )
+ ;; (when (and (memq 'japanese-radical attributes)
+ ;; (setq value (get-char-attribute char 'japanese-radical)))
+ ;; (unless (eq value radical)
+ ;; (insert (format "(japanese-radical\t . %S)\t; %c%s"
+ ;; value
+ ;; (ideographic-radical value)
+ ;; line-breaking))
+ ;; (or radical
+ ;; (setq radical value)))
+ ;; (setq attributes (delq 'japanese-radical attributes))
+ ;; )
(when (and (memq 'japanese-strokes attributes)
(setq value (get-char-attribute char 'japanese-strokes)))
(unless (eq value strokes)
;; (setq radical value)))
;; (setq attributes (delq 'shinjigen-1-radical attributes))
;; )
- (when (and (memq 'ideographic- attributes)
- (setq value (get-char-attribute char 'ideographic-)))
- (insert "(ideographic- ")
- (setq lbs (concat "\n" (make-string (current-column) ?\ ))
- separator nil)
- (while (consp value)
- (setq cell (car value))
- (if (integerp cell)
- (setq cell (decode-char '=ucs cell)))
- (cond ((characterp cell)
- (if separator
- (insert lbs))
- (if readable
- (insert (format "%S" cell))
- (char-db-insert-char-spec cell readable))
- (setq separator lbs))
- ((consp cell)
- (if separator
- (insert lbs))
- (if (consp (car cell))
- (char-db-insert-char-spec cell readable)
- (char-db-insert-char-reference cell readable))
- (setq separator lbs))
- (t
- (if separator
- (insert separator))
- (insert (prin1-to-string cell))
- (setq separator " ")))
- (setq value (cdr value)))
- (insert ")")
- (insert line-breaking)
- (setq attributes (delq 'ideographic- attributes)))
+ ;; (when (and (memq 'ideographic- attributes)
+ ;; (setq value (get-char-attribute char 'ideographic-)))
+ ;; (insert "(ideographic- ")
+ ;; (setq lbs (concat "\n" (make-string (current-column) ?\ ))
+ ;; separator nil)
+ ;; (while (consp value)
+ ;; (setq cell (car value))
+ ;; (if (integerp cell)
+ ;; (setq cell (decode-char '=ucs cell)))
+ ;; (cond ((characterp cell)
+ ;; (if separator
+ ;; (insert lbs))
+ ;; (if readable
+ ;; (insert (format "%S" cell))
+ ;; (char-db-insert-char-spec cell readable))
+ ;; (setq separator lbs))
+ ;; ((consp cell)
+ ;; (if separator
+ ;; (insert lbs))
+ ;; (if (consp (car cell))
+ ;; (char-db-insert-char-spec cell readable)
+ ;; (char-db-insert-char-reference cell readable))
+ ;; (setq separator lbs))
+ ;; (t
+ ;; (if separator
+ ;; (insert separator))
+ ;; (insert (prin1-to-string cell))
+ ;; (setq separator " ")))
+ ;; (setq value (cdr value)))
+ ;; (insert ")")
+ ;; (insert line-breaking)
+ ;; (setq attributes (delq 'ideographic- attributes)))
(when (and (memq 'total-strokes attributes)
(setq value (get-char-attribute char 'total-strokes)))
(insert (format "(total-strokes . %S)%s"
line-breaking))
(setq attributes (delq 'total-strokes attributes))
)
- (when (and (memq '->ideograph attributes)
- (setq value (get-char-attribute char '->ideograph)))
- (insert (format "(->ideograph\t%s)%s"
- (mapconcat (lambda (code)
- (cond ((symbolp code)
- (symbol-name code))
- ((integerp code)
- (format "#x%04X" code))
- (t
- (format "%s %S"
- line-breaking code))))
- value " ")
- line-breaking))
- (setq attributes (delq '->ideograph attributes))
- )
+ ;; (when (and (memq '->ideograph attributes)
+ ;; (setq value (get-char-attribute char '->ideograph)))
+ ;; (insert (format "(->ideograph\t%s)%s"
+ ;; (mapconcat (lambda (code)
+ ;; (cond ((symbolp code)
+ ;; (symbol-name code))
+ ;; ((integerp code)
+ ;; (format "#x%04X" code))
+ ;; (t
+ ;; (format "%s %S"
+ ;; line-breaking code))))
+ ;; value " ")
+ ;; line-breaking))
+ ;; (setq attributes (delq '->ideograph attributes))
+ ;; )
;; (when (and (memq '->decomposition attributes)
;; (setq value (get-char-attribute char '->decomposition)))
;; (insert (format "(->decomposition\t%s)%s"
line-breaking))
(setq attributes (delq '->mojikyo attributes))
)
- (when (and (memq 'hanyu-dazidian-vol attributes)
- (setq value (get-char-attribute char 'hanyu-dazidian-vol)))
- (insert (format "(hanyu-dazidian-vol . %d)%s"
- value line-breaking))
- (setq attributes (delq 'hanyu-dazidian-vol attributes))
- )
- (when (and (memq 'hanyu-dazidian-page attributes)
- (setq value (get-char-attribute char 'hanyu-dazidian-page)))
- (insert (format "(hanyu-dazidian-page . %d)%s"
- value line-breaking))
- (setq attributes (delq 'hanyu-dazidian-page attributes))
- )
- (when (and (memq 'hanyu-dazidian-char attributes)
- (setq value (get-char-attribute char 'hanyu-dazidian-char)))
- (insert (format "(hanyu-dazidian-char . %d)%s"
- value line-breaking))
- (setq attributes (delq 'hanyu-dazidian-char attributes))
- )
+ ;; (when (and (memq 'hanyu-dazidian-vol attributes)
+ ;; (setq value (get-char-attribute char 'hanyu-dazidian-vol)))
+ ;; (insert (format "(hanyu-dazidian-vol . %d)%s"
+ ;; value line-breaking))
+ ;; (setq attributes (delq 'hanyu-dazidian-vol attributes))
+ ;; )
+ ;; (when (and (memq 'hanyu-dazidian-page attributes)
+ ;; (setq value (get-char-attribute char 'hanyu-dazidian-page)))
+ ;; (insert (format "(hanyu-dazidian-page . %d)%s"
+ ;; value line-breaking))
+ ;; (setq attributes (delq 'hanyu-dazidian-page attributes))
+ ;; )
+ ;; (when (and (memq 'hanyu-dazidian-char attributes)
+ ;; (setq value (get-char-attribute char 'hanyu-dazidian-char)))
+ ;; (insert (format "(hanyu-dazidian-char . %d)%s"
+ ;; value line-breaking))
+ ;; (setq attributes (delq 'hanyu-dazidian-char attributes))
+ ;; )
(unless readable
(dolist (ignored '(composition
->denotational <-subsumptive ->ucs-unified
)
((or (eq name 'ideographic-structure)
(eq name 'ideographic-combination)
- (eq name 'ideographic-)
+ ;; (eq name 'ideographic-)
(eq name '=decomposition)
(char-feature-base-name= '=decomposition name)
(char-feature-base-name= '=>decomposition name)
(char-db-insert-relation-feature char name value
line-breaking
ccss readable))
- ((memq name '(ideograph=
- original-ideograph-of
- ancient-ideograph-of
- vulgar-ideograph-of
- wrong-ideograph-of
- ;; simplified-ideograph-of
- ideographic-variants
- ;; ideographic-different-form-of
- ))
- (insert (format "(%-18s%s " name line-breaking))
- (setq lbs (concat "\n" (make-string (current-column) ?\ ))
- separator nil)
- (while (consp value)
- (setq cell (car value))
- (if (and (consp cell)
- (consp (car cell)))
- (progn
- (if separator
- (insert lbs))
- (char-db-insert-alist cell readable)
- (setq separator lbs))
- (if separator
- (insert separator))
- (insert (prin1-to-string cell))
- (setq separator " "))
- (setq value (cdr value)))
- (insert ")")
- (insert line-breaking))
+ ;; ((memq name '(ideograph=
+ ;; original-ideograph-of
+ ;; ancient-ideograph-of
+ ;; vulgar-ideograph-of
+ ;; wrong-ideograph-of
+ ;; ;; simplified-ideograph-of
+ ;; ideographic-variants
+ ;; ;; ideographic-different-form-of
+ ;; ))
+ ;; (insert (format "(%-18s%s " name line-breaking))
+ ;; (setq lbs (concat "\n" (make-string (current-column) ?\ ))
+ ;; separator nil)
+ ;; (while (consp value)
+ ;; (setq cell (car value))
+ ;; (if (and (consp cell)
+ ;; (consp (car cell)))
+ ;; (progn
+ ;; (if separator
+ ;; (insert lbs))
+ ;; (char-db-insert-alist cell readable)
+ ;; (setq separator lbs))
+ ;; (if separator
+ ;; (insert separator))
+ ;; (insert (prin1-to-string cell))
+ ;; (setq separator " "))
+ ;; (setq value (cdr value)))
+ ;; (insert ")")
+ ;; (insert line-breaking))
((consp value)
(insert (format "(%-18s " name))
(setq lbs (concat "\n" (make-string (current-column) ?\ ))