class Quickbooks::Model::BaseModel

def as_json(options = nil)

def as_json(options = nil)
  options = {} if options.nil?
  options = options.dup if options.frozen?
  except_conditions = ["roxml_references"]
  except_conditions << options[:except]
  options[:except] = except_conditions.flatten.uniq.compact
  super(options)
end

def attribute_names

def attribute_names
  roxml_attrs.map(&:accessor)
end

def attributes

def attributes
  attributes = self.class.attribute_names.map do |name|
    value = public_send(name)
    value = value.attributes if value.respond_to?(:attributes)
    [name, value]
  end
  HashWithIndifferentAccess[attributes]
end

def attrs_with_types

def attrs_with_types
  roxml_attrs.map do |attr|
    "#{attr.accessor}:" +
      "#{attr.class.block_shorthands.invert[attr.blocks.last]}:#{attr.sought_type}"
  end
end

def initialize(attributes={})

def initialize(attributes={})
  attributes.each {|key, value| public_send("#{key}=", value) }
end

def inspect

def inspect
  # it would be nice if we could inspect all the children,
  # but it's likely to blow the stack in some cases
  "#<#{self.class} " +
  "#{attributes.map{|k,v| "#{k}: #{v.nil? ? 'nil' : v.to_s }"}.join ", "}>"
end

def inspect

def inspect
  "#{super}(#{attrs_with_types.join " "})"
end

def reference_attrs

def reference_attrs
  matches = roxml_attrs.select{|attr| attr.sought_type == Quickbooks::Model::BaseReference}.map{|attr| attr.accessor}
end

def reference_setters(*args)

end
self.discount_ref = BaseReference.new(id)
def discount_id=(id)
Would generate a method like:
reference_setters :discount_ref
Example:
Automatically generate an ID setter.
def reference_setters(*args)
  references = args.empty? ? reference_attrs : args
  references.each do |attribute|
    last_index = attribute.to_s.rindex('_ref')
    field_name = !last_index.nil? ? attribute.to_s.slice(0, last_index) : attribute
    method_name = "#{field_name}_id=".to_sym
    unless instance_methods(false).include?(method_name)
      method_definition = <<-METH
      def #{method_name}(id)
        self.#{attribute} = BaseReference.new(id)
      end
      METH
      class_eval(method_definition)
    end
  end
end

def resource_for_collection

These can be over-ridden in each model object as needed
def resource_for_collection
  self::REST_RESOURCE
end

def resource_for_singular

def resource_for_singular
  self::REST_RESOURCE
end

def to_xml_big_decimal

def to_xml_big_decimal
  Proc.new { |val| val.nil? ? nil : val.to_f }
end

def to_xml_inject_ns(model_name, options = {})

insert the static namespaces in the first opening tag that matches the +model_name+
ROXML doesnt insert the namespaces into generated XML so we need to do it ourselves
def to_xml_inject_ns(model_name, options = {})
  s = StringIO.new
  xml = to_xml(options).write_to(s, :indent => 0, :indent_text => '')
  destination_name = options.fetch(:destination_name, nil)
  destination_name ||= model_name
  sparse = options.fetch(:sparse, false)
  sparse_string = %{sparse="#{sparse}"}
  step1 = s.string.sub("<#{model_name}>", "<#{destination_name} #{Quickbooks::Service::BaseService::XML_NS} #{sparse_string}>")
  step2 = step1.sub("</#{model_name}>", "</#{destination_name}>")
  step2
end

def to_xml_ns(options = {})

def to_xml_ns(options = {})
  to_xml_inject_ns(self.class::XML_NODE, options)
end