<br><br><div class="gmail_quote">On Tue, May 21, 2013 at 2:55 PM, Frank Shearar <span dir="ltr">&lt;<a href="mailto:frank.shearar@gmail.com" target="_blank">frank.shearar@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">
<div class="HOEnZb"><div class="h5">On 21 May 2013 22:54, Eliot Miranda &lt;<a href="mailto:eliot.miranda@gmail.com">eliot.miranda@gmail.com</a>&gt; wrote:<br>
&gt;<br>
&gt;<br>
&gt; On Tue, May 21, 2013 at 2:53 PM, Eliot Miranda &lt;<a href="mailto:eliot.miranda@gmail.com">eliot.miranda@gmail.com</a>&gt;<br>
&gt; wrote:<br>
&gt;&gt;<br>
&gt;&gt;<br>
&gt;&gt;<br>
&gt;&gt; On Tue, May 21, 2013 at 2:40 PM, Frank Shearar &lt;<a href="mailto:frank.shearar@gmail.com">frank.shearar@gmail.com</a>&gt;<br>
&gt;&gt; wrote:<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; allMethodsSelect: aBlock localTo: aClass<br>
&gt;&gt;&gt;     &quot;Answer a SortedCollection of each methodr in, above, or below the<br>
&gt;&gt;&gt; given<br>
&gt;&gt;&gt;     class that, when used as the argument to aBlock, gives a true<br>
&gt;&gt;&gt; result.&quot;<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt;     | aSet |<br>
&gt;&gt;&gt;     aSet := Set new.<br>
&gt;&gt;&gt;     Cursor wait showWhile:<br>
&gt;&gt;&gt;         [aClass theNonMetaClass withAllSuperAndSubclassesDoGently:<br>
&gt;&gt;&gt;             [:class |<br>
&gt;&gt;&gt;                 class selectorsAndMethodsDo:<br>
&gt;&gt;&gt;                     [:aSelector :aMethod|<br>
&gt;&gt;&gt;                         (aBlock value: aMethod) ifTrue:<br>
&gt;&gt;&gt;                             [aSet add: (MethodReference new<br>
&gt;&gt;&gt; setStandardClass: class methodSymbol: aSelector)]]].<br>
&gt;&gt;&gt;         aClass theNonMetaClass class withAllSuperAndSubclassesDoGently:<br>
&gt;&gt;&gt;             [:class |<br>
&gt;&gt;&gt;                 class selectorsAndMethodsDo:<br>
&gt;&gt;&gt;                     [:aSelector :aMethod|<br>
&gt;&gt;&gt;                         (aBlock value: aMethod) ifTrue:<br>
&gt;&gt;&gt;                             [aSet add: (MethodReference new<br>
&gt;&gt;&gt; setStandardClass: class methodSymbol: aSelector)]]]].<br>
&gt;&gt;&gt;     ^aSet<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; Um. That is just an accidental duplication of the aClass<br>
&gt;&gt;&gt; theNonMetaClass class withAllSuperAndSubclassesDoGently: block, right?<br>
&gt;&gt;<br>
&gt;&gt;<br>
&gt;&gt; No, it&#39;s not :)  It&#39;s preserving existing behavior, which is to search<br>
&gt;&gt; class and instance side.  Note that<br>
&gt;&gt;<br>
&gt;&gt;  aClass theNonMetaClass withAllSuperAndSubclassesDoGently:<br>
&gt;&gt;     [:class|<br>
&gt;&gt;     {class. class class} do: aBlock<br>
&gt;&gt;<br>
&gt;&gt; is not equivalent to<br>
&gt;&gt;<br>
&gt;&gt;     aClass theNonMetaClass withAllSuperAndSubclassesDoGently: aBlock<br>
&gt;&gt;     aClass theNonMetaClass class withAllSuperAndSubclassesDoGently: aBlock<br>
&gt;&gt;<br>
&gt;&gt; because the latter searches Behavior, ClassDescription, Class etc, while<br>
&gt;&gt; the former doesn&#39;t.<br>
&gt;<br>
&gt;<br>
&gt; and just to be clear, I&#39;m not claiming one way is better or not.<br></div></div></blockquote><div><br></div><div>and writing it putting the block in a variable (as you did with another method last week, the future: one IIRC) makes the intention far clearer.</div>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="HOEnZb"><div class="h5">
<br>
</div></div>Ah! I had missed that single token!<br>
<span class="HOEnZb"><font color="#888888"><br>
frank<br>
<br>
&gt; --<br>
&gt; best,<br>
&gt; Eliot<br>
&gt;<br>
&gt;<br>
&gt;<br>
<br>
</font></span></blockquote></div><br><br clear="all"><div><br></div>-- <br>best,<div>Eliot</div>