Sha256: caa5d984e95356d02816ee5031cce9fd5844081bab38360484108dbaacbc4ce6

Contents?: true

Size: 1.84 KB

Versions: 4

Compression:

Stored size: 1.84 KB

Contents

# TODO: move to dm-more/dm-migrations

module DataMapper
  class TypeMap

    attr_accessor :parent, :chains

    def initialize(parent = nil, &blk)
      @parent, @chains = parent, {}

      blk.call(self) unless blk.nil?
    end

    def map(type)
      @chains[type] ||= TypeChain.new
    end

    def lookup(type)
      if type_mapped?(type)
        lookup_from_map(type)
      else
        lookup_by_type(type)
      end
    end

    def lookup_from_map(type)
      lookup_from_parent(type).merge(map(type).translate)
    end

    def lookup_from_parent(type)
      if !@parent.nil? && @parent.type_mapped?(type)
        @parent[type]
      else
        {}
      end
    end

    # @raise <DataMapper::TypeMap::Error> if the type is not a default primitive or has a type map entry.
    def lookup_by_type(type)
      raise DataMapper::TypeMap::Error.new(type) unless type.respond_to?(:primitive) && !type.primitive.nil?

      lookup(type.primitive).merge(Type::PROPERTY_OPTIONS.inject({}) {|h, k| h[k] = type.send(k); h})
    end

    alias [] lookup

    def type_mapped?(type)
      @chains.has_key?(type) || (@parent.nil? ? false : @parent.type_mapped?(type))
    end

    class TypeChain
      attr_accessor :primitive, :attributes

      def initialize
        @attributes = {}
      end

      def to(primitive)
        @primitive = primitive
        self
      end

      def with(attributes)
        raise "method 'with' expects a hash" unless attributes.kind_of?(Hash)
        @attributes.merge!(attributes)
        self
      end

      def translate
        @attributes.merge((@primitive.nil? ? {} : {:primitive => @primitive}))
      end
    end # class TypeChain

    class Error < StandardError
      def initialize(type)
        super("Type #{type} must have a default primitive or type map entry")
      end
    end
  end # class TypeMap
end # module DataMapper

Version data entries

4 entries across 4 versions & 3 rubygems

Version Path
datamapper-dm-core-0.9.11 lib/dm-core/type_map.rb
rpbertp13-dm-core-0.9.11.1 lib/dm-core/type_map.rb
rpbertp13-dm-core-0.9.11.2 lib/dm-core/type_map.rb
dm-core-0.9.11 lib/dm-core/type_map.rb