org.apache.commons.validator.Var Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of commons-validator Show documentation
Show all versions of commons-validator Show documentation
Apache Commons Validator provides the building blocks for both client side validation and server side data validation.
It may be used standalone or with a framework like Struts.
/*
* 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 Field
for
* passing in information to a pluggable validator. Instances of this class are
* configured with a <var> xml element.
*
* @version $Revision: 1739356 $
*/
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 = null;
/**
* The key or value the variable.
*/
private String value = null;
/**
* The optional JavaScript type of the variable.
*/
private String jsType = null;
/**
* Whether the variable is a resource [false]
*/
private boolean resource = false;
/**
* The bundle for a variable (when resource = 'true').
*/
private String bundle = null;
/**
* Default Constructor.
*/
public Var() {
super();
}
/**
* 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(String name, String value, String jsType) {
this.name = name;
this.value = value;
this.jsType = jsType;
}
/**
* Gets the name of the variable.
* @return The name of the variable.
*/
public String getName() {
return this.name;
}
/**
* Sets the name of the variable.
* @param name The name of the variable.
*/
public void setName(String name) {
this.name = name;
}
/**
* Gets the value of the variable.
* @return The value of the variable.
*/
public String getValue() {
return this.value;
}
/**
* Sets the value of the variable.
* @param value The value of the variable.
*/
public void setValue(String value) {
this.value = value;
}
/**
* Tests whether or not the value is a resource key or literal value.
* @return true
if value is a resource key.
* @since Validator 1.2.0
*/
public boolean isResource() {
return this.resource;
}
/**
* Sets whether or not the value is a resource.
* @param resource If true indicates the value is a resource.
* @since Validator 1.2.0
*/
public void setResource(boolean resource) {
this.resource = resource;
}
/**
* Returns the resource bundle name.
* @return The bundle name.
* @since Validator 1.2.0
*/
public String getBundle() {
return this.bundle;
}
/**
* Sets the resource bundle name.
* @param bundle The new bundle name.
* @since Validator 1.2.0
*/
public void setBundle(String bundle) {
this.bundle = bundle;
}
/**
* Gets the JavaScript type of the variable.
* @return The Javascript type of the variable.
*/
public String getJsType() {
return this.jsType;
}
/**
* Sets the JavaScript type of the variable.
* @param jsType The Javascript type of the variable.
*/
public void setJsType(String jsType) {
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(CloneNotSupportedException e) {
throw new RuntimeException(e.toString());
}
}
/**
* Returns a string representation of the object.
* @return A string representation of the variable.
*/
@Override
public String toString() {
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();
}
}