Skip to content

Commit

Permalink
Either: fix getEquivalence parameter order from `Either.getEquivale… (
Browse files Browse the repository at this point in the history
  • Loading branch information
gcanti authored and tim-smart committed Mar 20, 2024
1 parent 789a927 commit cb7bfb2
Show file tree
Hide file tree
Showing 4 changed files with 13 additions and 8 deletions.
5 changes: 5 additions & 0 deletions .changeset/strong-falcons-exercise.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"effect": minor
---

Either: fix `getEquivalence` parameter order from `Either.getEquivalence(left, right)` to `Either.getEquivalence({ left, right })`
12 changes: 6 additions & 6 deletions packages/effect/src/Either.ts
Original file line number Diff line number Diff line change
Expand Up @@ -287,15 +287,15 @@ export const getLeft: <R, L>(self: Either<R, L>) => Option<L> = either.getLeft
* @category equivalence
* @since 2.0.0
*/
export const getEquivalence = <R, L>(
EquivalenceL: Equivalence.Equivalence<L>,
EquivalenceR: Equivalence.Equivalence<R>
): Equivalence.Equivalence<Either<R, L>> =>
export const getEquivalence = <R, L>({ left, right }: {
right: Equivalence.Equivalence<R>
left: Equivalence.Equivalence<L>
}): Equivalence.Equivalence<Either<R, L>> =>
Equivalence.make((x, y) =>
x === y ||
(isLeft(x) ?
isLeft(y) && EquivalenceL(x.left, y.left) :
isRight(y) && EquivalenceR(x.right, y.right))
isLeft(y) && left(x.left, y.left) :
isRight(y) && right(x.right, y.right))
)

/**
Expand Down
2 changes: 1 addition & 1 deletion packages/effect/test/Either.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -177,7 +177,7 @@ describe("Either", () => {
})

it("getEquivalence", () => {
const isEquivalent = Either.getEquivalence(S.Equivalence, N.Equivalence)
const isEquivalent = Either.getEquivalence({ right: N.Equivalence, left: S.Equivalence })
Util.deepStrictEqual(isEquivalent(Either.right(1), Either.right(1)), true)
Util.deepStrictEqual(isEquivalent(Either.right(1), Either.right(2)), false)
Util.deepStrictEqual(isEquivalent(Either.right(1), Either.left("foo")), false)
Expand Down
2 changes: 1 addition & 1 deletion packages/schema/src/Schema.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5157,7 +5157,7 @@ export const eitherFromSelf = <R extends Schema.Any, L extends Schema.Any>({ lef
description: `Either<${format(left)}, ${format(right)}>`,
pretty: eitherPretty,
arbitrary: eitherArbitrary,
equivalence: (right, left) => Either.getEquivalence(left, right)
equivalence: (right, left) => Either.getEquivalence({ left, right })
}
)
}
Expand Down

0 comments on commit cb7bfb2

Please sign in to comment.