From adc3c07b73c1260e030dc981f2f1f990ee81dd98 Mon Sep 17 00:00:00 2001 From: Rob Norris Date: Fri, 16 Aug 2024 10:31:31 -0500 Subject: [PATCH] preserve internal error --- modules/core/src/main/scala/result.scala | 6 ++++++ modules/sql/shared/src/main/scala/SqlMapping.scala | 8 +++++++- 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/modules/core/src/main/scala/result.scala b/modules/core/src/main/scala/result.scala index 9c07414b..80c0bf5d 100644 --- a/modules/core/src/main/scala/result.scala +++ b/modules/core/src/main/scala/result.scala @@ -145,6 +145,12 @@ sealed trait Result[+T] { case _ => false } + def isFailure: Boolean = + this match { + case Result.Failure(_) => true + case _ => false + } + def hasProblems: Boolean = this match { case Result.Warning(_, _) => true diff --git a/modules/sql/shared/src/main/scala/SqlMapping.scala b/modules/sql/shared/src/main/scala/SqlMapping.scala index 99b75c64..ccb2b909 100644 --- a/modules/sql/shared/src/main/scala/SqlMapping.scala +++ b/modules/sql/shared/src/main/scala/SqlMapping.scala @@ -3557,7 +3557,13 @@ trait SqlMappingLike[F[_]] extends CirceMappingLike[F] with SqlModule[F] { self Result.failure(s"No field '$fieldName' for type ${context.tpe}") } - localField orElse mkCursorForField(this, fieldName, resultName) + // Fall back to the general implementation if it's a logic failure, + // but retain success and internal errors. + if (localField.isFailure) + mkCursorForField(this, fieldName, resultName) + else + localField + } }