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

org.eclipse.rdf4j.common.app.config.Configuration Maven / Gradle / Ivy

There is a newer version: 5.1.0
Show newest version
/*******************************************************************************
 * 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.common.app.config;

import java.io.IOException;

public interface Configuration {

	public static final String DIR = "conf";

	public static final String RESOURCES_LOCATION = "/org/eclipse/rdf4j/common/app/config/";

	public static final String DEFAULT_RESOURCES_LOCATION = RESOURCES_LOCATION + "defaults/";

	/**
	 * Initialize the configuration settings.
	 * 
	 * @throws IOException
	 *         if the configuration settings could not be initialized because of an I/O problem.
	 */
	public void init()
		throws IOException;

	/**
	 * Load the configuration settings. Settings will be loaded from a user and application specific location
	 * first. If no such settings exists, an attempt will be made to retrieve settings from a resource on the
	 * classpath. If no such settings exist either, settings will be loaded from a default resource on the
	 * classpath.
	 * 
	 * @throws IOException
	 *         if the configuration settings could not be loaded due to an I/O problem.
	 */
	public void load()
		throws IOException;

	/**
	 * Store configuration settings. Settings will be stored in a user and application specific location.
	 * 
	 * @throws IOException
	 *         if the configuration settings could not be saved due to an I/O problem.
	 */
	public void save()
		throws IOException;

	/**
	 * Clean up configuration resources.
	 * 
	 * @throws IOException
	 *         if one or more resources could not be cleaned up. Implementations should attempt to clean up as
	 *         many resources as possible before returning or throwing an exception.
	 */
	public void destroy()
		throws IOException;
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy