All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.geotools.data.memory.MemoryDataStore Maven / Gradle / Ivy

Go to download

The main module contains the GeoTools public interfaces that are used by other GeoTools modules (and GeoTools applications). Where possible we make use industry standard terms as provided by OGC and ISO standards. The formal GeoTools public api consists of gt-metadata, jts and the gt-main module. The main module contains the default implementations that are available provided to other GeoTools modules using our factory system. Factories are obtained from an appropriate FactoryFinder, giving applications a chance configure the factory used using the Factory Hints facilities. FilterFactory ff = CommonFactoryFinder.getFilterFactory(); Expression expr = ff.add( expression1, expression2 ); If you find yourself using implementation specific classes chances are you doing it wrong: Expression expr = new AddImpl( expression1, expressiom2 );

There is a newer version: 24.2-oss84-1
Show newest version
/*
 *    GeoTools - The Open Source Java GIS Toolkit
 *    http://geotools.org
 *
 *    (C) 2003-2016, Open Source Geospatial Foundation (OSGeo)
 *
 *    This library is free software; you can redistribute it and/or
 *    modify it under the terms of the GNU Lesser General Public
 *    License as published by the Free Software Foundation;
 *    version 2.1 of the License.
 *
 *    This library 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
 *    Lesser General Public License for more details.
 */
package org.geotools.data.memory;

import java.io.IOException;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import java.util.logging.Level;
import org.geotools.data.DataSourceException;
import org.geotools.data.FeatureReader;
import org.geotools.data.Query;
import org.geotools.data.Transaction;
import org.geotools.data.simple.SimpleFeatureCollection;
import org.geotools.data.simple.SimpleFeatureIterator;
import org.geotools.data.store.ContentDataStore;
import org.geotools.data.store.ContentEntry;
import org.geotools.data.store.ContentFeatureSource;
import org.geotools.feature.FeatureCollection;
import org.geotools.feature.FeatureIterator;
import org.geotools.feature.FeatureTypes;
import org.geotools.util.SuppressFBWarnings;
import org.opengis.feature.IllegalAttributeException;
import org.opengis.feature.simple.SimpleFeature;
import org.opengis.feature.simple.SimpleFeatureType;
import org.opengis.feature.type.Name;

/**
 * This is an example implementation of a DataStore used for testing.
 *
 * 

It serves as an example implementation of: * *

    *
  • FeatureListenerManager use: allows handling of FeatureEvents *
* *

This class will also illustrate the use of In-Process locking when the time comes. * * @author jgarnett */ // This code synchronizes on a ConcurrentHashMap, which does not seem very sensible (the structure // is designed for concurrent access...). May want to revisit @SuppressFBWarnings("JLM_JSR166_UTILCONCURRENT_MONITORENTER") public class MemoryDataStore extends ContentDataStore { public MemoryDataStore() { super(); } /** Use MemoryState to manage internal storage. */ protected MemoryState createContentState(ContentEntry entry) { return new MemoryState((MemoryEntry) entry); } /** * Construct an MemoryDataStore around an empty collection of the provided SimpleFeatureType * * @param featureType The initial feature type for the memory data store, an empty feature * collection of this type will be made available */ public MemoryDataStore(SimpleFeatureType featureType) { try { // creates new entry for FeatureType entry(featureType); } catch (IOException e) { LOGGER.log(Level.FINER, e.getMessage(), e); } } public MemoryDataStore(FeatureCollection collection) { addFeatures(collection); } public MemoryDataStore(SimpleFeatureCollection collection) { addFeatures(collection); } public MemoryDataStore(SimpleFeature[] array) { addFeatures(array); } public MemoryDataStore(FeatureReader reader) throws IOException { addFeatures(reader); } public MemoryDataStore(SimpleFeatureIterator reader) throws IOException { addFeatures(reader); } /** * Configures MemoryDataStore with FeatureReader. * * @param reader New contents to add * @throws IOException If problems are encountered while adding * @throws DataSourceException See IOException */ public void addFeatures(FeatureReader reader) throws IOException { try { SimpleFeature feature = reader.next(); if (feature == null) { throw new IllegalArgumentException( "Provided FeatureReader is closed"); } addFeatureInternal(feature); while (reader.hasNext()) { feature = reader.next(); addFeatureInternal(feature); } } catch (IllegalAttributeException e) { throw new DataSourceException("Problem using reader", e); } finally { reader.close(); } } /** * Configures MemoryDataStore with FeatureReader. * * @param reader New contents to add * @throws IOException If problems are encountered while adding * @throws DataSourceException See IOException */ public void addFeatures(SimpleFeatureIterator reader) throws IOException { try { SimpleFeature feature = reader.next(); if (feature == null) { throw new IllegalArgumentException( "Provided FeatureReader is closed"); } addFeatureInternal(feature); while (reader.hasNext()) { feature = reader.next(); addFeatureInternal(feature); } } finally { reader.close(); } } /** * Configures MemoryDataStore with Collection. * *

