Sha256: b0168fe300710939eb5c054516dccfe68e5d52e582b0fd0be38d394e7fa6cb08

Contents?: true

Size: 1.28 KB

Versions: 3

Compression:

Stored size: 1.28 KB

Contents

module Sequel
  module Plugins
    # The subset_conditions plugin creates an additional *_conditions method
    # for every subset created, which returns the filter conditions the subset
    # uses.  This can be useful if you want to use the conditions for a separate
    # filter or combine them with OR.
    #
    # Usage:
    #
    #   # Add subset_conditions in the Album class
    #   Album.plugin :subset_conditions
    #
    #   # This will now create a published_conditions method
    #   Album.subset :published, :published => true
    #
    #   Album.where(Album.published_conditions).sql
    #   # SELECT * FROM albums WHERE (published IS TRUE)
    #
    #   Album.exclude(Album.published_conditions).sql
    #   # SELECT * FROM albums WHERE (published IS NOT TRUE)
    #
    #   Album.where(Sequel.|(Album.published_conditions, :ready=>true)).sql
    #   # SELECT * FROM albums WHERE ((published IS TRUE) OR (ready IS TRUE))
    module SubsetConditions
      module ClassMethods
        # Also create a method that returns the conditions the filter uses.
        def subset(name, *args, &block)
          super
          cond = args
          cond = cond.first if cond.size == 1
          def_dataset_method(:"#{name}_conditions"){filter_expr(cond, &block)}
        end
      end
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
sequel-4.30.0 lib/sequel/plugins/subset_conditions.rb
sequel-4.29.0 lib/sequel/plugins/subset_conditions.rb
sequel-4.28.0 lib/sequel/plugins/subset_conditions.rb