| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
10.8 Introspection
Bigloo provides the programmer with some object introspection facilities.
See section see section Object library for information on classes and
objects handling. Introspection facilities are, by default, available
for all classes. However, in order to shrink the code size generation,
it may be useful to disable class introspection. This decision can be
taken on a per class basis (i.e., one class may be provided with
introspection facilities while another one is not). The compiler
option -fno-reflection 
(see Chapter Compiler description) prevents the
compiler to generate the code required for introspecting the classes
defined in the compiled module.
- bigloo procedure: class-fields class
- Returns the a description of the fields of class. This description is a list of field descriptions where each field description can be accessed by the means of the following library functions. The fields are those directly defined in class. That is - class-fieldsdoes not return fields defined in super classes of class.
- bigloo procedure: class-all-fields class
- Returns the a description of the fields of class. This description is a list of field descriptions where each field description can be accessed by the means of the following library functions. By contrast with - class-fields, this function returns fields that are also defined in the super classes of class. in th
- bigloo procedure: find-class-field class symbol
- Returns the field named symbol from class class. Returns - #fis such a field does not exist.
- bigloo procedure: class-field? obj
- Returns #t if obj is a class field descriptor. Otherwise returns #f. 
- bigloo procedure: class-field-indexed? field
- Returns - #tif the described field is indexed and- #fotherwise.
- bigloo procedure: class-field-accessor field
- Returns a procedure of one argument. Applying this function to an object returns the value of the field described by field. 
- bigloo procedure: class-field-len-accessor field
- A one argument function is returned. Applying this function to an object returns the length value of the field described by field. It is an error to apply - class-field-len-accessorto a non-indexed field.
- bigloo procedure: class-field-mutable? field
- Returns - #tif the described field is mutable and- #fotherwise.
- bigloo procedure: class-field-mutator field
- Returns a procedure of three, or two, arguments depending on whether the field is indexed or not. Applying this function to an object changes the value of the field described by field. It is an error to apply - class-field-mutatorto an immutable field.
- bigloo procedure: class-field-info field
- Returns the information associated to field (this the class declaration - infoattribute).
For means of an example, here is a possible implementation of the
equal? test for objects:
(define (object-equal? obj1 obj2)
   (define (class-field-equal? fd)
      (let ((get-value (class-field-accessor fd)))
         (if (not (class-field-indexed? fd))
             (equal? (get-value obj1)
                     (get-value obj2))
             (let* ((len (class-field-len-accessor
                          fd)))
                    (len1 (len obj1))
                    (len2 (len obj2)))
                (and (=fx len1 len2)
                     (let loop ((i 0))
                        (cond
                           ((=fx i len1)
                            #t)
                           ((equal?
                             (get-value obj1 i)
                             (get-value obj2 i))
                            (loop (+fx i 1)))
                           (else
                            #f))))))))
   (let ((class1 (object-class obj1))
         (class2 (object-class obj2)))
      (cond
         ((not (eq? class1 class2))
          #f)
         (else
          (let loop ((fields (class-fields class1))
                     (class  class1))
             (cond
                ((null? fields)
                 (let ((super (class-super class)))
                    (if (class? super)
                        (loop (class-fields super)
                              super)
                        #t)))
                ((class-field-equal? (car fields))
                 (loop (cdr fields) class))
                (else
                 #f)))))))
- bigloo procedure: class-creator class
- Returns the creator for class. The creator is a function for which the arity depends on the number of slots the class provides (see Section see section Creating and accessing objects). - When an instance is allocated by the means of the - class-creator, as for direct instantiation, the class constructor is automatically invoked. Example:- (module foo (main main) (static (class c1 (c1-constructor)))) (define c1-constructor (let ((count 0)) (lambda (inst) (set! count (+ 1 count)) (print "creating instance: " count) inst))) (define (main argv) (let ((o1 (instantiate::c1)) (o2 (instantiate::c1)) (o3 ((class-creator c1)))) 'done)) -| creating instance: 1 creating instance: 2 creating instance: 3- For each indexed field, two values must be sent to the function returned by - class-creator. The first value denotes the size of the indexed field. The second value denotes the initial values of the fields. For instance:- (module example (export (class point x y (* z)))) (let ((create (class-creator point))) (print (create 10 23 5 3))) - Produces -| #|POINT [X: 10] [Y: 23] [Z: 3 3 3 3 3]| 
- bigloo procedure: class-predicate class
- Returns the predicate for class. This predicate returns - #twhen applied to object of type class. It returns- #fotherwise.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] | 
 
  This document was generated on October 23, 2011 using texi2html 5.0.
 
 