You may use this to create a MemoryDataStore from a FeatureCollection. * * @param collection Collection of features to add * @throws IllegalArgumentException If provided collection is empty */ public void addFeatures(Collection collection) { if ((collection == null) || collection.isEmpty()) { throw new IllegalArgumentException("Provided Collection is empty"); } synchronized (entries) { for (Object item : collection) { addFeatureInternal((SimpleFeature) item); } } } public void addFeatures(FeatureCollection collection) { if ((collection == null)) { throw new IllegalArgumentException("Provided FeatureCollection is empty"); } synchronized (entries) { try (FeatureIterator iterator = collection.features()) { while (iterator.hasNext()) { addFeatureInternal(iterator.next()); } } } } /** * Configures MemoryDataStore with feature array. * * @param features Array of features to add * @throws IllegalArgumentException If provided feature array is empty */ public void addFeatures(SimpleFeature[] features) { if ((features == null) || (features.length == 0)) { throw new IllegalArgumentException("Provided features are empty"); } synchronized (entries) { for (int i = 0; i < features.length; i++) { addFeatureInternal(features[i]); } } } /** * Adds a single Feature to the correct typeName entry. * *

This is an internal operation used for setting up MemoryDataStore - please use * FeatureWriter for general use. * *

This method is willing to create new FeatureTypes for MemoryDataStore. * * @param feature Individual feature to add */ public void addFeature(SimpleFeature feature) { synchronized (entries) { addFeatureInternal(feature); } } private void addFeatureInternal(SimpleFeature feature) { if (feature == null) { throw new IllegalArgumentException("Provided Feature is empty"); } SimpleFeatureType featureType = feature.getFeatureType(); try { MemoryEntry entry = entry(featureType); entry.addFeature(feature); } catch (IOException e) { LOGGER.log(Level.FINER, e.getMessage(), e); } } /** * Access MemoryState for typeName. * *

Technically this is accessing the MemoryState for {@link Transaction#AUTO_COMMIT}, which * is the definitive storage for the feature content. * * @return MemoryState storing feature (by FeatureID) * @throws IOException If typeName cannot be found */ protected MemoryEntry entry(String typeName) throws IOException { synchronized (entries) { for (ContentEntry entry : this.entries.values()) { if (entry.getName().getLocalPart().equals(typeName)) { return (MemoryEntry) entry; } } } throw new IOException("Type name " + typeName + " not found"); } /** * Access to entry to store content of the provided schema, will create new entry if needed. * *

* * @return MemoryState used for content storage * @throws IOException If new entry could not be created due to typeName conflict */ protected MemoryEntry entry(SimpleFeatureType schema) throws IOException { Name typeName = schema.getName(); synchronized (entries) { if (entries.containsKey(typeName)) { MemoryEntry entry = (MemoryEntry) entries.get(typeName); if (FeatureTypes.equals(entry.schema, schema)) { return entry; } else { throw new IOException( "Entry " + typeName + " schema " + entry.schema + " incompatible with provided " + schema); } } else { MemoryEntry entry = new MemoryEntry(this, schema); entries.put(typeName, entry); return entry; } } } /** * List of available types provided by this DataStore. * * @return List of type names * @see org.geotools.data.ContentDataStore#getFeatureTypes() */ protected List createTypeNames() { List names = new ArrayList(this.entries.keySet()); Collections.sort( names, new Comparator() { public int compare(Name n1, Name n2) { return n1.toString().compareTo(n2.toString()); } }); return names; } protected ContentFeatureSource createFeatureSource(ContentEntry entry) { return createFeatureSource(entry, Query.ALL); } protected ContentFeatureSource createFeatureSource(ContentEntry entry, Query query) { return new MemoryFeatureStore(entry, query); } /** * Adds support for a new featureType to MemoryDataStore. * *

FeatureTypes are stored by typeName, an IOException will be thrown if the requested * typeName is already in use. * * @param featureType SimpleFeatureType to be added * @throws IOException If featureType already exists * @see org.geotools.data.DataStore#createSchema(org.geotools.feature.SimpleFeatureType) */ public void createSchema(SimpleFeatureType featureType) throws IOException { Name typeName = featureType.getName(); if (entries.containsKey(typeName)) { // we have a conflict throw new IOException(typeName + " already exists"); } MemoryEntry entry = new MemoryEntry(this, featureType); entries.put(typeName, entry); } @Override public void removeSchema(String typeName) throws IOException { for (Name name : entries.keySet()) { if (name.getLocalPart().equals(typeName)) { removeSchema(name); return; } } } @Override public void removeSchema(Name typeName) throws IOException { if (typeName != null) { // graceful remove, its fine if the type has never been registered synchronized (entries) { entries.remove(typeName); } } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy