require 'dm-core' module DataMapper class Property class Flag < Integer accept_options :flags attr_reader :flag_map def self.[](*values) klass = ::Class.new(self) klass.flags(values) klass end def initialize(model, name, options = {}, type = nil) super @flag_map = {} flags = options.fetch(:flags, self.class.flags) flags.each_with_index do |flag, i| flag_map[i] = flag end end def custom? true end def load(value) return [] if value.nil? || value <= 0 begin matches = [] 0.upto(flag_map.size - 1) do |i| matches << flag_map[i] if value[i] == 1 end matches.compact rescue TypeError, Errno::EDOM [] end end def dump(value) return if value.nil? flags = Array(value).map { |flag| flag.to_sym }.flatten flag_map.invert.values_at(*flags).compact.inject(0) { |sum, i| sum += 1 << i } end def typecast(value) case value when nil then nil when ::Array then value.map {|v| v.to_sym} else [value.to_sym] end end end # class Flag end # class Property end # module DataMapper