Sha256: f33c3288bd6e853a67c387acc85b03e09fa15b63bb13f4c6e1609f1e4ad7c0be
Contents?: true
Size: 1.68 KB
Versions: 5
Compression:
Stored size: 1.68 KB
Contents
require File.dirname(__FILE__) + '/simple_property' require File.dirname(__FILE__) + '/belongs_to_property' module CouchPotato module Persistence module Properties def self.included(base) base.extend ClassMethods base.class_eval do def self.properties @properties ||= {} @properties[self.name] ||= [] end end end module ClassMethods # returns all the property names of a model class that have been defined using the #property method # # example: # class Book # property :title # property :year # end # Book.property_names # => [:title, :year] def property_names properties.map(&:name) end def json_create(json) #:nodoc: return if json.nil? instance = super instance.send(:assign_attribute_copies_for_dirty_tracking) instance end # Declare a proprty on a model class. properties are not typed by default. You can use any of the basic types by JSON (String, Integer, Fixnum, Array, Hash). If you want a property to be of a custom class you have to define it using the :class option. # # example: # class Book # property :title # property :year # property :publisher, :class => Publisher # end def property(name, options = {}) clazz = options.delete(:class) properties << (clazz || SimpleProperty).new(self, name, options) end def belongs_to(name) #:nodoc: property name, :class => BelongsToProperty end end end end end
Version data entries
5 entries across 5 versions & 2 rubygems