All Downloads are FREE. Search and download functionalities are using the official Maven repository.

swaydb.Apply.scala Maven / Gradle / Ivy

There is a newer version: 0.15
Show newest version
/*
 * Copyright (c) 2020 Simer JS Plaha ([email protected] - @simerplaha)
 *
 * This file is a part of SwayDB.
 *
 * SwayDB is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License as
 * published by the Free Software Foundation, either version 3 of the
 * License, or (at your option) any later version.
 *
 * SwayDB is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with SwayDB. If not, see .
 *
 * Additional permission under the GNU Affero GPL version 3 section 7:
 * If you modify this Program or any covered work, only by linking or
 * combining it with separate works, the licensors of this Program grant
 * you additional permission to convey the resulting work.
 */

package swaydb

import scala.concurrent.duration.{Deadline, FiniteDuration}

/**
 * Output for [[PureFunction]] instances.
 */
sealed trait Apply[+V]
object Apply {

  /**
   * Function outputs for Map
   */
  object Map {
    def toOption[V](value: Map[V]): Map[Option[V]] =
      value match {
        case Apply.Nothing =>
          Apply.Nothing

        case Apply.Remove =>
          Apply.Remove

        case expire @ Apply.Expire(_) =>
          expire

        case Apply.Update(value, deadline) =>
          Apply.Update(Some(value), deadline)
      }
  }
  sealed trait Map[+V] extends Apply[V]

  /**
   * Function outputs for Set
   */
  sealed trait Set[+V] extends Apply[V]

  case object Nothing extends Map[Nothing] with Set[Nothing]
  case object Remove extends Map[Nothing] with Set[Nothing]
  object Expire {
    def apply(after: FiniteDuration): Expire =
      new Expire(after.fromNow)
  }

  final case class Expire(deadline: Deadline) extends Map[Nothing] with Set[Nothing]

  object Update {
    def apply[V](value: V): Update[V] =
      new Update(value, None)

    def apply[V](value: V, expireAfter: FiniteDuration): Update[V] =
      new Update(value, Some(expireAfter.fromNow))

    def apply[V](value: V, expireAt: Deadline): Update[V] =
      new Update(value, Some(expireAt))
  }

  final case class Update[V](value: V, deadline: Option[Deadline]) extends Map[V]
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy