Don't use deduplicated predecessors in mapper-created duplication check #589
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.
DirectPredecessorsGetter
returns a deduplicated set of predecessors, which causes problems with the "mapper-created duplication" check inTransformMapper
. Example: Suppose anIndexLambda
has two bindings that are duplicates of each other. When applying a mapper that deduplicates the DAG, such asCopyMapper
, the recursion will deduplicate these two arrays, which means that a newIndexLambda
must be created. This should not trigger the mapper-created duplicate error, because it should see that one of the predecessors has changed. However becauseDirectPredecessorsGetter
deduplicates internally (by virtue of returning aFrozenOrderedSet
), it will report that theIndexLambda
has only one predecessor. Subsequently, the duplication check won't see that a predecessor has changed, and it will trigger the error.This change adds a
ListOfDirectPredecessorsGetter
that returns a list instead of a set and uses that to implement the duplication check.