class Protobuf::Field::FieldArray

def <<(val)

def <<(val)
  super(normalize(val)) unless val.nil?
end

def []=(nth, val)

def []=(nth, val)
  super(nth, normalize(val)) unless val.nil?
end

def initialize(field)

def initialize(field)
  @field = field
end

def normalize(value)

def normalize(value)
  value = value.to_proto if value.respond_to?(:to_proto)
  fail TypeError, "Unacceptable value #{value} for field #{field.name} of type #{field.type_class}" unless field.acceptable?(value)
  if field.is_a?(::Protobuf::Field::EnumField)
    field.type_class.fetch(value)
  elsif field.is_a?(::Protobuf::Field::MessageField) && value.is_a?(field.type_class)
    value
  elsif field.is_a?(::Protobuf::Field::MessageField) && value.respond_to?(:to_hash)
    field.type_class.new(value.to_hash)
  else
    value
  end
end

def push(val)

def push(val)
  super(normalize(val)) unless val.nil?
end

def raise_type_error(val)

def raise_type_error(val)
  fail TypeError, <<-TYPE_ERROR
    Expected repeated value of type '#{field.type_class}'
    Got '#{val.class}' for repeated protobuf field #{field.name}
  TYPE_ERROR
end

def replace(val)

def replace(val)
  raise_type_error(val) unless val.is_a?(Array)
  val.map! { |v| normalize(v) }
  super(val)
end

def to_hash_value

The value in this case would be an array.
Return a hash-representation of the given values for this field type.
def to_hash_value
  map do |value|
    value.respond_to?(:to_hash_value) ? value.to_hash_value : value
  end
end

def to_json_hash_value

The value in this case would be an array.
that is safe to convert to JSON.
Return a hash-representation of the given values for this field type
def to_json_hash_value
  if field.respond_to?(:json_encode)
    map do |value|
      field.json_encode(value)
    end
  else
    map do |value|
      value.respond_to?(:to_json_hash_value) ? value.to_json_hash_value : value
    end
  end
end

def to_s

def to_s
  "[#{field.name}]"
end

def unshift(val)

def unshift(val)
  super(normalize(val)) unless val.nil?
end