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

org.apache.lucene.sandbox.queries.regex.RegexQuery Maven / Gradle / Ivy

There is a newer version: 9.11.1
Show newest version
package org.apache.lucene.sandbox.queries.regex;

/*
 * 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.
 */

import org.apache.lucene.search.MultiTermQuery;
import org.apache.lucene.index.FilteredTermsEnum;
import org.apache.lucene.search.RegexpQuery; // javadoc
import org.apache.lucene.index.Term;
import org.apache.lucene.index.Terms;
import org.apache.lucene.util.AttributeSource;
import org.apache.lucene.util.ToStringUtils;

import java.io.IOException;

/** Implements the regular expression term search query.
 * The expressions supported depend on the regular expression implementation
 * used by way of the {@link RegexCapabilities} interface.
 * 

* NOTE: You may wish to consider using the regex query support * in {@link RegexpQuery} instead, as it has better performance. * * @see RegexTermsEnum * @deprecated Use core's regex query. */ @Deprecated public class RegexQuery extends MultiTermQuery implements RegexQueryCapable { private RegexCapabilities regexImpl = new JavaUtilRegexCapabilities(); private Term term; /** Constructs a query for terms matching term. */ public RegexQuery(Term term) { super(term.field()); this.term = term; } public Term getTerm() { return term; } @Override public void setRegexImplementation(RegexCapabilities impl) { this.regexImpl = impl; } @Override public RegexCapabilities getRegexImplementation() { return regexImpl; } @Override protected FilteredTermsEnum getTermsEnum(Terms terms, AttributeSource atts) throws IOException { return new RegexTermsEnum(terms.iterator(), term, regexImpl); } @Override public String toString(String field) { StringBuilder buffer = new StringBuilder(); if (!term.field().equals(field)) { buffer.append(term.field()); buffer.append(":"); } buffer.append(term.text()); return buffer.toString(); } @Override public int hashCode() { final int prime = 31; int result = super.hashCode(); result = prime * result + ((regexImpl == null) ? 0 : regexImpl.hashCode()); result = prime * result + ((term == null) ? 0 : term.hashCode()); return result; } @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (!super.equals(obj)) { return false; } if (getClass() != obj.getClass()) { return false; } RegexQuery other = (RegexQuery) obj; if (regexImpl == null) { if (other.regexImpl != null) { return false; } } else if (!regexImpl.equals(other.regexImpl)) { return false; } if (term == null) { if (other.term != null) { return false; } } else if (!term.equals(other.term)) { return false; } return true; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy