/*
* Copyright (2005-2012) Schibsted ASA
* This file is part of Possom.
*
* Possom is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Possom is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Possom. If not, see <http://www.gnu.org/licenses/>.
*/
package no.sesat.search.query.transform;
import no.sesat.search.query.transform.AbstractQueryTransformerConfig.Controller;
import no.sesat.search.site.config.AbstractDocumentFactory;
import no.sesat.search.site.config.AbstractDocumentFactory.ParseType;
import org.apache.log4j.Logger;
import org.w3c.dom.Element;
/**
* Configuration bean for RegexpQueryTransformer.
*
* A transformer to apply a regular expression to each term.
*
* If the regular expression has a capturing group,
* it is only that group that is replacement,
* not the match to the whole regular expression.
* <b>It is therefore critical to use non-capturing groups for |?+* operations in the expressions.</b>
*
* @version $Id$
*
*
*/
@Controller("RegexpQueryTransformer")
public final class RegexpQueryTransformerConfig extends AbstractQueryTransformerConfig {
private static final Logger LOG = Logger.getLogger(RegexpQueryTransformerConfig.class);
/**
* Holds value of property regexp.
*/
private String regexp;
/**
* Holds value of property replacement.
*/
private String replacement = "";
@Override
public RegexpQueryTransformerConfig readQueryTransformer(final Element qt){
super.readQueryTransformer(qt);
AbstractDocumentFactory.fillBeanProperty(this, null, "regexp", ParseType.String, qt, "");
AbstractDocumentFactory.fillBeanProperty(this, null, "replacement", ParseType.String, qt, "");
return this;
}
/**
* Setter for property regexp.
* @param regexp New value of property regexp.
*/
public void setRegexp(final String regexp) {
this.regexp = regexp;
}
/** @see #setRegexp(java.lang.String)
*
* @return the regular expression
*/
public String getRegexp(){
return regexp;
}
/**
* Setter for property replacement.
* @param replacement New value of property replacement.
*/
public void setReplacement(final String replacement) {
this.replacement = replacement;
}
/** @see #setReplacement(java.lang.String)
*
* @return the replacement string
*/
public String getReplacement(){
return replacement;
}
}