Sha256: ec9e390b1513a620986da03953e42d9d6c2a87eb552237346c092d58320387b0
Contents?: true
Size: 1.27 KB
Versions: 2
Compression:
Stored size: 1.27 KB
Contents
class Query class << self # Returns a Ferret::Query from a raw String query. def extract_from(raw_query) parser.parse(convert_to_english(raw_query)) end # Returns terms related to content. Useful for cache highlighting def content_terms(raw_query) Query.extract_from(raw_query).terms(Indexer.index.searcher).select{|term| term.field==:content}.collect{|term| term.text}.uniq end private # Converts query keywords to english so they can be parsed by Ferret. def convert_to_english(raw_query) to_en={ /\b#{:AND.l}\b/=>'AND', /\b#{:OR.l}\b/=>'OR', /\b#{:NOT.l}\b/=>'NOT', /(#{:filename.l}):/=>'filename:', /(#{:filetype.l}):/=>'filetype:', /#{:content.l}:/ => 'content:', /(#{:modified.l}):/ => 'modified:', /(#{:language.l}):/ => 'language:', /\b#{:LIKE.l}\s+(\S+)/=>'\1~' } to_en.inject(raw_query){|mem,non_english_to_english_keyword| mem.gsub(*non_english_to_english_keyword) } end # Instantiates a QueryParser once, and keeps it in cache. def parser @@parser ||= Ferret::QueryParser.new(:fields => [:content, :filename, :basename, :filetype, :modified], :or_default => false, :analyzer=>Picolena::Analyzer) end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
picolena-0.1.8 | lib/picolena/templates/app/models/query.rb |
picolena-0.2.0 | lib/picolena/templates/app/models/query.rb |