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

org.eclipse.rdf4j.rio.helpers.BasicWriterSettings 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.helpers;

import org.eclipse.rdf4j.rio.RioSetting;

/**
 * A class encapsulating the basic writer settings that most writers may support.
 * 
 * @author Peter Ansell
 */
public class BasicWriterSettings {

	/**
	 * Boolean setting for writer to determine whether pretty printing is preferred.
	 * 

* Defaults to true *

* Can be overridden by setting system property {@code org.eclipse.rdf4j.rio.pretty_print}. */ public static final RioSetting PRETTY_PRINT = new BooleanRioSetting( "org.eclipse.rdf4j.rio.pretty_print", "Pretty print", Boolean.TRUE); /** * Inline blanks nodes by their value and don't write any blank node labels when this setting is true. This * setting should only be used when blank nodes never appear in the context and there are no blank node * cycles. *

* WARNING: This setting requires all triples to be processed before being written and could use a lot of * memory in the process and should be set to false for large RDF files. *

* Defaults to false. *

* Can be overridden by setting system property {@code org.eclipse.rdf4j.rio.inline_blank_nodes}. * * @since 2.3 */ public static final RioSetting INLINE_BLANK_NODES = new BooleanRioSetting( "org.eclipse.rdf4j.rio.inline_blank_nodes", "Use blank node property lists, collections, and anonymous nodes instead of blank node labels", Boolean.FALSE); /** * Boolean setting for writer to determine whether it should remove the xsd:string datatype from literals * and represent them as RDF-1.0 Plain Literals. *

* In RDF-1.1, all literals that would have been Plain Literals in RDF-1.0 will be typed as xsd:string * internally. *

* Defaults to true to allow for backwards compatibility without enforcing it. *

* Can be overridden by setting system property {@code org.eclipse.rdf4j.rio.rdf10_plain_literals}. */ public static final RioSetting XSD_STRING_TO_PLAIN_LITERAL = new BooleanRioSetting( "org.eclipse.rdf4j.rio.rdf10_plain_literals", "RDF-1.0 compatible Plain Literals", Boolean.TRUE); /** * Boolean setting for writer to determine whether it should omit the rdf:langString datatype from language * literals when serialising them. *

* In RDF-1.1, all RDF-1.0 Language Literals are typed using rdf:langString in the abstract model, but this * datatype is not necessary for concrete syntaxes. *

* In most concrete syntaxes it is either syntactically invalid or semantically ambiguous to have a language * tagged literal with an explicit datatype. In those cases this setting will not be used, and the * rdf:langString datatype will not be attached to language tagged literals. *

* In particular, in RDF/XML, if rdf:langString is serialised, the language tag may not be retained when the * document is parsed due to the precedence rule in RDF/XML for datatype over language. *

* Defaults to true as rdf:langString was not previously used, and should not be commonly required. *

* Can be overridden by setting system property {@code org.eclipse.rdf4j.rio.rdf10_language_literals}. */ public static final RioSetting RDF_LANGSTRING_TO_LANG_LITERAL = new BooleanRioSetting( "org.eclipse.rdf4j.rio.rdf10_language_literals", "RDF-1.0 compatible Language Literals", Boolean.TRUE); /** * Boolean setting for writer to determine whether it should include a base directive. *

* Defaults to true *

* Can be overridden by setting system property {@code org.eclipse.rdf4j.rio.base_directive}. */ public static final RioSetting BASE_DIRECTIVE = new BooleanRioSetting( "org.eclipse.rdf4j.rio.base_directive", "Serialize base directive", Boolean.TRUE); /** * Private default constructor. */ private BasicWriterSettings() { } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy