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) 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]