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

org.onebusaway.collections.ConcurrentCollectionsLibrary Maven / Gradle / Ivy

The newest version!
/**
 * Copyright (C) 2011 Brian Ferris 
 *
 * 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 org.onebusaway.collections;

import java.util.ArrayList;
import java.util.Collection;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import java.util.concurrent.ConcurrentMap;

public class ConcurrentCollectionsLibrary {

  private static final ListFactory _listFactory = new ListFactory();

  private static final SetFactory _setFactory = new SetFactory();

  public static  void addToMapValueList(
      ConcurrentMap> map, KEY key, VALUE value) {
    CollectionFactory> factory = listFactory();
    addToMapValueCollection(map, key, value, factory);
  }

  public static  void removeFromMapValueList(
      ConcurrentMap> map, KEY key, VALUE value) {
    CollectionFactory> factory = listFactory();
    removeFromMapValueCollection(map, key, value, factory);
  }

  public static  void addToMapValueSet(
      ConcurrentMap> map, KEY key, VALUE value) {
    CollectionFactory> factory = setFactory();
    addToMapValueCollection(map, key, value, factory);
  }

  public static  void removeFromMapValueSet(
      ConcurrentMap> map, KEY key, VALUE value) {
    CollectionFactory> factory = setFactory();
    removeFromMapValueCollection(map, key, value, factory);
  }

  /****
   * 
   ****/

  private static > void addToMapValueCollection(
      ConcurrentMap map, KEY key, VALUE value,
      CollectionFactory factory) {

    while (true) {

      C values = map.get(key);

      if (values == null) {
        C newKeys = factory.create(value);
        values = map.putIfAbsent(key, newKeys);
        if (values == null)
          return;
      }

      C origCopy = factory.copy(values);

      if (origCopy.contains(value))
        return;

      C extendedCopy = factory.copy(origCopy);
      extendedCopy.add(value);

      if (map.replace(key, origCopy, extendedCopy))
        return;
    }
  }

  private static > void removeFromMapValueCollection(
      ConcurrentMap map, KEY key, VALUE value,
      CollectionFactory factory) {

    while (true) {

      C values = map.get(key);

      if (values == null)
        return;

      C origCopy = factory.copy(values);

      if (!origCopy.contains(value))
        return;

      C reducedCopy = factory.copy(origCopy);
      reducedCopy.remove(value);

      if (reducedCopy.isEmpty()) {
        if (map.remove(key, origCopy))
          return;
      } else {
        if (map.replace(key, origCopy, reducedCopy))
          return;
      }
    }
  }

  @SuppressWarnings("unchecked")
  private static  CollectionFactory> listFactory() {
    return _listFactory;
  }

  @SuppressWarnings("unchecked")
  private static  CollectionFactory> setFactory() {
    return _setFactory;
  }

  private interface CollectionFactory> {
    public C create(VALUE value);

    public C copy(C existingValues);
  }

  @SuppressWarnings("rawtypes")
  private static class ListFactory implements CollectionFactory {

    @SuppressWarnings("unchecked")
    @Override
    public Collection create(Object value) {
      List values = new ArrayList(1);
      values.add(value);
      return values;
    }

    @SuppressWarnings("unchecked")
    @Override
    public Collection copy(Collection existingValues) {
      return new ArrayList(existingValues);
    }
  }

  @SuppressWarnings("rawtypes")
  private static class SetFactory implements CollectionFactory {

    @SuppressWarnings("unchecked")
    @Override
    public Collection create(Object value) {
      Set values = new HashSet();
      values.add(value);
      return values;
    }

    @SuppressWarnings("unchecked")
    @Override
    public Collection copy(Collection existingValues) {
      return new HashSet(existingValues);
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy