Package jfix.db4o

Source Code of jfix.db4o.Database

/*
    Copyright (C) 2010 maik.jablonski@gmail.com

    This program is free software: you can redistribute it and/or modify
    it under the terms of the GNU 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 General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with this program.  If not, see <http://www.gnu.org/licenses/>.
*/
package jfix.db4o;

import java.util.List;

import jfix.db4o.engine.PersistenceEngine;
import jfix.functor.Command;
import jfix.functor.Predicate;
import jfix.functor.Supplier;

/**
* Static wrapper around ObjectDatabase (with appropriate setup of the
* PersistenceEngine) to ease the access to the database.
*
* Per default PersistenceEngineDb4o is used. Other PersistenceEngines can be
* configured via calling #setPersistenceEngine() before opening the database
* via #open().
*/
public class Database {

  private static String persistenceEngineClassName;
  private static ObjectDatabase odb;

  static {
    setPersistenceEngine("jfix.db4o.engine.PersistenceEngineDb4o");
  }

  /**
   * Sets the PersistenceEnginge by fully qualified classname.
   */
  public static void setPersistenceEngine(String className) {
    persistenceEngineClassName = className;
  }

  /**
   * Sets the PersistenceEngine by given class.
   */
  public static void setPersistenceEngine(Class clazz) {
    persistenceEngineClassName = clazz.getName();
  }

  /**
   * Opens the given database. The parameter is usually a simple name for the
   * database which is used by the PersistenceEngine to build the appropriate
   * path to the database-file. If the given database-name contains a
   * File.separator, the given database-name will be used as default directory
   * for the database-file.
   */
  public static void open(String database) {
    try {
      PersistenceEngine engine = (PersistenceEngine) Class.forName(
          persistenceEngineClassName).newInstance();
      engine.open(database);
      odb = new ObjectDatabase(engine);
      odb.open();
    } catch (Exception e) {
      e.printStackTrace();
      throw new RuntimeException(e);
    }
  }

  /**
   * Closes the current database.
   */
  public static void close() {
    odb.close();
  }

  /**
   * Extended access to opened ObjectDatabase.
   */
  public static ObjectDatabase ext() {
    return odb;
  }

  /**
   * Performs a Read-Command.
   */
  public static void read(Command transaction) {
    odb.read(transaction);
  }

  /**
   * Performs a Write-Command.
   */
  public static void write(Command transaction) {
    odb.write(transaction);
  }

  /**
   * Saves or upates given object in database.
   */
  public static void save(Persistent persistent) {
    odb.save(persistent);
  }

  /**
   * Deletes given object from database. If references to given object still
   * exists in database, a RuntimeException is thrown.
   */
  public static void delete(Persistent persistent) {
    odb.delete(persistent);
  }

  /**
   * Retrieves (cached) value from given supplier. The value of the supplier
   * will be cached as long as no write-operation is performed against the
   * database.
   */
  public static <E> E query(Supplier<E> index) {
    return odb.query(index);
  }

  /**
   * Queries all object from database which are instances of given class and
   * match the given predicate.
   */
  public static <E> List<E> query(Class<E> clazz, Predicate<E> predicate) {
    return odb.query(clazz, predicate);
  }

  /**
   * Queries all object from database which are instances of given class.
   */
  public static <E> List<E> query(Class<E> clazz) {
    return odb.query(clazz);
  }

  /**
   * True if object is already stored in database.
   */
  public static boolean isStored(Persistent persistent) {
    return odb.isStored(persistent);
  }

  /**
   * Checks if given object is unique when compared by given predicate.
   */
  public static <E> boolean isUnique(E entity, Predicate<E> predicate) {
    return odb.isUnique(entity, predicate);
  }

  /**
   * Retrieves unique object from database which is an instance of class and
   * matches given predicate. If no or more than one object do match the
   * predicate, null is returned.
   */
  public static <E> E queryUnique(Class<E> clazz, Predicate<E> predicate) {
    return odb.queryUnique(clazz, predicate);
  }
}
TOP

Related Classes of jfix.db4o.Database

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.