Feature #7377
open#indetical? as an alias for #equal?
Added by aef (Alexander E. Fischer) almost 13 years ago. Updated over 1 year ago.
Description
As my feature request #7359 got rejected, here a more backward-compatible approach:
In my opinion the difference between #eql? and #equal? is really unintuitive. How about making their difference more obvious by giving one of them a more accurate name?
My proposal is to alias #equal? to #identical?.
I'll write a patch, if this is acceptable.
        
           Updated by Anonymous almost 13 years ago
          
          
        
        
          
            Actions
          
          #1
            [ruby-core:49617]
          Updated by Anonymous almost 13 years ago
          
          
        
        
          
            Actions
          
          #1
            [ruby-core:49617]
        
      
      +1, due to similar sounding name, these methods confuse beginners (me). #identical? feels much better.
        
           Updated by marcandre (Marc-Andre Lafortune) almost 13 years ago
          
          
        
        
          
            Actions
          
          #2
            [ruby-core:49647]
          Updated by marcandre (Marc-Andre Lafortune) almost 13 years ago
          
          
        
        
          
            Actions
          
          #2
            [ruby-core:49647]
        
      
      identical? can also mean "exactly alike", e.g. identical twins.
For the price of two additional letters, I'd recommend same_object? instead.
        
           Updated by aef (Alexander E. Fischer) almost 13 years ago
          
          
        
        
          
            Actions
          
          #3
          Updated by aef (Alexander E. Fischer) almost 13 years ago
          
          
        
        
          
            Actions
          
          #3
        
      
      #same_object? would also be ok by me.
        
           Updated by trans (Thomas Sawyer) almost 13 years ago
          
          
        
        
          
            Actions
          
          #4
            [ruby-core:49777]
          Updated by trans (Thomas Sawyer) almost 13 years ago
          
          
        
        
          
            Actions
          
          #4
            [ruby-core:49777]
        
      
      =begin
The reason for the word "identical" is b/c of the root "id" which corresponds to the fact that the id's are the same. They would not be identical if the id's were not the same. So yes, "exactly alike" is precise. Only the identical object is exactly like itself. Remember too we are comparing two references, not the objects themselves. We are really asking if reference x is identical to reference y.
Also, the #same_object? seems redundant b/c everything is an object. So if an alternate is to be suggested, I would think it should just be (({#same?})). It would suffice, but does just "same?" really have such a precise meaning?
=end
        
           Updated by marcandre (Marc-Andre Lafortune) almost 13 years ago
          
          
        
        
          
            Actions
          
          #5
            [ruby-core:49795]
          Updated by marcandre (Marc-Andre Lafortune) almost 13 years ago
          
          
        
        
          
            Actions
          
          #5
            [ruby-core:49795]
        
      
      trans (Thomas Sawyer) wrote:
=begin
The reason for the word "identical" is b/c of the root "id" which corresponds to the fact that the id's are the same. They would not be identical if the id's were not the same.
Identical twins are not the same person (i.e. not the same object), and calling SomeActiveRecordModel.first twice will not give you the same object even if they share the same id and values.
Also, the #same_object? seems redundant b/c everything is an object. So if an alternate is to be suggested, I would think it should just be (({#same?})). It would suffice, but does just "same?" really have such a precise meaning?
You clearly have never been to Thaïland ;-)
'object' is not redundant, since one can compare sameness in different ways, by value being the most popular.
See also https://bugs.ruby-lang.org/issues/6367 for another proposed use of same?
        
           Updated by Anonymous almost 13 years ago
          
          
        
        
          
            Actions
          
          #6
            [ruby-core:49802]
          Updated by Anonymous almost 13 years ago
          
          
        
        
          
            Actions
          
          #6
            [ruby-core:49802]
        
      
      Marc, sorry to break it to you, but "identical twins" is misuse of the word identical, something like "dictatorial democracy" :)
        
           Updated by trans (Thomas Sawyer) almost 13 years ago
          
          
        
        
          
            Actions
          
          #7
            [ruby-core:49810]
          Updated by trans (Thomas Sawyer) almost 13 years ago
          
          
        
        
          
            Actions
          
          #7
            [ruby-core:49810]
        
      
      "and calling SomeActiveRecordModel.first twice will not give you the same object even if they share the same id"
