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

fm.common.rich.RichImmutableArray.scala Maven / Gradle / Ivy

/*
 * Copyright 2016 Frugal Mechanic (http://frugalmechanic.com)
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package fm.common.rich

import com.github.benmanes.caffeine.cache.{CacheLoader, Caffeine, LoadingCache}
import fm.common.{ImmutableArray, Interner}
import fm.common.ImmutableArray

object RichImmutableArray {
  // Needed on Scala 2.11. Other versions of Scala can automatically perform this functional interface conversion
  private implicit def toCacheLoader[K, V](f: K => V): CacheLoader[K, V] = new CacheLoader[K, V] {
    override def load(key: K): V = f(key)
  }

  private val interners: LoadingCache[Class[_], Interner[ImmutableArray[_]]] = Caffeine.newBuilder()
    .weakKeys()
    .build{ (_: Class[_]) =>
    Interner[ImmutableArray[_]]()
  }
}

final class RichImmutableArray[A](val arr: ImmutableArray[A]) extends AnyVal {
  def intern: ImmutableArray[A] = RichImmutableArray.interners.get(arr.getClass)(arr).asInstanceOf[ImmutableArray[A]]
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy