Sha256: ee81ea6f89bb1d913dc61c96531490126f796b9186befe4f1d092411869cf3ff
Contents?: true
Size: 1.71 KB
Versions: 54
Compression:
Stored size: 1.71 KB
Contents
module Searchlogic module CoreExt # Contains extensions for the Object class that Searchlogic uses. module Object # Searchlogic needs to know the expected type of the condition value so that it can properly cast # the value in the Searchlogic::Search object. For example: # # search = User.search(:id_gt => "1") # # You would expect this: # # search.id_gt => 1 # # Not this: # # search.id_gt => "1" # # Parameter values from forms are ALWAYS strings, so we have to cast them. Just like ActiveRecord # does when you instantiate a new User object. # # The problem is that ruby has no variable types, so Searchlogic needs to know what type you are expecting # for your named scope. So instead of this: # # named_scope :id_gt, lambda { |value| {:conditions => ["id > ?", value]} } # # You need to do this: # # named_scope :id_gt, searchlogic_lambda(:integer) { |value| {:conditions => ["id > ?", value]} } # # If you are wanting a string, you don't have to do anything, because Searchlogic assumes you want a string. # If you want something else, you need to specify it as I did in the above example. Comments are appreciated # on this, if you know of a better solution please let me know. But this is the best I could come up with, # without being intrusive and altering default behavior. def searchlogic_lambda(type = :string, options = {}, &block) proc = lambda(&block) proc.searchlogic_options ||= {} proc.searchlogic_options[:type] = type proc.searchlogic_options.merge!(options) proc end end end end
Version data entries
54 entries across 54 versions & 8 rubygems