r3491: *** empty log message ***
[hyperobject.git] / example.lisp
index 974a1e20af5717b456f39d26b6a5b8c7f3ee61a7..e16bba54835954ff78f905ec240ebbe67a40410e 100644 (file)
@@ -2,16 +2,14 @@
 ;;;; *************************************************************************
 ;;;; FILE IDENTIFICATION
 ;;;;
-;;;; Name:          hyperobject-plain-example.lisp
-;;;; Purpose:       Hyper Object Metaclass
+;;;; Name:          hyperobject-example.lisp
+;;;; Purpose:       Hyperobject Example file
 ;;;; Programmer:    Kevin M. Rosenberg
-;;;; Date Started:  Apr 2000
+;;;; Date Started:  Oct 2002
 ;;;;
-;;;; This metaclass as functions to classes to allow display
-;;;; in Text, HTML, and XML formats. This includes hyperlinking
-;;;; capability and sub-objects.
+;;;; A simple example file for hyperobjects
 ;;;;
-;;;; $Id: example.lisp,v 1.1 2002/11/22 10:49:24 kevin Exp $
+;;;; $Id: example.lisp,v 1.6 2002/11/24 17:47:50 kevin Exp $
 ;;;;
 ;;;; This file is Copyright (c) 2000-2002 by Kevin M. Rosenberg
 ;;;;
  
 (in-package :hyperobject-user)
 
-(define-hyperobject person ()
-  ((first-name :type string :reference find-person-by-last-name)
-   (last-name :type string)
-   (dob :type integer :initform 0 :format-func format-date)
-   (resume :type cdata)
-   (addresses :subobject t))
+
+(defclass person (hyperobject)
+  ((first-name :type string :initarg :first-name :reader first-name)
+   (last-name :type string :initarg :last-name :reader last-name
+             :reference find-person-by-last-name)
+   (dob :type integer :initarg :dob :reader dob :print-formatter format-date)
+   (resume :type cdata :initarg :resume :reader resume)
+   (addresses :initarg :addresses :reader addresses :subobject t))
+  (:metaclass hyperobject-class)
+  (:default-initargs :first-name nil :last-name nil :dob 0 :resume nil) 
+  (:print-slots first-name last-name dob resume)
   (:title "Person")
-  (:documentation "Person hyperobject class"))
+  (:description "A Person"))
 
 (defun format-date (ut)
   (when (typep ut 'integer)
                year
                hr min sec))))
 
-(define-hyperobject address ()
-  ((title :type string)
-   (street :type string)
-   (phones :subobject t))
+(defclass address (hyperobject)
+  ((title :type string :initarg :title :reader title)
+   (street :type string :initarg :street :reader street)
+   (phones :initarg :phones :reader phones :subobject t))
+  (:metaclass hyperobject-class)
+  (:default-initargs :title nil :street nil) 
   (:title "Address")
-  (:documentation "Address hyperobject"))
+  (:print-slots title street)
+  (:description "An address"))
 
-(define-hyperobject phone ()
-  ((phone-number :type string))
+(defclass phone (hyperobject)
+  ((title :type string :initarg :title :reader title)
+   (phone-number :type string :initarg :phone-number :reader phone-number))
+  (:metaclass hyperobject-class)
   (:title "Phone Number")
-  (:documentation "Phone hyperobject"))
+  (:default-initargs :title nil :phone-number nil)
+  (:print-slots title phone-number)
+  (:description "A phone number"))
 
 
-(defparameter home-phone-1 (make-instance 'phone :phone-number "367-9812"))
-(defparameter home-phone-2 (make-instance 'phone :phone-number "367-9813"))
+(defparameter home-phone-1 (make-instance 'phone :title "Voice" :phone-number "367-9812"))
+(defparameter home-phone-2 (make-instance 'phone :title "Fax" :phone-number "367-9813"))
 
-(defparameter office-phone-1 (make-instance 'phone :phone-number "123-0001"))
-(defparameter office-phone-2 (make-instance 'phone :phone-number "123-0002"))
-(defparameter office-phone-3 (make-instance 'phone :phone-number "123-0005"))
+(defparameter office-phone-1 (make-instance 'phone :title "Main line" :phone-number "123-0001"))
+(defparameter office-phone-2 (make-instance 'phone :title "Staff line" :phone-number "123-0002"))
+(defparameter office-phone-3 (make-instance 'phone :title "Fax" :phone-number "123-0005"))
 
 (defparameter home (make-instance 'address :title "Home" :street "321 Shady Lane"
                                  :phones (list home-phone-1 home-phone-2)))