Warning: this is an htmlized version!
The original is here, and
the conversion rules are here.
;; This file:
;;   http://anggtwu.net/LISP/tostring1.lisp.html
;;   http://anggtwu.net/LISP/tostring1.lisp
;;          (find-angg "LISP/tostring1.lisp")
;; Author: Eduardo Ochs <eduardoochs@gmail.com>
;;
;; (defun e () (interactive) (find-angg "LISP/tostring1.lisp"))
;; (find-eev "eev-blinks.el" "find-estruct")
;; (find-es "lisp" "defclass")
;; (find-es "emacs" "cl-print-object")


(defclass mypair ()
  ((a :initarg :a :initform nil)
   (b :initarg :b :initform nil)))

(defun mkmypair (aa bb) (make-instance 'mypair :a aa :b bb))

(defmethod print-object ((p mypair) stream)
  (with-slots (a b) p (format stream "~a_~a" a b)))

(mkmypair 22 33)   ; -> 22_33

#|
* (eepitch-sbcl)
* (eepitch-kill)
* (eepitch-sbcl)
(load "tostring1.lisp")

(describe (mkmypair 22 33))
(mkmypair 22 33)

|#





























#|
* (eepitch-sbcl)
* (eepitch-kill)
* (eepitch-sbcl)
(load "tostring1.lisp")

(defvar ab)
(setq ab (mkmypair 22 33))
(setq ab (mkmypair 222 333))
(slot-value ab 'a)

(with-slots (a b) ab (list a b))
(with-slots (a b) ab (format nil "~a_~a" a b))

(defmethod print-object ((p mypair) stream)
  (with-slots (a b) p (format stream "~a_~a" a b)))

(mkmypair 4 5)

ab

  (princ (pr obj) stream))

(defun prmypair ((p mypair)))


(defclass mypair () ((a :initarg :a) (b :initarg :b)))
(make-instance 'mypair :a 22 :b 33)
(describe (make-instance 'mypair :a 22 :b 33))
(describe (make-instance 'mypair       :b 33))
(describe (make-instance 'mypair :a 22))
(describe (make-instance 'mypair))
(with-slots ((aa a) (bb b)) (make-instance 'mypair :a 22 :b 33) (list aa bb))
(with-slots ((aa a) (bb b)) (make-instance 'mypair       :b 33) (list aa bb)) ; err

(defmethod print-object ((obj person) stream)
      (print-unreadable-object (obj stream :type t)
        (with-accessors ((name name)
                         (lisper lisper))
            obj
          (format stream "~a, lisper: ~a" name lisper))))




#<STANDARD-CLASS COMMON-LISP-USER::TRIPLE>
CL-USER> (make-instance 'triple :a 1 :b 2 :c 3)
#<TRIPLE {101927F7D3}>

(defclass C () ())
(describe 'C)
(defclass C (a b) ())
(describe 'C)
(defclass C () (a b))
(describe 'C)
(make-instance 'C)
(describe (make-instance 'C))
(describe (make-instance 'C 2 3))
(describe (make-instance 'C :elements 2 3))
(describe 'make-instance)

* (eepitch-sbcl)
* (eepitch-kill)
* (eepitch-sbcl)
              (defclass mytriple () (a b c))
(macroexpand '(defclass mytriple () (a b c)))
             (describe 'mytriple)
(make-instance 'mytriple)
(make-instance 'mytriple :a 22)

(describe (make-instance 'C 2 3))




(let ((A (make-instance 'my-array :elements '(23 45))))
  (print A)) ;; This prints "23_45"

|#