[Pharo-project] Why we have Behavior >> flushCache?

Stéphane Ducasse stephane.ducasse at inria.fr
Tue Apr 26 12:51:59 CEST 2011


what is the cache flushed?
I think that your point is valid and it would be good to do it.

Stef

On Apr 26, 2011, at 12:34 PM, Mariano Martinez Peck wrote:

> Hi. As far as I can see,
> 
> Behavior >> flushCache
>     "Tell the interpreter to remove the contents of its method lookup cache, if it has 
>     one.  Essential.  See Object documentation whatIsAPrimitive."
> 
>     <primitive: 89>
>     self primitiveFailed
> 
> 
> And primitive 89 does nothing in particular with the receiver (the class in this case). In both, InterpreterVM and Cog, the WHOLE cache is flushed, there is NOTHING related to the receiver class. Of course, that's at least what it looks for me (please tell me if I am wrong).
> So...if this is the case, wouldn't make sense to move it elsewhere?  like Smalltalk flushCache or Smalltalk vm flushCache  (and it is a good moment to reify the VM). So after we can do: Smalltalk vm version. Smalltlak vm flushCache, Smalltalk vm parameterAt:  , etc....
> 
> If you don't like doing "Smalltalk vm" then we can create a VM class with all class methods, or a singleton and use #current or a singleton and put it in Smalltalk globals...etc
> 
> We will need to fix a couple of senders, thus.
> 
> What do you think?  For me is really confusing, and you don't understand it until you see the primitive implementation. 
> 
> Cheers
> 
> -- 
> Mariano
> http://marianopeck.wordpress.com
> 




More information about the Pharo-project mailing list