org.scalactic.DefaultEquality.scala Maven / Gradle / Ivy
The newest version!
/* * Copyright 2001-2013 Artima, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.scalactic import org.scalactic.anyvals.NonEmptyArray /** * A default
b if they * are arrays, and using the result or results of invokingEquality
type class implementation (which can be used for any type) whose *areEqual
method compares the passed objects with==
, calling.deep
* first on any passed object that is an array. * */ private[scalactic] final class DefaultEquality[A] extends Equality[A] { /** * Indicates whether the objects passed asa
andb
are equal by invoking==
ona
* passing inb
, treating arrays specially by invoking.deep
ona
and/or.deep
in the equality check. * * @param a a left-hand-side object being compared with another (right-hand-side one) for equality (e.g.,a == b
) * @param b a right-hand-side object being compared with another (left-hand-side one) for equality (e.g.,a == b
) */ def areEqual(a: A, b: Any): Boolean = { DefaultEquality.areEqualComparingArraysStructurally(a, b) } override def toString: String = "Equality.default" } object DefaultEquality { import ArrayHelper.deep private[org] def areEqualComparingArraysStructurally(left: Any, right: Any): Boolean = { // Prior to 2.0 this only called .deep if both sides were arrays. Loosened it // when nearing 2.0.M6 to call .deep if either left or right side is an array. // TODO: this is the same algo as in scalactic.DefaultEquality. Put that one in // a singleton and use it in both places. left match { case leftArray: Array[_] => right match { case rightArray: Array[_] => deep(leftArray) == deep(rightArray) case rightNonEmptyArray: NonEmptyArray[_] => deep(leftArray) == deep(rightNonEmptyArray.toArray) case _ => deep(leftArray) == right } case leftNonEmptyArray: NonEmptyArray[_] => right match { case rightArray: Array[_] => deep(leftNonEmptyArray.toArray) == deep(rightArray) case rightNonEmptyArray: NonEmptyArray[_] => deep(leftNonEmptyArray.toArray) == deep(rightNonEmptyArray.toArray) case _ => deep(leftNonEmptyArray.toArray) == right } case other => { right match { case rightArray: Array[_] => left == deep(rightArray) case rightNonEmptyArray: NonEmptyArray[_] => left == deep(rightNonEmptyArray.toArray) case _ => left == right } } } } }
© 2015 - 2024 Weber Informatics LLC | Privacy Policy