That's not the id we mean. In Ruby every object has a unique id.
x = "foo"
x.object_id  #=> 17086140
So to ask x.identical? y is the to ask x.object_id == y.object_id. And that's how it works under the hood. Which is why I think a term the indicates the "id" aspect of this is nicer and really fortunate that we even have available to us. I'm not saying #same_object? is an awful choice. It would still be better than the current confusion. But #identical? gives us a little bit stronger semantics.
        
           Updated by drbrain (Eric Hodel) almost 13 years ago
          
          
        
        
          
            Actions
          
          #8
            [ruby-core:49907]
          Updated by drbrain (Eric Hodel) almost 13 years ago
          
          
        
        
          
            Actions
          
          #8
            [ruby-core:49907]
        
      
      Boris, sorry to break it to you, but "identical" means both "similar in every detail" (so not a misuse as in "identical twins") and also "expressing a [mathematical] identity" according to the Oxford English Dictionary.
If we already have a convention and need to debate the meanings of a proposed new convention it is probably best if we just drop the discussion.
By carrying on with the existing conventions we reduce cognitive load on rubyists. New rubyists learning by themselves don't have to wonder "why can I do this two ways?" and "which way is the recommended way?". People who teach ruby won't need to tell new rubyists "we have two ways to do this because of a long discussion that would distract from the current lesson". Long-time rubyists won't need to wonder "Why was a second way of doing this added? How does it make my life better?"
The pursuit of a perfect language is noble, but there are always going to be rough edges. Invalidating years of working code and years of blog posts and instruction to rearrange a few methods to be more "perfect" is probably not the best use of our time.
        
           Updated by Anonymous almost 13 years ago
          
          
        
        
          
            Actions
          
          #9
            [ruby-core:49958]
          Updated by Anonymous almost 13 years ago
          
          
        
        
          
            Actions
          
          #9
            [ruby-core:49958]
        
      
      Eric, your post could be shortened to 10% without loss of meaning: You give +1 to stability. I give +1 to having a synonym #identical? for #equal?
        
           Updated by mame (Yusuke Endoh) almost 13 years ago
          
          
        
        
          
            Actions
          
          #10
            [ruby-core:49995]
          Updated by mame (Yusuke Endoh) almost 13 years ago
          
          
        
        
          
            Actions
          
          #10
            [ruby-core:49995]
        
      
      - Target version set to 2.6
        
           Updated by trans (Thomas Sawyer) almost 13 years ago
          
          
        
        
          
            Actions
          
          #11
            [ruby-core:50007]
          Updated by trans (Thomas Sawyer) almost 13 years ago
          
          
        
        
          
            Actions
          
          #11
            [ruby-core:50007]
        
      
      This is nothing unusual or difficult about an alias. Ruby has a number of them and it hasn't turned any nuby minds to mush. On the contrary, it really provides a good way for the language to mature naturally. Case in point, early on I used Enumerable#collect, others did as well. But now I only use #map. I've notice almost everyone uses #map now too. #collect is still around, and it probably will never leave us, and despite having two methods for the same thing I don't hear anyone complaining that it should. I for one am thankful we've had the choice (if it were up for debate back in the day I would have voted for #collect and been poorer for it).
The pursuit of a better language is noble, and thus should be pursued. After all, that's why we are all here. Isn't it? There is no invalidation of code and years of blog posts by adding an alias in any case. Besides that, other features of the language have changed much more drastically over the years in pursuit of the better language (the transition for #id to #object_id and the coming deprecation of #autoload come to mind). Asking for a simple alias because it conceptually makes more sense and helps to differentiate the more confusing question of how #equal? differs from #eql? is a feather by comparison --and it's how it makes our life better.
        
           Updated by trans (Thomas Sawyer) almost 13 years ago
          
          
        
        
          
            Actions
          
          #12
            [ruby-core:50009]
          Updated by trans (Thomas Sawyer) almost 13 years ago
          
          
        
        
          
            Actions
          
          #12
            [ruby-core:50009]
        
      
      @boris
You give +1 to stability. I give +1 to having a synonym #identical? for #equal?
Nothing to do with stability. A bit more like +1 to defeatism.
        
           Updated by naruse (Yui NARUSE) almost 8 years ago
          
          
        
        
          
            Actions
          
          #13
          Updated by naruse (Yui NARUSE) almost 8 years ago
          
          
        
        
          
            Actions
          
          #13
        
      
      - Target version deleted (2.6)
        
           Updated by hsbt (Hiroshi SHIBATA) over 1 year ago
          
          
        
        
          
            Actions
          
          #14
          Updated by hsbt (Hiroshi SHIBATA) over 1 year ago
          
          
        
        
          
            Actions
          
          #14
        
      
      - Status changed from Open to Assigned