On 02.08.2015 19:02, Peter Uhnák [via Smalltalk] wrote:
>     (a b c) = (b a c) if a = b
>
>     (a b c) < (b a c) if a < b
>     The semantics are well defined.
>
>
> Since you mentioned JavaScript, you should know that you can't compare
> arrays with ==, because it does object comparison.
>
>     No. Sorted collection maintains order of its elements, and I'm talking
>     about order on [the set of] sequencable collections
>
> This will make sense only if the objects have overriden their #=.
> Which also means that it is not very useful to use #<, because you can't
> define order without overriding #=.

Technically, you can:
        (a < b) not and: [ (b < a) not ] "a and b are equal"

But of course it's reasonable to implement #= and #hash along with #< - 
that's what TComparable requires.

> Compare it to sorting a collection, where you can either do #sorted,
> which will do "a <= b" by default, but you can still do #sorted: and
> specify the sort order, dtto with PluggableDictionary etc.
> So if anything, it would make more sense to be able to block-based
> testing (without relying on #<), because more often then not you will
> have your values wrapped in some (bigger) objects.

Something like #compare:using: where second argument is a binary block?
Might be a solution, although not as elegant.
Question is what are return values of the method and what is expected to 
be returned from the block?
String>>#compare: returns integer from 1 to 3; 
SequencableCollection>>#findBinary: expects either 0, negative or 
positive integer; #sorted: expects boolean; #max:, #min:, etc. expect 
object to be compared.

> And finally "Because in almost every programming language..." is not an
> argument.
> You could argue that "1 + 2 * 3" should return "7", because that's how
> every language does it and that's how mathematicians did it for
> thousands of years. And yet Smalltalk happily returns "9" and yet it
> makes sense, and some could argue that it's even better.
>
> Peter
>
> On Sun, Aug 2, 2015 at 4:59 PM, Alexandre Bergel <[hidden email]
> </user/SendEmail.jtp?type=node&node=4840722&i=0>> wrote:
>
>     > I'd say it is questonable if SequenceableCollections should be 
> comparable by default.
>
>     +1
>
>     Alexandre
>     --
>     _,.;:~^~:;._,.;:~^~:;._,.;:~^~:;._,.;:~^~:;._,.;:
>     Alexandre Bergel http://www.bergel.eu
>     ^~:;._,.;:~^~:;._,.;:~^~:;._,.;:~^~:;._,.;:~^~:;.
>
>
>
>
>
>
>
> ------------------------------------------------------------------------
> If you reply to this email, your message will be added to the discussion
> below:
> http://forum.world.st/Comparison-for-SequencableCollection-tp4840704p4840722.html
>
> To unsubscribe from Comparison for SequencableCollection, click here
> <http://forum.world.st/template/NamlServlet.jtp?macro=unsubscribe_by_code&node=4840704&code=cmVnQHdlYndhcnJpb3Iud3N8NDg0MDcwNHwzOTM0MDk5MzI=>.
> NAML
> <http://forum.world.st/template/NamlServlet.jtp?macro=macro_viewer&id=instant_html%21nabble%3Aemail.naml&base=nabble.naml.namespaces.BasicNamespace-nabble.view.web.template.NabbleNamespace-nabble.view.web.template.NodeNamespace&breadcrumbs=notify_subscribers%21nabble%3Aemail.naml-instant_emails%21nabble%3Aemail.naml-send_instant_email%21nabble%3Aemail.naml>
>




--
View this message in context: 
http://forum.world.st/Comparison-for-SequencableCollection-tp4840704p4840723.html
Sent from the Pharo Smalltalk Users mailing list archive at Nabble.com.

Reply via email to