Sha256: 68cf061864dc04546dc1b0dca47ed4dffc5d7d7083fefe110aa8ec16d6b3f7e1
Contents?: true
Size: 1.3 KB
Versions: 2
Compression:
Stored size: 1.3 KB
Contents
require 'betterdocs/dsl/representer' require 'betterdocs/dsl/common' require 'betterdocs/dsl/naming' require 'betterdocs/dsl/json_type_mapper' class Betterdocs::Dsl::Result::Property < Betterdocs::Dsl::Representer extend Tins::DSLAccessor include Betterdocs::Dsl::Common include Betterdocs::Dsl::Naming dsl_accessor :represent_with dsl_accessor :description, 'TODO' dsl_accessor :example, 'TODO' dsl_accessor :types do [] end def initialize(representer, name, options, &block) super types Betterdocs::Dsl::JsonTypeMapper.map_types(types) if sr = sub_representer? sr < Betterdocs::ResultRepresenter or raise TypeError, "#{sr.inspect} is not a Betterdocs::Result subclass" end end def sub_representer? represent_with end def actual_property_name (options[:as] || name).to_s end def assign(result, object) assign?(object) or return result[actual_property_name] = compute_value(object) end def compute_value(object) value = object.__send__(name) value.nil? and return if represent_with represent_with.hashify(value) elsif ActiveSupport::TimeWithZone === value value.extend Betterdocs::JsonTimeWithZone else value end end def add_to_collector(collector) collector.properties[name] = self end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
betterdocs-0.4.0 | lib/betterdocs/dsl/result/property.rb |
betterdocs-0.3.0 | lib/betterdocs/dsl/result/property.rb |