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"}; } }