Commit 6e0a6d1c authored by reed-lau's avatar reed-lau Committed by Adam Cozzette

Add move constructor for Reflection's SetString

parent 43156775
...@@ -1223,6 +1223,38 @@ void Reflection::SetString(Message* message, const FieldDescriptor* field, ...@@ -1223,6 +1223,38 @@ void Reflection::SetString(Message* message, const FieldDescriptor* field,
} }
void Reflection::SetString(Message* message, const FieldDescriptor* field,
const std::string&& value) const {
USAGE_CHECK_ALL(SetString, SINGULAR, STRING);
if (field->is_extension()) {
return MutableExtensionSet(message)->SetString(field->number(),
field->type(), value, field);
} else {
switch (field->options().ctype()) {
default: // TODO(kenton): Support other string reps.
case FieldOptions::STRING: {
if (IsInlined(field)) {
MutableField<InlinedStringField>(message, field)
->SetNoArena(nullptr, value);
break;
}
const std::string* default_ptr =
&DefaultRaw<ArenaStringPtr>(field).Get();
if (field->containing_oneof() && !HasOneofField(*message, field)) {
ClearOneof(message, field->containing_oneof());
MutableField<ArenaStringPtr>(message, field)
->UnsafeSetDefault(default_ptr);
}
*(MutableField<ArenaStringPtr>(message, field)
->Mutable(default_ptr, GetArena(message))) = value;
break;
}
}
}
}
std::string Reflection::GetRepeatedString(const Message& message, std::string Reflection::GetRepeatedString(const Message& message,
const FieldDescriptor* field, const FieldDescriptor* field,
int index) const { int index) const {
......
...@@ -540,6 +540,8 @@ class PROTOBUF_EXPORT Reflection final { ...@@ -540,6 +540,8 @@ class PROTOBUF_EXPORT Reflection final {
bool value) const; bool value) const;
void SetString(Message* message, const FieldDescriptor* field, void SetString(Message* message, const FieldDescriptor* field,
const std::string& value) const; const std::string& value) const;
void SetString(Message* message, const FieldDescriptor* field,
const std::string&& value) const;
void SetEnum(Message* message, const FieldDescriptor* field, void SetEnum(Message* message, const FieldDescriptor* field,
const EnumValueDescriptor* value) const; const EnumValueDescriptor* value) const;
// Set an enum field's value with an integer rather than EnumValueDescriptor. // Set an enum field's value with an integer rather than EnumValueDescriptor.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment