AbstractWebNotifListData.java

/*
 * Copyright (C) 2003-2014 eXo Platform SAS.
 *
 * This program 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.
 *
 * This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
 */
package org.exoplatform.commons.notification.impl.service.storage.cache;

import java.io.Serializable;
import java.util.Collections;
import java.util.LinkedList;
import java.util.List;

/**
 * Created by The eXo Platform SAS
 * Author : eXoPlatform
 *          exo@exoplatform.com
 * Oct 30, 2014  
 */
public abstract class AbstractWebNotifListData<K, V> implements Serializable {
  private static final long serialVersionUID = -9014159315525998105L;

  /** defines the list keeps the data **/
  private final LinkedList<V> list = new LinkedList<V>();
  /** */
  protected final K key;
  
  /**
   * 
   * @param key
   * @param list
   */
  public AbstractWebNotifListData(K key, final List<V> list) {
    this.list.addAll(list);
    this.key = key;
  }
  
  public AbstractWebNotifListData(K key) {
    this.key = key;
  }
  
  /**
   * Gets the list of its wrapper 
   * @return
   */
  public List<V> getList() {
    return this.list;
  }

  /**
   * Gets the size of elements
   * @return
   */
  public int size() {
    return list.size();
  }

  /**
   * Gets the sublist by given from and to
   * 
   * @param from the given from
   * @param to the given to
   * @return the sublist
   */
  public List<V> subList(int from, int to) {
    if (from >= this.list.size()) return Collections.emptyList();
    //
    if (to == -1) return this.list;
    //
    int newTo = Math.min(to, this.list.size());
    return this.list.subList(from, newTo);
  }
  
  
  /**
   * Puts the value at the given index
   * @param value
   * @param ownerId
   */
  public void put(int index, V value, String ownerId) {
    beforePut();
    this.list.add(index, value);
    afterPut();
  }
  
  /**
   * Puts the value at the top of list
   * @param value the given value
   */
  public void putAtTop(V value, String ownerId) {
    put(0, value, ownerId);
  }
  
  public void beforePut() {}
  
  public void afterPut() {}
  
  public void beforePutRef() {}
  
  public void afterPutRef() {}
  
  public void beforeMove(V value) {
    this.list.remove(value);
  }
  
  public void afterMove() {}
  
  public void beforeRemove() {}
  
  public void afterRemove() {}
  
  /**
   * Moves the value at the given index
   * @param value
   * @param ownerId
   */
  public void move(int index, V value, String ownerId) {
    beforeMove(value);
    this.list.add(index, value);
    afterMove();
  }
  
  /**
   * Moves the value at the top of list
   * @param value the given value
   */
  public void moveTop(V value, String ownerId) {
    beforeMove(value);
    this.list.addFirst(value);
    afterMove();
  }
  
  /**
   * Moves the value at the given index
   * @param value
   * @param ownerId
   */
  public void remove(V value, String ownerId) {
    beforeRemove();
    this.list.remove(value);
    afterRemove();
  }
  
  /**
   * Inserts the value into last position
   * @param value
   */
  public void insertLast(V value) {
    this.list.offerLast(value);
  }
  
  /**
   * Returns true if this list contains the specified element.
   * 
   * @param value
   * @return
   */
  public boolean contains(V value) {
    return list.contains(value);
  }
  
  /**
   * Removes all of the elements from this list.
   * 
   */
  public void clear() {
    list.clear();
  }
  
  /**
   * Removes the item by its value
   * @param value the id
   * @return
   */
  public boolean removeByValue(V value) {
    return this.list.remove(value);
  }

  @Override
  public boolean equals(Object o) {
    if (this == o) return true;
    if (!(o instanceof AbstractWebNotifListData)) return false;

    AbstractWebNotifListData<?, ?> that = (AbstractWebNotifListData<?, ?>) o;

    if(!list.equals(that.list)) {
      return false;
    }
    return key != null ? key.equals(that.key) : that.key == null;

  }

  @Override
  public int hashCode() {
    int result = (key != null ? key.hashCode() : 0);
    result = 31 * result + (list != null ? list.hashCode() : 0);
    return result;
  }
}