001 /*
002 * Copyright 2002-2004 the original author or authors.
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License"); you may not
005 * use this file except in compliance with the License. You may obtain a copy of
006 * the License at
007 *
008 * http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
012 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
013 * License for the specific language governing permissions and limitations under
014 * the License.
015 */
016 package org.springframework.rules.constraint;
017
018 import java.util.regex.Matcher;
019 import java.util.regex.Pattern;
020
021 import org.springframework.rules.constraint.Constraint;
022 import org.springframework.rules.reporting.TypeResolvable;
023 import org.springframework.rules.reporting.TypeResolvableSupport;
024
025 /**
026 * A constraint based on a regular expression pattern.
027 *
028 * @see TypeResolvable
029 * @see Pattern
030 *
031 * @author Keith Donald
032 */
033 public class RegexpConstraint extends TypeResolvableSupport implements Constraint {
034
035 private Pattern pattern;
036
037 /**
038 * Creates a RegexpConstraint with the provided regular expression pattern
039 * string.
040 *
041 * @param regex The regular expression
042 */
043 public RegexpConstraint(String regex) {
044 this(regex, null);
045 }
046
047 /**
048 * Creates a RegexpConstraint with the provided regular expression pattern
049 * string and sets the type of the constraint to provide specific messages.
050 *
051 * @param regex the regular expression.
052 * @param type id used to fetch the message.
053 */
054 public RegexpConstraint(String regex, String type) {
055 super(type);
056 pattern = Pattern.compile(regex);
057 }
058
059 /**
060 * Test if the argument matches the pattern.
061 */
062 public boolean test(Object argument) {
063 if (argument == null) {
064 argument = "";
065 }
066 Matcher m = pattern.matcher((CharSequence) argument);
067 return m.matches();
068 }
069
070 public String toString() {
071 return getDefaultMessage() + " " + pattern.pattern();
072 }
073 }