From d75186ab79ed55b1653f423d05a5ab14a91567f4 Mon Sep 17 00:00:00 2001 From: Daniel Urban Date: Sat, 24 Sep 2016 21:22:13 +0200 Subject: [PATCH 1/2] Add Order instance for scala.Symbol --- AUTHORS.md | 1 + .../test/scala/cats/kernel/laws/LawTests.scala | 7 +++++++ .../main/scala/cats/kernel/instances/all.scala | 1 + .../main/scala/cats/kernel/instances/symbol.scala | 15 +++++++++++++++ 4 files changed, 24 insertions(+) create mode 100644 kernel/src/main/scala/cats/kernel/instances/symbol.scala diff --git a/AUTHORS.md b/AUTHORS.md index 007a7cd218..109bd36572 100644 --- a/AUTHORS.md +++ b/AUTHORS.md @@ -41,6 +41,7 @@ possible: * Csongor Kiss * Dale Wijnand * Daniel Spiewak + * Daniel Urban * Dave Gurnell * Dave Rostron * David Allsopp diff --git a/kernel-laws/src/test/scala/cats/kernel/laws/LawTests.scala b/kernel-laws/src/test/scala/cats/kernel/laws/LawTests.scala index 7f0ce51018..9b8b014cb3 100644 --- a/kernel-laws/src/test/scala/cats/kernel/laws/LawTests.scala +++ b/kernel-laws/src/test/scala/cats/kernel/laws/LawTests.scala @@ -30,6 +30,9 @@ class LawTests extends FunSuite with Discipline { implicit val arbitraryBitSet: Arbitrary[BitSet] = Arbitrary(arbitrary[List[Short]].map(ns => BitSet(ns.map(_ & 0xffff): _*))) + implicit val arbitrarySymbol: Arbitrary[Symbol] = + Arbitrary(arbitrary[String].map(s => Symbol(s))) + // this instance is not available in scalacheck 1.13.2. // remove this once a newer version is available. implicit val cogenBigInt: Cogen[BigInt] = @@ -40,6 +43,9 @@ class LawTests extends FunSuite with Discipline { implicit val cogenBigDecimal: Cogen[BigDecimal] = Cogen[Double].contramap(_.toDouble) + implicit val cogenSymbol: Cogen[Symbol] = + Cogen[String].contramap(_.name) + { // needed for Cogen[Map[...]] implicit val ohe: Ordering[HasEq[Int]] = Ordering[Int].on(_.a) @@ -64,6 +70,7 @@ class LawTests extends FunSuite with Discipline { laws[OrderLaws, Unit].check(_.order) laws[OrderLaws, Boolean].check(_.order) laws[OrderLaws, String].check(_.order) + laws[OrderLaws, Symbol].check(_.order) laws[OrderLaws, Byte].check(_.order) laws[OrderLaws, Short].check(_.order) laws[OrderLaws, Char].check(_.order) diff --git a/kernel/src/main/scala/cats/kernel/instances/all.scala b/kernel/src/main/scala/cats/kernel/instances/all.scala index 8ca6d5348d..98c0dc6399 100644 --- a/kernel/src/main/scala/cats/kernel/instances/all.scala +++ b/kernel/src/main/scala/cats/kernel/instances/all.scala @@ -22,6 +22,7 @@ trait AllInstances with ShortInstances with StreamInstances with StringInstances + with SymbolInstances with TupleInstances with UnitInstances with VectorInstances diff --git a/kernel/src/main/scala/cats/kernel/instances/symbol.scala b/kernel/src/main/scala/cats/kernel/instances/symbol.scala new file mode 100644 index 0000000000..91eca71052 --- /dev/null +++ b/kernel/src/main/scala/cats/kernel/instances/symbol.scala @@ -0,0 +1,15 @@ +package cats.kernel +package instances + +package object symbol extends SymbolInstances + +trait SymbolInstances { + implicit val catsKernelStdOrderForSymbol: Order[Symbol] = new SymbolOrder +} + +class SymbolOrder extends Order[Symbol] { + override def eqv(x: Symbol, y: Symbol): Boolean = + x eq y + def compare(x: Symbol, y: Symbol): Int = + if (x eq y) 0 else x.name compareTo y.name +} From 318e456f73e4751888441d38a8580b493e8724b4 Mon Sep 17 00:00:00 2001 From: Daniel Urban Date: Wed, 28 Sep 2016 19:36:42 +0200 Subject: [PATCH 2/2] Add comment that Symbols are interned --- kernel/src/main/scala/cats/kernel/instances/symbol.scala | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/kernel/src/main/scala/cats/kernel/instances/symbol.scala b/kernel/src/main/scala/cats/kernel/instances/symbol.scala index 91eca71052..b1261ba875 100644 --- a/kernel/src/main/scala/cats/kernel/instances/symbol.scala +++ b/kernel/src/main/scala/cats/kernel/instances/symbol.scala @@ -8,8 +8,12 @@ trait SymbolInstances { } class SymbolOrder extends Order[Symbol] { - override def eqv(x: Symbol, y: Symbol): Boolean = + + override def eqv(x: Symbol, y: Symbol): Boolean = { + // Symbols are interned x eq y + } + def compare(x: Symbol, y: Symbol): Int = if (x eq y) 0 else x.name compareTo y.name }