Subject: Re: CLOS macros: `with-slots' vs `with-accessors'
From: Erik Naggum <erik@naggum.no>
Date: 1998/12/25
Newsgroups: comp.lang.lisp
Message-ID: <3123578561990030@naggum.no>

* David Bakhash <cadet@bu.edu>
| In CLOS programming, I find a lot to be redundant.  For example, the
| `with-slots' and `with-accessors' are redundant if you consider that slot
| accessors always pertain to slots.  Unless I'm mistaken, accessors
| pertain directly to slots, so why would one want to use `with-accessors'?
| There's always gonna be a slot that can give you the right value.  Are
| there speed issues?

  WITH-ACCESSORS lets you name the variables that refer to slots by using
  the published interface.  WITH-SLOTS defaults to using the name of the
  slots, although you may name them otherwise at will, so you will use
  information internal to the class definition.  you use them in the same
  circumstances that you would use the accessor or the slot, respectively.

  I use WITH-ACCESSORS in code that should not know about the class
  internals, and WITH-SLOTS in code that depends on it, anyway, such as
  PRINT-OBJECT or SLOT-UNBOUND methods and other such obvious internals.

  BTW, note that an accessor method need not refer directly to a slot, so
  your assumption does not hold.  an accessor can compute the value from
  other slots.  it could also have been a slot once, now superseded by
  changes to the class, but you would want to make such changes as painless
  as possible by keeping backward compatibility with the published
  interface and either compute a new value or provide a default value or
  whatever.

  hm.  reading your article over, it seems that you think that an accessor
  is a special kind of method that accesses slots.  while true in the
  special (although most usual) case, an accessor is better viewed as a
  method on the class that returns the value of a slot, by _default_, but
  any method on the class that returns a value that relates _directly_ to
  the state of the object (that is, the value would not change until the
  state of the object changed), may properly be termed an accessor.  it
  would also be a reasonable requirement if an accessor returned whatever
  value it was set to by the last (setf <accessor>).  it would make sense
  to refer to an accessor as a "reader" ("getter") or "writer" ("setter")
  if it didn't support this symmetry.  again, however, such a function need
  not refer to _slots_ per se, only directly to the state of the object.
  an example (I've seen this somewhere, but forget the source) might be a
  class of colored objects, and an accessor SAME-COLOR-P, which returned
  NIL if the colors were different, and the color if they were the same.
  it would make sense to make this method setf'able, to set the color of
  all the objects at the same.
  
#:Erik
-- 
  Nie wieder KrF!  Nie wieder KrF!  Nie wieder KrF!  Nie wieder KrF!