class Protobuf::Field::BytesField

def self.default

def self.default
  ''
end

def acceptable?(val)

def acceptable?(val)
  val.is_a?(String) || val.nil? || val.is_a?(Symbol) || val.is_a?(::Protobuf::Message)
end

def coerce!(value)

def coerce!(value)
  case value
  when String, Symbol
    "#{value}"
  when NilClass
    nil
  when ::Protobuf::Message
    value.dup
  else
    fail TypeError, "Unacceptable value #{value} for field #{name} of type #{type_class}"
  end
end

def decode(bytes)

def decode(bytes)
  bytes_to_decode = bytes.dup
  bytes_to_decode.force_encoding(::Protobuf::Field::BytesField::BYTES_ENCODING)
  bytes_to_decode
end

def encode(value)

def encode(value)
  if value.is_a?(::Protobuf::Message)
    value_to_encode = value.encode
  else
    value_to_encode = value.dup
  end
  value_to_encode.force_encoding(::Protobuf::Field::BytesField::BYTES_ENCODING)
  string_size = ::Protobuf::Field::VarintField.encode(value_to_encode.size)
  "#{string_size}#{value_to_encode}"
end

def wire_type

def wire_type
  ::Protobuf::WireType::LENGTH_DELIMITED
end