[WIP] Add isoneto
trait and use in similar
#57981
Draft
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This implements the suggestion in #41946 (comment), which makes it possible for range wrappers to opt into the methods for
OneTo
axes. In particular, this targetssimilar
, which means that any axis type that opts in to theOneTo
-like behavior would avoid hitting methods fromOffsetArray
s. In particular, avoiding piracy has been a requested feature inOffsetArrays
for a while (e.g. JuliaArrays/OffsetArrays.jl#306), and this allows individual types to circumvent the issue.An example of usage:
With this, on master, we obtain
This is because
similar
considers aOneToWrapper
to be an offset axis. In particular, withOffsetArrays
loaded, we obtainHowever, if we further define
we obtain
Now this method is handled by
Base
, as theOneToWrapper
behaves like aOneTo
. This is now unaffected byOffsetArrays
being loaded.Closes #41946.