com.aspectran.utils.apon.Parameters Maven / Gradle / Ivy
The newest version!
/*
* Copyright (c) 2008-2025 The Aspectran Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.aspectran.utils.apon;
import java.io.File;
import java.io.Reader;
import java.util.Collection;
import java.util.List;
/**
* The Interface Parameters.
*/
public interface Parameters {
/**
* Returns whether the parameter can be added after the parameters instance
* is created.
* @return {@code true} if the parameter can be added after the parameters
* instance is created, otherwise {@code false}
*/
boolean isStructureFixed();
/**
* Returns the owner of this {@code Parameters}.
* @return the owner of this {@code Parameters}
*/
Parameter getProprietor();
/**
* Specifies the owner of this {@code Parameters}.
* @param proprietor the owner of this {@code Parameters}
*/
void setProprietor(Parameter proprietor);
/**
* Returns the parent of the proprietor of this {@code Parameters}.
*
* proprietor --> container --> proprietor == parent
*
* @return a {@code Parameter}
*/
Parameter getParent();
/**
* Returns its real name.
* If no name is given, it returns the name given by the owner.
* @return the actual name of this Parameters
*/
String getActualName();
/**
* Specifies the actual name of this {@code Parameters}.
* @param actualName the actual name of this {@code Parameters}
*/
void setActualName(String actualName);
/**
* Returns the qualified name.
* @return the qualified name
*/
String getQualifiedName();
String getQualifiedName(String name);
String getQualifiedName(ParameterKey key);
ParameterValue getParameterValue(String name);
ParameterValue getParameterValue(ParameterKey key);
Collection getParameterValues();
/**
* Returns all parameter names associated with this {@code Parameters}.
* @return an array of all parameter names associated with this {@code Parameters}
*/
String[] getParameterNames();
/**
* Returns whether this parameter exists.
* @param name the name of the parameter to check
* @return {@code true} if the specified parameter exists; {@code false} otherwise
*/
boolean hasParameter(String name);
/**
* Returns whether the specified parameter exists.
* @param key the parameter definition
* @return {@code true} if the specified parameter exists; {@code false} otherwise
*/
boolean hasParameter(ParameterKey key);
/**
* Returns whether a value is assigned to the specified parameter.
* Even if a null is assigned, it is valid.
* @param name the name of the parameter to check
* @return {@code true} if a parameter is assigned a value; {@code false} otherwise
*/
boolean isAssigned(String name);
/**
* Returns whether a value is assigned to the specified parameter.
* Even if a null is assigned, it is valid.
* @param key the parameter definition
* @return {@code true} if a parameter is assigned a value; {@code false} otherwise
*/
boolean isAssigned(ParameterKey key);
/**
* Returns whether a non-null value is assigned to the specified parameter.
* @param name the name of the parameter to check
* @return {@code true} if a non-null value is assigned a value; {@code false} otherwise
*/
boolean hasValue(String name);
/**
* Returns whether a non-null value is assigned to the specified parameter.
* @param key the parameter definition
* @return {@code true} if a non-null value is assigned a value; {@code false} otherwise
*/
boolean hasValue(ParameterKey key);
/**
* Returns the Parameter with the specified name.
* @param name the parameter name
* @return the Parameter with the specified name, or {@code null} if it does not exist
*/
Parameter getParameter(String name);
/**
* Returns the Parameter corresponding to the specified parameter definition.
* @param key the parameter definition
* @return the Parameter corresponding to the specified parameter definition,
* or {@code null} if it does not exist
*/
Parameter getParameter(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
Object getValue(String name);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
Object getValue(ParameterKey key);
void putAll(Parameters parameters);
/**
* Put a value into the Parameter with the specified name.
* @param name the parameter name
* @param value the value of parameter
*/
void putValue(String name, Object value);
/**
* Put a value into the Parameter with the specified parameter definition.
* @param key the parameter definition
* @param value the value of parameter
*/
void putValue(ParameterKey key, Object value);
/**
* Put a value of the parameter corresponding to the given name.
* If the value is null, ignore it.
* @param name the parameter name
* @param value the value of parameter
*/
void putValueIfNotNull(String name, Object value);
/**
* Put a value of the parameter corresponding to the given parameter definition.
* If the value is null, ignore it.
* @param key the parameter definition
* @param value the value of parameter
*/
void putValueIfNotNull(ParameterKey key, Object value);
/**
* Remove the value of this parameter.
* @param name the parameter name
*/
void removeValue(String name);
/**
* Remove the value of this parameter.
* @param key the parameter key
*/
void removeValue(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
String getString(String name);
/**
* Return the value for the specified parameter,
* or {@code defaultValue} if the parameter does not exist.
* @param name the parameter name
* @param defaultValue the default value to return if no value is found
* @return the value for the specified parameter, or {@code defaultValue}
*/
String getString(String name, String defaultValue);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
String[] getStringArray(String name);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
String getString(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code defaultValue} if the parameter does not exist.
* @param key the parameter definition
* @param defaultValue the default value to return if no value is found
* @return the value for the specified parameter, or {@code defaultValue}
*/
String getString(ParameterKey key, String defaultValue);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
String[] getStringArray(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
List getStringList(String name);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
List getStringList(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
Integer getInt(String name);
/**
* Return the value for the specified parameter,
* or {@code defaultValue} if the parameter does not exist.
* @param name the parameter name
* @param defaultValue the default value to return if no value is found
* @return the value for the specified parameter, or {@code defaultValue}
*/
int getInt(String name, int defaultValue);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
Integer[] getIntArray(String name);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
Integer getInt(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code defaultValue} if the parameter does not exist.
* @param key the parameter definition
* @param defaultValue the default value to return if no value is found
* @return the value for the specified parameter, or {@code defaultValue}
*/
int getInt(ParameterKey key, int defaultValue);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
Integer[] getIntArray(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
List getIntList(String name);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
List getIntList(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
Long getLong(String name);
/**
* Return the value for the specified parameter,
* or {@code defaultValue} if the parameter does not exist.
* @param name the parameter name
* @param defaultValue the default value to return if no value is found
* @return the value for the specified parameter, or {@code defaultValue}
*/
long getLong(String name, long defaultValue);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
Long[] getLongArray(String name);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
Long getLong(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code defaultValue} if the parameter does not exist.
* @param key the parameter definition
* @param defaultValue the default value to return if no value is found
* @return the value for the specified parameter, or {@code defaultValue}
*/
long getLong(ParameterKey key, long defaultValue);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
Long[] getLongArray(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
List getLongList(String name);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
List getLongList(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
Float getFloat(String name);
/**
* Return the value for the specified parameter,
* or {@code defaultValue} if the parameter does not exist.
* @param name the parameter name
* @param defaultValue the default value to return if no value is found
* @return the value for the specified parameter, or {@code defaultValue}
*/
float getFloat(String name, float defaultValue);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
Float[] getFloatArray(String name);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
Float getFloat(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code defaultValue} if the parameter does not exist.
* @param key the parameter definition
* @param defaultValue the default value to return if no value is found
* @return the value for the specified parameter, or {@code defaultValue}
*/
float getFloat(ParameterKey key, float defaultValue);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
Float[] getFloatArray(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
List getFloatList(String name);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
List getFloatList(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
Double getDouble(String name);
/**
* Return the value for the specified parameter,
* or {@code defaultValue} if the parameter does not exist.
* @param name the parameter name
* @param defaultValue the default value to return if no value is found
* @return the value for the specified parameter, or {@code defaultValue}
*/
double getDouble(String name, double defaultValue);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
Double[] getDoubleArray(String name);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
Double getDouble(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code defaultValue} if the parameter does not exist.
* @param key the parameter definition
* @param defaultValue the default value to return if no value is found
* @return the value for the specified parameter, or {@code defaultValue}
*/
double getDouble(ParameterKey key, double defaultValue);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
Double[] getDoubleArray(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
List getDoubleList(String name);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
List getDoubleList(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
Boolean getBoolean(String name);
/**
* Return the value for the specified parameter,
* or {@code defaultValue} if the parameter does not exist.
* @param name the parameter name
* @param defaultValue the default value to return if no value is found
* @return the value for the specified parameter, or {@code defaultValue}
*/
boolean getBoolean(String name, boolean defaultValue);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
Boolean[] getBooleanArray(String name);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
Boolean getBoolean(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code defaultValue} if the parameter does not exist.
* @param key the parameter definition
* @param defaultValue the default value to return if no value is found
* @return the value for the specified parameter, or {@code defaultValue}
*/
boolean getBoolean(ParameterKey key, boolean defaultValue);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
Boolean[] getBooleanArray(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
List getBooleanList(String name);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
List getBooleanList(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param the type parameter
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
T getParameters(String name);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param the type parameter
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
T[] getParametersArray(String name);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param the type parameter
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
T getParameters(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param the type parameter
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
T[] getParametersArray(ParameterKey key);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param the type parameter
* @param name the parameter name
* @return the value for the specified parameter, or {@code null}
*/
List getParametersList(String name);
/**
* Return the value for the specified parameter,
* or {@code null} if the parameter does not exist.
* @param the type parameter
* @param key the parameter definition
* @return the value for the specified parameter, or {@code null}
*/
List getParametersList(ParameterKey key);
ParameterValue newParameterValue(String name, ValueType valueType);
ParameterValue newParameterValue(String name, ValueType valueType, boolean array);
T newParameters(String name);
T newParameters(ParameterKey key);
T touchParameters(String name);
T touchParameters(ParameterKey key);
/**
* Updates the holder of the subparameters belonging to this parameter.
*/
void updateContainer(Parameters container);
void readFrom(String apon) throws AponParseException;
void readFrom(VariableParameters parameters) throws AponParseException;
void readFrom(File file) throws AponParseException;
void readFrom(File file, String encoding) throws AponParseException;
void readFrom(Reader reader) throws AponParseException;
T copy();
String describe();
String describe(boolean details);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy