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