<br><br><div class="gmail_quote">On Tue, Apr 26, 2011 at 6:59 PM, Eliot Miranda <span dir="ltr">&lt;<a href="mailto:eliot.miranda@gmail.com" target="_blank">eliot.miranda@gmail.com</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">

Mariano,<div><br></div><div>    the point is that it is classes that manage adding methods to classes and hence it is their private behavior to flush the VM&#39;s method cache.  </div></blockquote><div><br>Ok...I agree, but still it is misleading when we are talking about &quot;method cache&quot;. Because methods are in classes...so I promise everybody that didn&#39;t know and you ask what Behavior &gt;&gt; flushCache does, and everybody will say that it flushed the cache of the methods of that class, not the whole cache. I can understand CompiledMethod &gt;&gt; flushCache and even Symbol &gt;&gt; flushCache ... but this one looks really strange. <br>

 </div><blockquote class="gmail_quote" style="margin:0pt 0pt 0pt 0.8ex;border-left:1px solid rgb(204, 204, 204);padding-left:1ex"><div>You&#39;ll see &quot;self flushCache&quot; in Smalltalk-80 v2 images. </div></blockquote>
<div><br>that makes more sense indeed<br> </div><blockquote class="gmail_quote" style="margin: 0pt 0pt 0pt 0.8ex; border-left: 1px solid rgb(204, 204, 204); padding-left: 1ex;"><div> Now of course the VM provides selective cache flushing but back in the day adding or removing a method implied flushing the whole cache.  Personally I don&#39;t see that this justifies adding Smalltalk vm yet.  I would wait until you have a few more use cases.</div>
</blockquote><div><br>Sorry but in this case, I disagree. I think the opposite: it is the perfect moment to reify the VM in the image and start using it. Why?  exactly because right now we have few uses and it is really easy to migrate. In fact, for Behavior &gt;&gt; flushCache there are only 3 senders.  And I don&#39;t pretend to remove them right now, but with the normal deprecation policy. This is, in Pharo 1.3 we let the messages like Behavior &gt;&gt; flushCache,  SmalltalkImage &gt;&gt; vmVersion, etc. But we let them as deprecated explaining that now they should use XXX. And of course, inside the image we do fix the senders.<br>
<br>In fact, in Pharo 1.3, the method SmalltalkImage &gt;&gt; vm<br>    &quot;Answer the object to query about virtual machine.&quot;<br>    <br>    ^self<br><br>already exists :)<br><br>I see the following possible behavior for VM right now (I mean, the following methods are already in SmalltalkImage):<br>
<br>- #flushCache <br>- #buildDate<br>- #interpreterSourceVersion<br>- #platformSourceVersion<br>- #versionLabel<br>- #extraVMMemory<br>- #extraVMMemory:<br>- #gcBiasToGrow:<br>- #gcBiasToGrowLimit:<br>- #getVMParameters<br>
- #primitiveGCBiasToGrow:<br>- #vmParameterAt:<br>-#vmParameterAt:put:<br>- #reportCPUandRAM<br>- #vmStatisticsReportString<br>- #vmStatisticsShortString<br><br>So....I think they are enough. And the sooner we do this, the easier it would be to reify the VM in the image. <br>
<br>Cheers<br><br>Mariano <br><br><br></div><blockquote class="gmail_quote" style="margin: 0pt 0pt 0pt 0.8ex; border-left: 1px solid rgb(204, 204, 204); padding-left: 1ex;"><div><div>
<div></div><div><br>
<br><div class="gmail_quote">On Tue, Apr 26, 2011 at 3:34 AM, Mariano Martinez Peck <span dir="ltr">&lt;<a href="mailto:marianopeck@gmail.com" target="_blank">marianopeck@gmail.com</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">


Hi. As far as I can see,<br><br>Behavior &gt;&gt; flushCache<br>    &quot;Tell the interpreter to remove the contents of its method lookup cache, if it has <br>    one.  Essential.  See Object documentation whatIsAPrimitive.&quot;<br>



<br>    &lt;primitive: 89&gt;<br>    self primitiveFailed<br clear="all"><br><br>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&#39;s at least what it looks for me (please tell me if I am wrong).<br>



So...if this is the case, wouldn&#39;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....<br>



<br>If you don&#39;t like doing &quot;Smalltalk vm&quot; 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<br><br>We will need to fix a couple of senders, thus.<br>



<br>What do you think?  For me is really confusing, and you don&#39;t understand it until you see the primitive implementation. <br><br>Cheers<br><font color="#888888"><br>-- <br>Mariano<br><a href="http://marianopeck.wordpress.com" target="_blank">http://marianopeck.wordpress.com</a><br>



<br>
</font></blockquote></div><br></div></div></div>
</blockquote></div><br><br clear="all"><br>-- <br>Mariano<br><a href="http://marianopeck.wordpress.com" target="_blank">http://marianopeck.wordpress.com</a><br><br>