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

org.ocpsoft.rewrite.param.ParameterizedPatternBuilder Maven / Gradle / Ivy

There is a newer version: 10.0.2.Final
Show newest version
/*
 * Copyright 2013 Lincoln Baxter, III
 * 
 * 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 org.ocpsoft.rewrite.param;

import java.util.List;
import java.util.Map;
import java.util.regex.Pattern;

import org.ocpsoft.rewrite.context.EvaluationContext;
import org.ocpsoft.rewrite.event.Rewrite;
import org.ocpsoft.rewrite.exception.ParameterizationException;

/**
 * 
 * A {@link Parameterized} regular expression {@link Pattern}.
 * 
 * @author Lincoln Baxter, III
 * 
 */
public interface ParameterizedPatternBuilder extends ParameterizedPattern
{
   /**
    * Return the {@link ParameterizedPatternParser} corresponding to the pattern with which this
    * {@link ParameterizedPatternBuilder} was constructed.
    */
   ParameterizedPatternParser getParser();

   /**
    * Use this expression to build a {@link String} from this expression's pattern. Extract needed values from the
    * {@link EvaluationContext}.
    * 
    * @throws {@link ParameterizationException} when a required parameter is missing.
    */
   String build(Rewrite event, EvaluationContext context, Transposition transposition)
            throws ParameterizationException;

   /**
    * Use this expression to build a {@link String} from given values.
    * 
    * @throws {@link ParameterizationException} when a required parameter is missing.
    */
   String build(Map parameters) throws ParameterizationException;

   /**
    * Use this expression's pattern to build a {@link String} from the given values. Enforces that the number of values
    * passed must equal the number of expression parameters. Does not apply any configured {@link Transposition} instances.
    * 
    * @throws {@link ParameterizationException} when a required parameter is missing.
    */
   String build(List values) throws ParameterizationException;
}