From 44384ac5e7142c39a485abd9e19e963bbeec598b Mon Sep 17 00:00:00 2001 From: Ondra Pelech Date: Sun, 9 Jun 2024 22:59:12 +0200 Subject: [PATCH] YamlDecoder: mapError and flatMap --- .../scala/org/virtuslab/yaml/YamlCodec.scala | 2 +- .../org/virtuslab/yaml/YamlDecoder.scala | 27 +++++++++++++------ 2 files changed, 20 insertions(+), 9 deletions(-) diff --git a/core/shared/src/main/scala/org/virtuslab/yaml/YamlCodec.scala b/core/shared/src/main/scala/org/virtuslab/yaml/YamlCodec.scala index 8b9dfc81c..55448c03e 100644 --- a/core/shared/src/main/scala/org/virtuslab/yaml/YamlCodec.scala +++ b/core/shared/src/main/scala/org/virtuslab/yaml/YamlCodec.scala @@ -9,7 +9,7 @@ trait YamlCodec[T] extends YamlDecoder[T] with YamlEncoder[T] { self => YamlCodec.make(self.map(f), self.mapContra(g)) def mapInvariantError[T1](f: T => Either[ConstructError, T1])(g: T1 => T): YamlCodec[T1] = - YamlCodec.make(self.flatMap(f), self.mapContra(g)) + YamlCodec.make(self.mapError(f), self.mapContra(g)) } object YamlCodec extends YamlCodecCompanionCrossCompat { diff --git a/core/shared/src/main/scala/org/virtuslab/yaml/YamlDecoder.scala b/core/shared/src/main/scala/org/virtuslab/yaml/YamlDecoder.scala index cee777e8d..8da84dda0 100644 --- a/core/shared/src/main/scala/org/virtuslab/yaml/YamlDecoder.scala +++ b/core/shared/src/main/scala/org/virtuslab/yaml/YamlDecoder.scala @@ -33,11 +33,22 @@ trait YamlDecoder[T] { self => self.construct(node).map(f) } - final def flatMap[T1](f: T => Either[ConstructError, T1]): YamlDecoder[T1] = new YamlDecoder[T1] { + final def mapError[T1](f: T => Either[ConstructError, T1]): YamlDecoder[T1] = + new YamlDecoder[T1] { + override def construct(node: Node)(implicit + settings: LoadSettings + ): Either[ConstructError, T1] = + self.construct(node).flatMap(f) + } + + final def flatMap[T1](f: T => YamlDecoder[T1]): YamlDecoder[T1] = new YamlDecoder[T1] { override def construct(node: Node)(implicit settings: LoadSettings ): Either[ConstructError, T1] = - self.construct(node).flatMap(f) + self.construct(node) match { + case Right(result) => f(result).construct(node) + case l @ Left(_) => l.asInstanceOf[Left[ConstructError, Nothing]] + } } } @@ -125,16 +136,16 @@ object YamlDecoder extends YamlDecoderCompanionCrossCompat { case node @ ScalarNode(_, Tag.int) => forByte .widen[Any] - .orElse(forShort.widen[Any]) - .orElse(forInt.widen[Any]) - .orElse(forLong.widen[Any]) - .orElse(forBigInt.widen[Any]) + .orElse(forShort.widen) + .orElse(forInt.widen) + .orElse(forLong.widen) + .orElse(forBigInt.widen) .construct(node) case node @ ScalarNode(_, Tag.float) => forFloat .widen[Any] - .orElse(forDouble.widen[Any]) - .orElse(forBigDecimal.widen[Any]) + .orElse(forDouble.widen) + .orElse(forBigDecimal.widen) .construct(node) case ScalarNode(value, Tag.str) => Right(value)