When you remove the allocate method from a class the you can't allocate the class via the allocate method. However, you can allocate the class via the new method:
classFoo;endFoo.singleton_class.undef_method(:allocate)beginFoo.allocate# doesn't work, of courserescueNoMethodErrorendbeginClass.instance_method(:allocate).bind_call(Foo)# also doesn't workrescueTypeErrorendFoo.new# works?
I think that when we remove the allocate method, the new method should also fail as there is no allocate method for new to call.
The current behavior may be what you want if you want to ensure that new instances of the class have #initialize called on them. I suppose you could switch to making allocate private, but that still would allow for send(:allocate).
If we disallow .new if .allocate is undefined, should we also disallow #dup and #clone, both of which also need to allocate an object?
The current behavior may be what you want if you want to ensure that new instances of the class have #initialize called on them. I suppose you could switch to making allocate private, but that still would allow for send(:allocate).
If we disallow .new if .allocate is undefined, should we also disallow #dup and #clone, both of which also need to allocate an object?
I think that makes sense. For example if you wanted to ensure a particular instance is a singleton:
classFoo;endsingleton=Foo.newFoo.singleton_class.undef_method(:allocate)# now there can only be one instance of `Foo` as new / allocate / dup / clone will raise
May I ask what is the use case for this?
The only reason I can think to undefine allocate is if you want to allow only a single instance of the class, and in that case include Singleton should do the job fine I think.