File: special-slots-3.lisp

package info (click to toggle)
cl-contextl 1%3A20160313.git5894fba-1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 332 kB
  • sloc: lisp: 3,146; makefile: 2
file content (34 lines) | stat: -rw-r--r-- 1,003 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
(asdf:oos 'asdf:load-op :contextl)

(in-package :contextl-user)

(defclass person3 ()
  ((name3 :initarg :name
          :accessor person-name3))
  (:metaclass special-class))

(defparameter *p*
  (make-instance 'person3 :name "Dr. Jekyll"))

(assert (equal (person-name3 *p*) "Dr. Jekyll"))

(defparameter *error-count* 0)

(symbol-macrolet ((safe-special-symbol-progv t))
  (handler-bind
      ((error (lambda (error)
                (incf *error-count*)
                (eval '(defclass person3 ()
                         ((name3 :initarg :name
                                 :special t
                                 :accessor person-name3))
                         (:metaclass special-class)))
                (assert (equal (person-name3 *p*) "Dr. Jekyll"))
                (continue error))))
    (dletf (((person-name3 *p*) "Mr. Hide"))
      (assert (equal (person-name3 *p*) "Mr. Hide")))))

(assert (eql *error-count* 1))
(assert (equal (person-name3 *p*) "Dr. Jekyll"))

(print :done)