lib/sup/modes/search-results-mode.rb in sup-0.3 vs lib/sup/modes/search-results-mode.rb in sup-0.4

- old
+ new

@@ -1,33 +1,36 @@ module Redwood class SearchResultsMode < ThreadIndexMode - def initialize qobj + def initialize qobj, qopts = nil @qobj = qobj - super [], { :qobj => @qobj } + @qopts = qopts + + super [], { :qobj => @qobj }.merge(@qopts) end register_keymap do |k| k.add :refine_search, "Refine search", '.' end def refine_search query = BufferManager.ask :search, "query: ", (@qobj.to_s + " ") return unless query && query !~ /^\s*$/ - SearchResultsMode.spawn_from_query query + SearchResultsMode.spawn_from_query query, @qopts end ## a proper is_relevant? method requires some way of asking ferret ## if an in-memory object satisfies a query. i'm not sure how to do ## that yet. in the worst case i can make an in-memory index, add ## the message, and search against it to see if i have > 0 results, ## but that seems pretty insane. def self.spawn_from_query text begin - qobj = Index.parse_user_query_string(text) or return + qobj, extraopts = Index.parse_user_query_string(text) + return unless qobj short_text = text.length < 20 ? text : text[0 ... 20] + "..." - mode = SearchResultsMode.new qobj + mode = SearchResultsMode.new qobj, extraopts BufferManager.spawn "search: \"#{short_text}\"", mode mode.load_threads :num => mode.buffer.content_height rescue Ferret::QueryParser::QueryParseException => e BufferManager.flash "Couldn't parse query." end