Sha256: 6a4089b5e55fd2c77bc2dc69a121265cde9104ea292073976304628c527cdd8b
Contents?: true
Size: 1.71 KB
Versions: 7
Compression:
Stored size: 1.71 KB
Contents
require 'representable' require 'representable/bindings/hash_bindings' module Representable # The generic representer. Brings #to_hash and #from_hash to your object. # If you plan to write your own representer for a new media type, try to use this module (e.g., check how JSON reuses Hash's internal # architecture). module Hash def self.included(base) base.class_eval do include Representable # either in Hero or HeroRepresentation. extend ClassMethods register_feature Representable::Hash end end module ClassMethods def collection_representer_class Collection end end # Note: `#from_hash` still does _not_ stringify incoming hashes. This is per design: Representable is not made for hashes, only, # but for any arbitrary data structure. A generic `key.to_s` with non-hash data would result in weird issues. # I decided it's more predictable to require the user to provide stringified keys. def from_hash(data, options={}, binding_builder=PropertyBinding) data = filter_wrap(data, options) update_properties_from(data, options, binding_builder) end def to_hash(options={}, binding_builder=PropertyBinding) hash = create_representation_with({}, options, binding_builder) return hash unless wrap = options[:wrap] || representation_wrap(options) {wrap => hash} end private def filter_wrap(data, options) return data unless wrap = options[:wrap] || representation_wrap(options) filter_wrap_for(data, wrap) end def filter_wrap_for(data, wrap) data[wrap.to_s] || {} # DISCUSS: don't initialize this more than once. # TODO: this should be done with #read. end end end
Version data entries
7 entries across 7 versions & 1 rubygems