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

org.geotools.data.FeatureWriter 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) 2008, 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;

import java.io.Closeable;
import java.io.IOException;
import org.opengis.feature.Feature;
import org.opengis.feature.type.FeatureType;

/**
 * Provides the ability to write Features information.
 *
 * 

Capabilities: * *

    *
  • Similar API to FeatureReader *
  • After aquiring a feature using next() you may call remove() or after modification write(). * If you do not call one of these two methods before calling hasNext(), or next() for that * matter, the feature will be left unmodified. *
  • This API allows modification, and Filter based modification to be written. Please see * ContentDataStore for examples of implementing common opperations using this API. *
  • In order to add new Features, FeatureWriters capable of accepting new content allow next() * to be called when hasNext() is false to allow new feature creation. These * changes *
* *

One thing that is really nice about the approach to adding content is that the generation of * FID is not left in the users control. * * @author Ian Schneider * @author Jody Garnett, Refractions Research * @version $Id$ */ public interface FeatureWriter extends Closeable { /** * FeatureType this reader has been configured to create. * * @return FeatureType this writer has been configured to create. */ T getFeatureType(); /** * Reads a Feature from the underlying AttributeReader. * *

This method may return a Feature even though hasNext() returns false, this * allows FeatureWriters to provide an ability to append content. * * @return Feature from Query, or newly appended Feature * @throws IOException if the writer has been closed or an I/O error occurs reading the next * Feature. */ F next() throws IOException; /** * Removes current Feature, must be called before hasNext. * *

FeatureWriters will need to allow all FeatureSources of the same typeName to issue a * FeatureEvent event of type FeatureEvent.FEATURES_REMOVED when this method is * called. * *

If this FeatureWriter is opperating against a Transaction FEATURES_REMOVED events should * only be sent to FeatureSources operating on the same Transaction. When Transaction commit() * is called other FeatureSources will be informed of the modifications. * *

When the current Feature has been provided as new content, this method "cancels" the add * opperation (and notification needed). */ void remove() throws IOException; /** * Writes the current Feature, must be called before hasNext. * *

FeautreWriters will need to allow FeatureSources of the same typeName to issue a * FeatureEvent: * *

    *
  • FeatureEvent.FEATURES_ADDED: when next() has been called with hasNext() equal to * false. *
  • FeatureEvent.FEATURES_MODIFIED: when next has been called with hasNext() equal to * true and the resulting Feature has indeed been modified. *
* *

If this FeatureWriter is opperating against a Transaction the FEATURES_MODIFIED or * FEATURES_ADDED events should only be sent to FeatureSources opperating on the same * Transaction. When Transaction commit() is called other FeatureSources will be informed of the * modifications. * *

If you have not called write() when you call hasNext() or next(), no modification will * occur(). */ void write() throws IOException; /** * Query whether this FeatureWriter has another Feature. * *

Please note: it is more efficient to construct your FeatureWriter with a Filer (to skip * entries you do not want), than to force the creation of entire Features only to skip over * them. * *

FeatureWriters that support append operations will allow calls to next, even when * hasNext() returns false. * * @return true if an additional Feature is available, false * if not. * @throws IOException if an I/O error occurs. */ boolean hasNext() throws IOException; /** * Release the underlying resources. * * @throws IOException if there there are problems releasing underlying resources, or possibly * if close has been called (up to the implementation). * @throws IOException if an I/O error occurs */ void close() throws IOException; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy