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

org.ekrich.config.ConfigOrigin.scala Maven / Gradle / Ivy

The newest version!
/**
 *   Copyright (C) 2011-2012 Typesafe Inc. 
 */
package org.ekrich.config

import java.net.URL
import java.util.List

/**
 * Represents the origin (such as filename and line number) of a
 * {@link ConfigValue} for use in error messages. Obtain the origin of a value
 * with {@link ConfigValue#origin}. Exceptions may have an origin, see
 * {@link ConfigException#origin}, but be careful because
 * ConfigException.origin() may return null.
 *
 * 

* It's best to use this interface only for debugging; its accuracy is * "best effort" rather than guaranteed, and a potentially-noticeable amount of * memory could probably be saved if origins were not kept around, so in the * future there might be some option to discard origins. * *

* Do not implement this interface; it should only be implemented by * the config library. Arbitrary implementations will not work because the * library internals assume a specific concrete implementation. Also, this * interface is likely to grow new methods over time, so third-party * implementations will break. */ trait ConfigOrigin { /** * Returns a string describing the origin of a value or exception. This will * never return null. * * @return string describing the origin */ def description: String /** * Returns a filename describing the origin. This will return null if the * origin was not a file. * * @return filename of the origin or null */ def filename: String /** * Returns a URL describing the origin. This will return null if the origin * has no meaningful URL. * * @return url of the origin or null */ def url: URL /** * Returns a classpath resource name describing the origin. This will return * null if the origin was not a classpath resource. * * @return resource name of the origin or null */ def resource: String /** * Returns a line number where the value or exception originated. This will * return -1 if there's no meaningful line number. * * @return line number or -1 if none is available */ def lineNumber: Int /** * Returns any comments that appeared to "go with" this place in the file. * Often an empty list, but never null. The details of this are subject to * change, but at the moment comments that are immediately before an array * element or object field, with no blank line after the comment, "go with" * that element or field. * * @return any comments that seemed to "go with" this origin, empty list if * none */ def comments: List[String] /** * Returns a {@code ConfigOrigin} based on this one, but with the given * comments. Does not modify this instance or any {@code ConfigValue}s with * this origin (since they are immutable). To set the returned origin to a * {@code ConfigValue}, use {@link ConfigValue#withOrigin}. * *

* Note that when the given comments are equal to the comments on this object, * a new instance may not be created and {@code this} is returned directly. * * @since 1.3.0 * @param comments the comments used on the returned origin * @return the ConfigOrigin with the given comments */ def withComments(comments: List[String]): ConfigOrigin /** * Returns a {@code ConfigOrigin} based on this one, but with the given * line number. This origin must be a FILE, URL or RESOURCE. Does not modify * this instance or any {@code ConfigValue}s with this origin (since they are * immutable). To set the returned origin to a {@code ConfigValue}, use * {@link ConfigValue#withOrigin}. * *

* Note that when the given lineNumber are equal to the lineNumber on this * object, a new instance may not be created and {@code this} is returned * directly. * * @since 1.3.0 * @param lineNumber the new line number * @return the created ConfigOrigin */ def withLineNumber(lineNumber: Int): ConfigOrigin }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy