Android Open Source - InMemoryDb In Memory Db Tree Set






From Project

Back to project page InMemoryDb.

License

The source code is released under:

Apache License

If you think the Android project InMemoryDb listed in this page is inappropriate, such as containing malicious code/tools or violating the copyright, please email info at java2s dot com, thanks.

Java Source Code

package org.gawst.asyncdb;
/*w w w.  j a  v a2  s  . co m*/
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.Comparator;
import java.util.TreeSet;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.ReentrantLock;

/**
 * a basic helper class to keep the content of a flat database in an {@link TreeSet}
 * <p>
 * you should use the {@link #mDataLock} when iterating through the {@link TreeSet}
 * @author Steve Lhomme
 *
 * @param <E> the type of items stored in memory by the {@link InMemoryDbTreeSet}
 */
public abstract class InMemoryDbTreeSet<E, INSERT_ID> extends InMemoryDbSet<E, TreeSet<E>, INSERT_ID> {

  /**
   * The array where the data are stored, locked when writing on it
   */
  private TreeSet<E> mData;

  /**
   * Field to tell when the data are being reloaded from the DB
   */
  private boolean mIsLoading;

  private final Comparator<E> comparator;

  /**
   * ReentrantLock used to protect {@link #mData} when reading/writing/iterating it
   */
  protected ReentrantLock mDataLock;

  /**
   * Condition to block the {@link #mData} access before the data are loaded
   */
  private Condition dataLoaded;

  /**
   * @param db The already created {@link android.database.sqlite.SQLiteOpenHelper} to use as storage
   * @param name of the database file, or null for an in-memory database
   * @param logger the {@link Logger} to use for all logs (can be null for the default Android logs)
   * @param comparator comparator to sort the elements
   */
  protected InMemoryDbTreeSet(DataSource<E, INSERT_ID> db, String name, Logger logger, Comparator<E> comparator) {
    this(db, name, logger, comparator, null);
  }

  /**
   * @param db
   * @param name of the database file, or null for an in-memory database
   * @param logger the {@link org.gawst.asyncdb.Logger} to use for all logs (can be null for the default Android logs)
   * @param comparator comparator to sort the elements
   * @param initCookie Cookie to pass to {@link AsynchronousDbHelper#preloadInit(Object)}
   */
  protected InMemoryDbTreeSet(DataSource<E, INSERT_ID> db, String name, Logger logger, Comparator<E> comparator, Object initCookie) {
    super(db, name, logger, initCookie);
    this.comparator = comparator;
  }

  @Override
  protected void preloadInit(Object cookie) {
    mDataLock = new ReentrantLock();
    dataLoaded = mDataLock.newCondition();
    super.preloadInit(cookie);
    mData = new TreeSet<E>(comparator);
  }

  @Override
  protected TreeSet<E> getSet() {
    if (!mDataLock.isHeldByCurrentThread()) throw new IllegalStateException("we need a lock on mDataLock to access mData in "+this);
    if (!isDataLoaded() && !mIsLoading)
      try {
        // we're trying to read the data but they are not loading yet
        LogManager.logger.v(STARTUP_TAG, "waiting data loaded in "+this);
        long now = System.currentTimeMillis();
        dataLoaded.await(10, TimeUnit.SECONDS);
        LogManager.logger.v(STARTUP_TAG, "waiting data loaded in "+this+" finished after "+(System.currentTimeMillis()-now));
      } catch (InterruptedException ignored) {
        LogManager.logger.w(STARTUP_TAG, "timed out waiting for data loaded in "+this);
      }
    return mData;
  }

  @Override
  protected void startLoadingInMemory() {
    mDataLock.lock();
    mData.clear();
    mIsLoading = true;
    super.startLoadingInMemory();
  }

  @Override
  protected void finishLoadingInMemory() {
    super.finishLoadingInMemory();
    mIsLoading = false;
    dataLoaded.signalAll();
    mDataLock.unlock();
  }

  @Override
  public boolean contains(E object) {
    // protect the data coherence
    mDataLock.lock();
    try {
      return super.contains(object);
    } finally {
      mDataLock.unlock();
    }
  }

  @Override
  public boolean add(E item) {
    // protect the data coherence
    mDataLock.lock();
    try {
      return super.add(item);
    } finally {
      mDataLock.unlock();
    }
  }

  @Override
  public boolean replace(E item) {
    // protect the data coherence
    mDataLock.lock();
    try {
      return super.replace(item);
    } finally {
      mDataLock.unlock();
    }
  }

  @Override
  public boolean remove(E item) {
    // protect the data coherence
    mDataLock.lock();
    try {
      return super.remove(item);
    } finally {
      mDataLock.unlock();
    }
  }

  @Override
  public boolean removeAll(Collection<E> collection) {
    // protect the data coherence
    mDataLock.lock();
    try {
      return super.removeAll(collection);
    } finally {
      mDataLock.unlock();
    }
  }

  @Override
  protected void clearDataInMemory() {
    // protect the data coherence
    mDataLock.lock();
    try {
      super.clearDataInMemory();
    } finally {
      mDataLock.unlock();
    }
  }

  public int size() {
    mDataLock.lock();
    try {
      return null==mData ? 0 : mData.size();
    } finally {
      mDataLock.unlock();
    }
  }

  @Override
  public E get(int position) {
    mDataLock.lock();
    try {
      return super.get(position);
    } finally {
      mDataLock.unlock();
    }
  }

  @Override
  public void waitForDataLoaded() {
    mDataLock.lock();
    try {
      getSet();
        super.waitForDataLoaded();
    } finally {
      mDataLock.unlock();
    }
  }

  @Override
  public java.util.List<E> getListCopy() {
    mDataLock.lock();
    try {
      return Collections.unmodifiableList(new ArrayList<E>(getSet()));
    } finally {
      mDataLock.unlock();
    }
  }
}




Java Source Code List

org.gawst.asyncdb.AsyncDatabaseHandler.java
org.gawst.asyncdb.AsyncDbHelperHandler.java
org.gawst.asyncdb.AsyncQueryHandler.java
org.gawst.asyncdb.AsynchronousDatabase.java
org.gawst.asyncdb.AsynchronousDbErrorHandler.java
org.gawst.asyncdb.AsynchronousDbHelper.java
org.gawst.asyncdb.AsynchronousDbOperation.java
org.gawst.asyncdb.DataSource.java
org.gawst.asyncdb.InMemoryDbArrayList.java
org.gawst.asyncdb.InMemoryDbCopyOnWriteArrayList.java
org.gawst.asyncdb.InMemoryDbList.java
org.gawst.asyncdb.InMemoryDbListener.java
org.gawst.asyncdb.InMemoryDbMap.java
org.gawst.asyncdb.InMemoryDbSet.java
org.gawst.asyncdb.InMemoryDbTreeSet.java
org.gawst.asyncdb.InMemoryHashmapDb.java
org.gawst.asyncdb.InMemoryLruCache.java
org.gawst.asyncdb.InvalidDbEntry.java
org.gawst.asyncdb.InvalidEntry.java
org.gawst.asyncdb.LogManager.java
org.gawst.asyncdb.Logger.java
org.gawst.asyncdb.LruCache.java
org.gawst.asyncdb.MapDataSource.java
org.gawst.asyncdb.MapDatabaseElementHandler.java
org.gawst.asyncdb.MapEntry.java
org.gawst.asyncdb.adapter.InMemoryArrayListAdapter.java
org.gawst.asyncdb.adapter.InMemoryFilteredAdapter.java
org.gawst.asyncdb.adapter.InMemoryFilteredListAdapter.java
org.gawst.asyncdb.adapter.InMemoryFilteredTreeAdapter.java
org.gawst.asyncdb.adapter.InMemoryTreeSetAdapter.java
org.gawst.asyncdb.adapter.UIHandler.java
org.gawst.asyncdb.purge.DatabasePurgerMaxDate.java
org.gawst.asyncdb.purge.DatabaseSourcePurgerMax.java
org.gawst.asyncdb.purge.DatabaseSourcePurger.java
org.gawst.asyncdb.purge.PurgeHandler.java
org.gawst.asyncdb.source.ContentProviderDataSource.java
org.gawst.asyncdb.source.CursorDataSource.java
org.gawst.asyncdb.source.DatabaseElementHandler.java
org.gawst.asyncdb.source.DatabaseSource.java
org.gawst.asyncdb.source.SqliteDataSource.java
org.gawst.asyncdb.source.SqliteMapDataSource.java
org.gawst.asyncdb.source.typed.TypedContentProviderDataSource.java
org.gawst.asyncdb.source.typed.TypedCursorDataSource.java
org.gawst.asyncdb.source.typed.TypedDatabaseElementHandler.java
org.gawst.asyncdb.source.typed.TypedDatabaseSource.java
org.gawst.asyncdb.source.typed.TypedSqliteDataSource.java
org.gawst.asyncdb.source.typed.TypedSqliteMapDataSource.java