diff options
| author | Stefan Monnier <monnier@iro.umontreal.ca> | 2015-03-18 23:02:26 -0400 | 
|---|---|---|
| committer | Stefan Monnier <monnier@iro.umontreal.ca> | 2015-03-18 23:02:26 -0400 | 
| commit | 50c117fe86d94719807cbe08353c032779b3b910 (patch) | |
| tree | 9db572083112db33d17d759a245278fa0af7b897 /lisp/emacs-lisp/eieio-opt.el | |
| parent | f469024eea692a163beb98a824b5cc0a4e8bcda8 (diff) | |
| download | emacs-50c117fe86d94719807cbe08353c032779b3b910.tar.gz | |
EIEIO: Change class's representation to unify instance & class slots
* lisp/emacs-lisp/eieio-core.el (eieio--class): Change field names and order
to match those of cl--class; use cl--slot for both instance slots and
class slots.
(eieio--object-num-slots): Use cl-struct-slot-info.
(eieio--object-class): Rename from eieio--object-class-object.
(eieio--object-class-name): Remove.
(eieio-defclass-internal): Adjust to new slot representation.
Store doc in class rather than in `variable-documentation'.
(eieio--perform-slot-validation-for-default): Change API to take
a slot object.
(eieio--slot-override): New function.
(eieio--add-new-slot): Rewrite.
(eieio-copy-parents-into-subclass): Rewrite.
(eieio--validate-slot-value, eieio--validate-class-slot-value)
(eieio-oref-default, eieio-oset-default)
(eieio--class-slot-name-index, eieio-set-defaults): Adjust to new
slot representation.
(eieio--c3-merge-lists): Simplify.
(eieio--class/struct-parents): New function.
(eieio--class-precedence-bfs): Use it.
* lisp/emacs-lisp/eieio.el (with-slots): Use macroexp-let2.
(object-class-fast): Change recommend replacement.
(eieio-object-class): Rewrite.
(slot-exists-p): Adjust to new slot representation.
(initialize-instance): Adjust to new slot representation.
(object-write): Adjust to new slot representation.
* lisp/emacs-lisp/eieio-base.el (eieio-persistent-convert-list-to-object):
Manually map initargs to slot names.
(eieio-persistent-validate/fix-slot-value): Adjust to new
slot representation.
* lisp/emacs-lisp/eieio-compat.el (eieio--generic-static-symbol-specializers):
Extract from eieio--generic-static-symbol-generalizer.
(eieio--generic-static-symbol-generalizer): Use it.
* lisp/emacs-lisp/eieio-custom.el (eieio-object-value-create)
(eieio-object-value-get): Adjust to new slot representation.
* lisp/emacs-lisp/eieio-datadebug.el (data-debug/eieio-insert-slots):
Declare to silence warnings.
(data-debug-insert-object-button): Avoid `object-slots'.
(data-debug/eieio-insert-slots): Adjust to new slot representation.
* lisp/emacs-lisp/eieio-opt.el (eieio--help-print-slot): New function
extracted from eieio-help-class-slots.
(eieio-help-class-slots): Use it.  Adjust to new slot representation.
* test/automated/eieio-test-methodinvoke.el (make-instance): Use new-style
`subclass' specializer for a change.
* test/automated/eieio-test-persist.el (persist-test-save-and-compare):
Adjust to new slot representation.
* test/automated/eieio-tests.el (eieio-test-17-virtual-slot): Don't use
initarg in `oset'.
(eieio-test-32-slot-attribute-override-2): Adjust to new
slot representation.
* lisp/emacs-lisp/cl-preloaded.el (cl--class): Fix type of `parents'.
Diffstat (limited to 'lisp/emacs-lisp/eieio-opt.el')
| -rw-r--r-- | lisp/emacs-lisp/eieio-opt.el | 90 | 
1 files changed, 28 insertions, 62 deletions
| diff --git a/lisp/emacs-lisp/eieio-opt.el b/lisp/emacs-lisp/eieio-opt.el index a769ca7b536..7f98730340d 100644 --- a/lisp/emacs-lisp/eieio-opt.el +++ b/lisp/emacs-lisp/eieio-opt.el @@ -99,7 +99,7 @@ If CLASS is actually an object, then also display current values of that object.      (when pl        (insert " Inherits from ")        (while (setq cur (pop pl)) -	(setq cur (eieio--class-symbol cur)) +	(setq cur (eieio--class-name cur))  	(insert "`")  	(help-insert-xref-button (symbol-name cur)  				 'help-function cur) @@ -136,74 +136,40 @@ If CLASS is actually an object, then also display current values of that object.                    (or doc "")))  	(insert "\n\n"))))) +(defun eieio--help-print-slot (slot) +  (insert +   (concat +    (propertize "Slot: " 'face 'bold) +    (prin1-to-string (cl--slot-descriptor-name slot)) +    (unless (eq (cl--slot-descriptor-type slot) t) +      (concat "    type = " +              (prin1-to-string (cl--slot-descriptor-type slot)))) +    (unless (eq (cl--slot-descriptor-initform slot) eieio-unbound) +      (concat "    default = " +              (prin1-to-string (cl--slot-descriptor-initform slot)))) +    (when (alist-get :printer (cl--slot-descriptor-props slot)) +      (concat "    printer = " +              (prin1-to-string +               (alist-get :printer (cl--slot-descriptor-props slot))))) +    (when (alist-get :documentation (cl--slot-descriptor-props slot)) +      (concat "\n  " (alist-get :documentation (cl--slot-descriptor-props slot)) +              "\n"))) +   "\n")) +  (defun eieio-help-class-slots (class)    "Print help description for the slots in CLASS.  Outputs to the current buffer."    (let* ((cv (eieio--class-v class)) -	 (docs   (eieio--class-public-doc cv)) -	 (names  (eieio--class-public-a cv)) -	 (deflt  (eieio--class-public-d cv)) -	 (types  (eieio--class-public-type cv)) -	 (publp (eieio--class-public-printer cv)) -	 (i      0) -	 (prot   (eieio--class-protection cv)) -	 ) +         (slots (eieio--class-slots cv)) +         (cslots (eieio--class-class-slots cv)))      (insert (propertize "Instance Allocated Slots:\n\n"  			'face 'bold)) -    (while names -      (insert -       (concat -	(when (car prot) -	  (propertize "Private " 'face 'bold)) -	(propertize "Slot: " 'face 'bold) -	(prin1-to-string (car names)) -	(unless (eq (aref types i) t) -	  (concat "    type = " -		  (prin1-to-string (aref types i)))) -	(unless (eq (car deflt) eieio-unbound) -	  (concat "    default = " -		  (prin1-to-string (car deflt)))) -	(when (car publp) -	  (concat "    printer = " -		  (prin1-to-string (car publp)))) -	(when (car docs) -	  (concat "\n  " (car docs) "\n")) -	"\n")) -      (setq names (cdr names) -	    docs (cdr docs) -	    deflt (cdr deflt) -	    publp (cdr publp) -	    prot (cdr prot) -	    i (1+ i))) -    (setq docs  (eieio--class-class-allocation-doc cv) -	  names (eieio--class-class-allocation-a cv) -	  types (eieio--class-class-allocation-type cv) -	  i     0 -	  prot  (eieio--class-class-allocation-protection cv)) -    (when names +    (dotimes (i (length slots)) +      (eieio--help-print-slot (aref slots i))) +    (when (> (length cslots) 0)        (insert (propertize "\nClass Allocated Slots:\n\n" 'face 'bold))) -    (while names -      (insert -       (concat -	(when (car prot) -	  "Private ") -	"Slot: " -	(prin1-to-string (car names)) -	(unless (eq (aref types i) t) -	  (concat "    type = " -		  (prin1-to-string (aref types i)))) -	(condition-case nil -	    (let ((value (eieio-oref class (car names)))) -	      (concat "   value = " -		      (prin1-to-string value))) -	  (error nil)) -	(when (car docs) -	  (concat "\n\n " (car docs) "\n")) -	"\n")) -      (setq names (cdr names) -	    docs (cdr docs) -	    prot (cdr prot) -	    i (1+ i))))) +    (dotimes (i (length cslots)) +      (eieio--help-print-slot (aref cslots i)))))  (defun eieio-build-class-alist (&optional class instantiable-only buildlist)    "Return an alist of all currently active classes for completion purposes. | 
