In trunk the Enumerable#find method ifnone parameter has to be callable or nil. I found that sometimes I want to return a simple value without wrapping it in a proc. This pull request adds support for non-callable defaults when no items match.
Oh, I didn't realized that this ticket was from github pull reqeust.
Thank you for your importing work!
But, the fact remains that this proposal was not accepted by the 2.0.0 deadline. Sorry.
It is unfortunate that people misunderstands that github pullreq is the right way to request a feature to Ruby.
Is it impossible to stop (or automatically reject) pullreq?
Currently, it is not able to distinguish from the case a hash is given as an ordinal argument.
So there still is a possibility to break a compatibility.
I rather like @ioquatix (Samuel Williams) idea here, and was considering making a similar ticket to suggest that ifnone does not make much sense when compared to other Ruby APIs.
What's the point of the "default value" as compared to just find { ... } || default?
Would it be more performant? (I believe no)
Would it read more naturally? I believe no, the statement reads "find (and if not found, use that) by this condition..."
Would it be readable at all?.. I believe barely, actually find(10) { condition } can be misunderstood as "find, starting from index 10", and something like find(:delete) { condition } can be read as some local DSL for "find&delete". Keyword argument will improve it, of course, but looks unlike any other core API, and still reads "find, else default, by this condition...".
But the question for me is still: why is it necessary at all? what exactly it achieves?