gate.util.persistence.Persistence Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gate-core Show documentation
Show all versions of gate-core Show documentation
GATE - general achitecture for text engineering - is open source
software capable of solving almost any text processing problem. This
artifact enables you to embed the core GATE Embedded with its essential
dependencies. You will able to use the GATE Embedded API and load and
store GATE XML documents. This artifact is the perfect dependency for
CREOLE plugins or for applications that need to customize the GATE
dependencies due to confict with their own dependencies or for lower
footprint.
The newest version!
/*
* Copyright (c) 1995-2012, The University of Sheffield. See the file
* COPYRIGHT.txt in the software or at http://gate.ac.uk/gate/COPYRIGHT.txt
*
* This file is part of GATE (see http://gate.ac.uk/), and is free
* software, licenced under the GNU Library General Public License,
* Version 2, June 1991 (in the distribution as file licence.html,
* and also available at http://gate.ac.uk/gate/licence.html).
*
* Valentin Tablan 25/10/2001
*
* $Id: Persistence.java 15333 2012-02-07 13:18:33Z ian_roberts $
*
*/
package gate.util.persistence;
import java.io.Serializable;
import gate.creole.ResourceInstantiationException;
import gate.persist.PersistenceException;
/**
* Defines an object that holds persistent data about another object.
* Storing an arbitrary object will consist of creating an appropiate
* Persistence object for it and storing that one (via serialisation).
*
* Restoring a previously saved object will consist of restoring the persistence
* object and using the data it stores to create a new object that is as similar
* as possible to the original object.
*/
public interface Persistence extends Serializable{
/**
* Populates this Persistence with the data that needs to be stored from the
* original source object.
*/
public void extractDataFromSource(Object source)throws PersistenceException;
/**
* Creates a new object from the data contained. This new object is supposed
* to be a copy for the original object used as source for data extraction.
*/
public Object createObject()throws PersistenceException,
ResourceInstantiationException;
}