From 377152e497e3dac6a950783783ec37f852fa8350 Mon Sep 17 00:00:00 2001 From: Yilin Wei Date: Fri, 19 May 2017 14:21:44 +0100 Subject: [PATCH 1/2] Fix issue --- core/src/main/scala/cats/Reducible.scala | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/core/src/main/scala/cats/Reducible.scala b/core/src/main/scala/cats/Reducible.scala index 76ab5d4ca5..91e8d1e4b6 100644 --- a/core/src/main/scala/cats/Reducible.scala +++ b/core/src/main/scala/cats/Reducible.scala @@ -227,7 +227,7 @@ abstract class NonEmptyReducible[F[_], G[_]](implicit G: Foldable[G]) extends Re } override def get[A](fa: F[A])(idx: Long): Option[A] = - if (idx == 0L) Some(split(fa)._1) else G.get(split(fa)._2)(idx) + if (idx == 0L) Some(split(fa)._1) else G.get(split(fa)._2)(idx - 1L) override def fold[A](fa: F[A])(implicit A: Monoid[A]): A = { val (a, ga) = split(fa) From bb9f8c9ac8d84cebb26bb8efd8d84f5780517f28 Mon Sep 17 00:00:00 2001 From: Yilin Wei Date: Fri, 26 May 2017 16:37:42 +0100 Subject: [PATCH 2/2] Adding test for Reducible default get/size implementation --- tests/src/test/scala/cats/tests/ReducibleTests.scala | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/tests/src/test/scala/cats/tests/ReducibleTests.scala b/tests/src/test/scala/cats/tests/ReducibleTests.scala index f670f12291..4331b09c41 100644 --- a/tests/src/test/scala/cats/tests/ReducibleTests.scala +++ b/tests/src/test/scala/cats/tests/ReducibleTests.scala @@ -23,6 +23,15 @@ class ReducibleTestsAdditional extends CatsSuite { if (a === goal) Now(true) else lb } + test("Reducible[NonEmptyList] default get/size implementation") { + val R = new NonEmptyReducible[NonEmptyList, List] { + def split[A](nel: NonEmptyList[A]): (A, List[A]) = (nel.head, nel.tail) + } + val nel = NonEmptyList.of(1, 2, 3) + R.get(nel)(1L) should === (nel.get(1L)) + R.size(nel) should === (nel.size.toLong) + R.get(nel)(4L) should === (None) + } test("Reducible[NonEmptyList]") { val R = Reducible[NonEmptyList]