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

coursier.internal.InMemoryCachingFetcher.scala Maven / Gradle / Ivy

package coursier.internal

import java.util.concurrent.ConcurrentHashMap

import coursier.core.Repository
import coursier.util.{Artifact, EitherT, Sync}

/** For benchmarking purposes */
final class InMemoryCachingFetcher[F[_]](underlying: Repository.Fetch[F])(implicit S: Sync[F]) {

  @volatile private var onlyCache0 = false
  private val cache                = new ConcurrentHashMap[Artifact, Either[String, String]]
  private val byUrl                = new ConcurrentHashMap[String, Either[String, String]]

  def onlyCache(): Unit = {
    onlyCache0 = true
  }

  def fromCache(url: String): String =
    Option(byUrl.get(url)) match {
      case None =>
        throw new NoSuchElementException(url)
      case Some(Left(err)) =>
        sys.error(s"$url is errored: $err")
      case Some(Right(s)) => s
    }

  def fetcher: Repository.Fetch[F] =
    artifact =>
      EitherT {
        Option(cache.get(artifact)) match {
          case None =>
            if (onlyCache0)
              S.fromAttempt(Left(new NoSuchElementException(s"Artifact $artifact")))
            else
              S.map(underlying(artifact).run) { res =>
                val res0 = Option(cache.putIfAbsent(artifact, res))
                  .getOrElse(res)
                byUrl.putIfAbsent(artifact.url, res0)
                res0
              }
          case Some(res) => S.point(res)
        }
      }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy