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 CurationQuery 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 getQueryName() { return "Curation and Comments"; } @Override protected void getQueryTermsWithoutOrganisms(List<org.apache.lucene.search.Query> queries) { BooleanQuery bq = new BooleanQuery(); if(StringUtils.containsWhitespace(search)) { BooleanQuery bq_sub = new BooleanQuery(); for(String term : search.split(" ")) { bq_sub.add(new TermQuery(new Term("allCuration",term.toLowerCase())), Occur.MUST); } bq.add(bq_sub, Occur.MUST); } else { if (search.indexOf('*') == -1) { bq.add(new TermQuery(new Term("allCuration",search.toLowerCase())), Occur.MUST); } else { bq.add(new WildcardQuery(new Term("allCuration", search.toLowerCase())), Occur.MUST); } } // TODO determine the cvterm id programmatically bq.add(new TermQuery(new Term("type.cvTermId", "191")), Occur.MUST); 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"}; } @Override public String getQueryDescription() { return "Searches curation and comments."; } }