gate.util.persistence.LRPersistence 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 26/10/2001
*
* $Id: LRPersistence.java 18176 2014-07-11 15:45:13Z johann_p $
*
*/
package gate.util.persistence;
import java.io.Serializable;
import java.util.Map;
import gate.DataStore;
import gate.LanguageResource;
import gate.creole.ResourceInstantiationException;
import gate.persist.PersistenceException;
public class LRPersistence extends ResourcePersistence {
/**
* Populates this Persistence with the data that needs to be stored from the
* original source object.
*/
@Override
public void extractDataFromSource(Object source)throws PersistenceException{
//check input
if(! (source instanceof LanguageResource)){
throw new UnsupportedOperationException(
getClass().getName() + " can only be used for " +
LanguageResource.class.getName() +
" objects!\n" + source.getClass().getName() +
" is not a " + LanguageResource.class.getName());
}
super.extractDataFromSource(source);
//LR's will have the features saved by their respective persistence
//mechanism
features = null;
LanguageResource lr = (LanguageResource)source;
if(lr.getDataStore() == null){
dsData = null;
}else{
dsData = PersistenceManager.
getPersistentRepresentation(lr.getDataStore());
persistenceID = lr.getLRPersistenceId();
}
}
/**
* 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.
*/
@SuppressWarnings("unchecked")
@Override
public Object createObject()throws PersistenceException,
ResourceInstantiationException{
if(dsData == null) return super.createObject();
else{
//persistent doc
initParams = PersistenceManager.getTransientRepresentation(
initParams,containingControllerName,initParamOverrides);
DataStore ds = (DataStore)PersistenceManager.getTransientRepresentation(
dsData,containingControllerName,initParamOverrides);
((Map