org.eclipse.rdf4j.rio.RDFWriter Maven / Gradle / Ivy
/*******************************************************************************
* Copyright (c) 2015 Eclipse RDF4J contributors, Aduna, and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Distribution License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*******************************************************************************/
package org.eclipse.rdf4j.rio;
import java.io.OutputStream;
import java.io.Writer;
import java.util.Collection;
import java.util.Optional;
import org.eclipse.rdf4j.common.annotation.Experimental;
import org.eclipse.rdf4j.common.annotation.InternalUseOnly;
/**
* An interface for RDF document writers. To allow RDF document writers to be created through reflection, all
* implementing classes should define at least two public constructors: one with an {@link OutputStream} argument and
* one with an {@link Writer} argument.
*/
public interface RDFWriter extends RDFHandler {
/**
* Gets the RDF format that this RDFWriter uses.
*/
public RDFFormat getRDFFormat();
/**
* Gets the {@link OutputStream} this writer writes to, if it uses one.
*
* @return an optional OutputStream
* @implNote This temporary default method is only supplied for backward compatibility. Concrete implementations are
* expected to override.
* @apiNote This method is currently considered experimental / for internal use only, and is likely to change in a
* future release without guarantees for backward compatibility. Use at your own risk.
* @since 3.2.0
*/
@InternalUseOnly
@Experimental
public default Optional getOutputStream() {
return Optional.empty();
}
/**
* Sets all supplied writer configuration options.
*
* @param config a writer configuration object.
* @return Either a copy of this writer, if it is immutable, or this object, to allow chaining of method calls.
*/
public RDFWriter setWriterConfig(WriterConfig config);
/**
* Retrieves the current writer configuration as a single object.
*
* @return a writer configuration object representing the current configuration of the writer.
*/
public WriterConfig getWriterConfig();
/**
* @return A collection of {@link RioSetting}s that are supported by this RDFWriter.
*/
public Collection> getSupportedSettings();
/**
* Set a setting on the writer, and return this writer object to allow chaining.
*
* @param setting The setting to change.
* @param value The value to change.
* @return Either a copy of this writer, if it is immutable, or this object, to allow chaining of method calls.
*/
public RDFWriter set(RioSetting setting, T value);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy