package org.genedb.querying.tmpquery;
import org.genedb.querying.core.QueryClass;
import org.genedb.querying.core.QueryParam;
import org.apache.lucene.index.Term;
import org.apache.lucene.search.BooleanQuery;
import org.apache.lucene.search.TermQuery;
import org.apache.lucene.search.WildcardQuery;
import org.apache.lucene.search.BooleanClause.Occur;
import org.springframework.util.StringUtils;
import java.util.List;
@QueryClass(
title="Coding and pseudogenes by protein length",
shortDesc="Get a list of transcripts ",
longDesc=""
)
public class SimpleNameQuery extends OrganismLuceneQuery {
@QueryParam(
order=1,
title="The search string"
)
private String search = "";
@Override
protected String getluceneIndexName() {
return "org.gmod.schema.mapped.Feature";
}
@Override
public String getQueryDescription() {
return "Searches for features whose name matches the input.";
}
@Override
public String getQueryName() {
return "Simple Name";
}
@Override
protected void getQueryTermsWithoutOrganisms(List<org.apache.lucene.search.Query> queries) {
BooleanQuery bq = new BooleanQuery();
if(StringUtils.containsWhitespace(search)) {
for(String term : search.split(" ")) {
bq.add(new TermQuery(new Term("product",term.toLowerCase()
)), Occur.SHOULD);
}
} else {
if (search.indexOf('*') == -1) {
bq.add(new TermQuery(new Term("allNames",search.toLowerCase())), Occur.SHOULD);
} else {
bq.add(new WildcardQuery(new Term("allNames", search.toLowerCase())), Occur.SHOULD);
}
}
queries.add(bq);
queries.add(productiveTranscriptQuery);
}
// ------ Autogenerated code below here
public void setSearch(String search) {
this.search = search;
}
public String getSearch() {
return search;
}
@Override
protected String[] getParamNames() {
return new String[] {"search", "product", "allNames", "pseudogenes"};
}
}