Var.java
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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 org.apache.commons.validator;
import java.io.Serializable;
/**
* A variable that can be associated with a <code>Field</code> for
* passing in information to a pluggable validator. Instances of this class are
* configured with a <var> xml element.
*/
public class Var implements Cloneable, Serializable {
private static final long serialVersionUID = -684185211548420224L;
/**
* Int Constant for JavaScript type. This can be used
* when auto-generating JavaScript.
*/
public static final String JSTYPE_INT = "int";
/**
* String Constant for JavaScript type. This can be used
* when auto-generating JavaScript.
*/
public static final String JSTYPE_STRING = "string";
/**
* Regular Expression Constant for JavaScript type. This can be used
* when auto-generating JavaScript.
*/
public static final String JSTYPE_REGEXP = "regexp";
/**
* The name of the variable.
*/
private String name;
/**
* The key or value the variable.
*/
private String value;
/**
* The optional JavaScript type of the variable.
*/
private String jsType;
/**
* Whether the variable is a resource [false]
*/
private boolean resource;
/**
* The bundle for a variable (when resource = 'true').
*/
private String bundle;
/**
* Default Constructor.
*/
public Var() {
}
/**
* Constructs a variable with a specified name, value
* and JavaScript type.
* @param name Variable name.
* @param value Variable value.
* @param jsType Variable JavaScript type.
*/
public Var(final String name, final String value, final String jsType) {
this.name = name;
this.value = value;
this.jsType = jsType;
}
/**
* Creates and returns a copy of this object.
* @return A copy of the variable.
*/
@Override
public Object clone() {
try {
return super.clone();
} catch (final CloneNotSupportedException e) {
throw new UnsupportedOperationException(e.toString(), e);
}
}
/**
* Returns the resource bundle name.
* @return The bundle name.
* @since 1.2.0
*/
public String getBundle() {
return this.bundle;
}
/**
* Gets the JavaScript type of the variable.
* @return The JavaScript type of the variable.
*/
public String getJsType() {
return this.jsType;
}
/**
* Gets the name of the variable.
* @return The name of the variable.
*/
public String getName() {
return this.name;
}
/**
* Gets the value of the variable.
* @return The value of the variable.
*/
public String getValue() {
return this.value;
}
/**
* Tests whether or not the value is a resource key or literal value.
* @return {@code true} if value is a resource key.
* @since 1.2.0
*/
public boolean isResource() {
return this.resource;
}
/**
* Sets the resource bundle name.
* @param bundle The new bundle name.
* @since 1.2.0
*/
public void setBundle(final String bundle) {
this.bundle = bundle;
}
/**
* Sets the JavaScript type of the variable.
* @param jsType The JavaScript type of the variable.
*/
public void setJsType(final String jsType) {
this.jsType = jsType;
}
/**
* Sets the name of the variable.
* @param name The name of the variable.
*/
public void setName(final String name) {
this.name = name;
}
/**
* Sets whether or not the value is a resource.
* @param resource If true indicates the value is a resource.
* @since 1.2.0
*/
public void setResource(final boolean resource) {
this.resource = resource;
}
/**
* Sets the value of the variable.
* @param value The value of the variable.
*/
public void setValue(final String value) {
this.value = value;
}
/**
* Returns a string representation of the object.
* @return A string representation of the variable.
*/
@Override
public String toString() {
final StringBuilder results = new StringBuilder();
results.append("Var: name=");
results.append(name);
results.append(" value=");
results.append(value);
results.append(" resource=");
results.append(resource);
if (resource) {
results.append(" bundle=");
results.append(bundle);
}
results.append(" jsType=");
results.append(jsType);
results.append("\n");
return results.toString();
}
}