1 /*
2  *  Make.org Core API
3  *  Copyright (C) 2020 Make.org
4  *
5  * This program is free software: you can redistribute it and/or modify
6  *  it under the terms of the GNU Affero General Public License as
7  *  published by the Free Software Foundation, either version 3 of the
8  *  License, or (at your option) any later version.
9  *
10  *  This program is distributed in the hope that it will be useful,
11  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
12  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  *  GNU Affero General Public License for more details.
14  *
15  *  You should have received a copy of the GNU Affero General Public License
16  *  along with this program.  If not, see <https://www.gnu.org/licenses/>.
17  *
18  */
19 
20 package org.make.core.technical.enumeratum
21 
22 import enumeratum.values.{StringEnumEntry, ValueEnum, ValueEnumEntry}
23 import io.circe.{Decoder, Encoder}
24 
25 trait FallbackingCirceEnum[A, B <: ValueEnumEntry[A]] { self: ValueEnum[A, B] =>
26 
27   def default(value: A): B
28 
29   def apply(value: A): B = withValueOpt(value).getOrElse(default(value))
30 
31   implicit def decoder(implicit d: Decoder[A]): Decoder[B] = Decoder[A].map(apply)
32   implicit def encoder(implicit e: Encoder[A]): Encoder[B] = Encoder[A].contramap(_.value)
33 
34 }
35 
36 object FallbackingCirceEnum {
37 
38   type FallbackingStringCirceEnum[A <: StringEnumEntry] = FallbackingCirceEnum[String, A]
39 
40 }
Line Stmt Id Pos Tree Symbol Tests Code
29 4076 1032 - 1077 Apply scala.Option.getOrElse akka.http.scaladsl.testkit.routetest,org.make.core.user.usertest,org.make.api.user.persistentuserservicecomponenttest,org.make.api.feature.featureservicetest FallbackingCirceEnum.this.withValueOpt(value).getOrElse[B](FallbackingCirceEnum.this.default(value))
29 5126 1062 - 1076 Apply org.make.core.technical.enumeratum.FallbackingCirceEnum.default akka.http.scaladsl.testkit.routetest,org.make.core.user.usertest,org.make.api.user.persistentuserservicecomponenttest,org.make.api.feature.featureservicetest FallbackingCirceEnum.this.default(value)
31 5547 1140 - 1161 Apply io.circe.Decoder.map akka.http.scaladsl.testkit.routetest io.circe.Decoder.apply[A](d).map[B](((value: A) => FallbackingCirceEnum.this.apply(value)))
31 2160 1155 - 1160 Apply org.make.core.technical.enumeratum.FallbackingCirceEnum.apply akka.http.scaladsl.testkit.routetest FallbackingCirceEnum.this.apply(value)
32 3442 1244 - 1251 Select enumeratum.values.ValueEnumEntry.value x$1.value
32 2440 1223 - 1252 Apply io.circe.Encoder.contramap io.circe.Encoder.apply[A](e).contramap[B](((x$1: B) => x$1.value))