[Xotcl] Mixins in XOTcl

Neil Madden nem at cs.nott.ac.uk
Wed May 19 22:20:23 CEST 2004


On 19 May 2004, at 21:05, Michael Schlenker wrote:
>> Woah there! I said nothing about mutable objects/values.
>
> You talked about adding instance variables which are mutable objects 
> by definition, while Adam talked about mutable objects directly.

What do you mean here? Variables are mutable, yes. They're not 
"objects" though (they're neither XOTcl objects, or even Tcl_Objs 
(values) - I assume they're normal Tcl namespaced variables, but XOTcl 
might implement them differently). I'm proposing a change of interface 
that's all. At present we have a "special" variable (the mixin list) 
which is hidden behind the [$obj mixin] and [$obj info mixin] commands. 
All I am saying is to bring that variable into the limelight to be an 
actual instance variable of the object, and use the usual methods to 
alter it. It's always been mutable, just not in place.

(By "immutable" I would be referring to something like a "final" 
variable in Java - you can assign to it once, but never again.)

>
>> Mutable variables are all that is needed, and they exist already (in 
>> fact, you have to go an extra step to get immutable variables).
>
> Of course, mutability is what variables are all about... ;-)

Not in all languages! C.f. prolog, various rule interpreters etc. Of 
course, that's probably an abuse of the term "variable", but I 
digress... :^)

>
>> The idea is to reuse things like [lappend], [linsert], [lreplace] 
>> etc, without creating lots of [mixin_append], [mixin_replace] etc 
>> etc. That's the duplication of effort.
>
> You can reuse them, correct me if I'm wrong:
>
> set mixins [$obj info mixins]
> # use standard list operations as you like
> set mixins [linsert $mixins 0 $newMixin]
> lappend mixins $anotherMixin
> $obj mixin $mixins
>
> Where is the huge benefit of a magic instance variable containing the 
> list of mixins? I just don't see the benefit, but i see that you would 
> add a magic variable name to objects where none existed before.

Well, you have magic variables now - they're just hidden behind the 
[$obj info mixins]/[$obj mixin]. The difference I was proposing was to 
get rid of these special methods, and replace them with a regular 
instance variable:

$obj lappend mixinlist $somemixin
$obj set mixinlist [linsert [$obj set mixinlist] 0 $newMixin]
etc

Just a trade off between altering the list in the "standard" way using 
the normal variable methods, or via a set of additional mixin-specific 
methods (the mixin_prepend etc that were proposed). Note this has 
nothing to do with mutable values vs accessor methods: the only way you 
can get/set an instance variable is via [$obj set] so it's already 
hidden behind accessor functions (oh, there's the instvar stuff, but 
I've never really looked at that).

Yes, it would add a "magic" variable name, but remove some "magic" 
methods. I was just seeing what appeared to be a proposal to mirror all 
of the variable manipulation commands with special ones to deal with 
mixins, which seemed a bit of a waste.

Cheers,

Neil.




More information about the Xotcl mailing list