Commit bbd6dc6d authored by Hao Nguyen's avatar Hao Nguyen

Revert "Replaced all instances of Simple{IDF}toa with StrCat."

This reverts commit 029f2c7c.
parent 6b4b9869
...@@ -643,7 +643,7 @@ std::string DefaultValue(const Options& options, const FieldDescriptor* field) { ...@@ -643,7 +643,7 @@ std::string DefaultValue(const Options& options, const FieldDescriptor* field) {
} else if (value != value) { } else if (value != value) {
return "std::numeric_limits<double>::quiet_NaN()"; return "std::numeric_limits<double>::quiet_NaN()";
} else { } else {
return StrCat(value); return SimpleDtoa(value);
} }
} }
case FieldDescriptor::CPPTYPE_FLOAT: { case FieldDescriptor::CPPTYPE_FLOAT: {
...@@ -655,7 +655,7 @@ std::string DefaultValue(const Options& options, const FieldDescriptor* field) { ...@@ -655,7 +655,7 @@ std::string DefaultValue(const Options& options, const FieldDescriptor* field) {
} else if (value != value) { } else if (value != value) {
return "std::numeric_limits<float>::quiet_NaN()"; return "std::numeric_limits<float>::quiet_NaN()";
} else { } else {
std::string float_value = StrCat(value); std::string float_value = SimpleFtoa(value);
// If floating point value contains a period (.) or an exponent // If floating point value contains a period (.) or an exponent
// (either E or e), then append suffix 'f' to make it a float // (either E or e), then append suffix 'f' to make it a float
// literal. // literal.
......
...@@ -79,12 +79,12 @@ void EnumGenerator::Generate(io::Printer* printer) { ...@@ -79,12 +79,12 @@ void EnumGenerator::Generate(io::Printer* printer) {
printer->Print("[pbr::OriginalName(\"$original_name$\", PreferredAlias = false)] $name$ = $number$,\n", printer->Print("[pbr::OriginalName(\"$original_name$\", PreferredAlias = false)] $name$ = $number$,\n",
"original_name", original_name, "original_name", original_name,
"name", name, "name", name,
"number", StrCat(number)); "number", SimpleItoa(number));
} else { } else {
printer->Print("[pbr::OriginalName(\"$original_name$\")] $name$ = $number$,\n", printer->Print("[pbr::OriginalName(\"$original_name$\")] $name$ = $number$,\n",
"original_name", original_name, "original_name", original_name,
"name", name, "name", name,
"number", StrCat(number)); "number", SimpleItoa(number));
} }
} }
printer->Outdent(); printer->Outdent();
......
...@@ -62,14 +62,14 @@ void FieldGeneratorBase::SetCommonFieldVariables( ...@@ -62,14 +62,14 @@ void FieldGeneratorBase::SetCommonFieldVariables(
uint tag = internal::WireFormat::MakeTag(descriptor_); uint tag = internal::WireFormat::MakeTag(descriptor_);
uint8 tag_array[5]; uint8 tag_array[5];
io::CodedOutputStream::WriteTagToArray(tag, tag_array); io::CodedOutputStream::WriteTagToArray(tag, tag_array);
string tag_bytes = StrCat(tag_array[0]); string tag_bytes = SimpleItoa(tag_array[0]);
for (int i = 1; i < tag_size; i++) { for (int i = 1; i < tag_size; i++) {
tag_bytes += ", " + StrCat(tag_array[i]); tag_bytes += ", " + SimpleItoa(tag_array[i]);
} }
(*variables)["access_level"] = "public"; (*variables)["access_level"] = "public";
(*variables)["tag"] = StrCat(tag); (*variables)["tag"] = SimpleItoa(tag);
(*variables)["tag_size"] = StrCat(tag_size); (*variables)["tag_size"] = SimpleItoa(tag_size);
(*variables)["tag_bytes"] = tag_bytes; (*variables)["tag_bytes"] = tag_bytes;
(*variables)["property_name"] = property_name(); (*variables)["property_name"] = property_name();
...@@ -91,8 +91,8 @@ void FieldGeneratorBase::SetCommonFieldVariables( ...@@ -91,8 +91,8 @@ void FieldGeneratorBase::SetCommonFieldVariables(
(*variables)["has_not_property_check"] = "!" + (*variables)["has_property_check"]; (*variables)["has_not_property_check"] = "!" + (*variables)["has_property_check"];
(*variables)["other_has_not_property_check"] = "!" + (*variables)["other_has_property_check"]; (*variables)["other_has_not_property_check"] = "!" + (*variables)["other_has_property_check"];
if (presenceIndex_ != -1) { if (presenceIndex_ != -1) {
string hasBitsNumber = StrCat(presenceIndex_ / 32); string hasBitsNumber = SimpleItoa(presenceIndex_ / 32);
string hasBitsMask = StrCat(1 << (presenceIndex_ % 32)); string hasBitsMask = SimpleItoa(1 << (presenceIndex_ % 32));
(*variables)["has_field_check"] = "(_hasBits" + hasBitsNumber + " & " + hasBitsMask + ") != 0"; (*variables)["has_field_check"] = "(_hasBits" + hasBitsNumber + " & " + hasBitsMask + ") != 0";
(*variables)["set_has_field"] = "_hasBits" + hasBitsNumber + " |= " + hasBitsMask; (*variables)["set_has_field"] = "_hasBits" + hasBitsNumber + " |= " + hasBitsMask;
(*variables)["clear_has_field"] = "_hasBits" + hasBitsNumber + " &= ~" + hasBitsMask; (*variables)["clear_has_field"] = "_hasBits" + hasBitsNumber + " &= ~" + hasBitsMask;
...@@ -325,7 +325,7 @@ std::string FieldGeneratorBase::default_value(const FieldDescriptor* descriptor) ...@@ -325,7 +325,7 @@ std::string FieldGeneratorBase::default_value(const FieldDescriptor* descriptor)
} else if (std::isnan(value)) { } else if (std::isnan(value)) {
return "double.NaN"; return "double.NaN";
} }
return StrCat(value) + "D"; return SimpleDtoa(value) + "D";
} }
case FieldDescriptor::TYPE_FLOAT: { case FieldDescriptor::TYPE_FLOAT: {
float value = descriptor->default_value_float(); float value = descriptor->default_value_float();
...@@ -336,18 +336,18 @@ std::string FieldGeneratorBase::default_value(const FieldDescriptor* descriptor) ...@@ -336,18 +336,18 @@ std::string FieldGeneratorBase::default_value(const FieldDescriptor* descriptor)
} else if (std::isnan(value)) { } else if (std::isnan(value)) {
return "float.NaN"; return "float.NaN";
} }
return StrCat(value) + "F"; return SimpleFtoa(value) + "F";
} }
case FieldDescriptor::TYPE_INT64: case FieldDescriptor::TYPE_INT64:
return StrCat(descriptor->default_value_int64()) + "L"; return SimpleItoa(descriptor->default_value_int64()) + "L";
case FieldDescriptor::TYPE_UINT64: case FieldDescriptor::TYPE_UINT64:
return StrCat(descriptor->default_value_uint64()) + "UL"; return SimpleItoa(descriptor->default_value_uint64()) + "UL";
case FieldDescriptor::TYPE_INT32: case FieldDescriptor::TYPE_INT32:
return StrCat(descriptor->default_value_int32()); return SimpleItoa(descriptor->default_value_int32());
case FieldDescriptor::TYPE_FIXED64: case FieldDescriptor::TYPE_FIXED64:
return StrCat(descriptor->default_value_uint64()) + "UL"; return SimpleItoa(descriptor->default_value_uint64()) + "UL";
case FieldDescriptor::TYPE_FIXED32: case FieldDescriptor::TYPE_FIXED32:
return StrCat(descriptor->default_value_uint32()); return SimpleItoa(descriptor->default_value_uint32());
case FieldDescriptor::TYPE_BOOL: case FieldDescriptor::TYPE_BOOL:
if (descriptor->default_value_bool()) { if (descriptor->default_value_bool()) {
return "true"; return "true";
...@@ -359,15 +359,15 @@ std::string FieldGeneratorBase::default_value(const FieldDescriptor* descriptor) ...@@ -359,15 +359,15 @@ std::string FieldGeneratorBase::default_value(const FieldDescriptor* descriptor)
case FieldDescriptor::TYPE_BYTES: case FieldDescriptor::TYPE_BYTES:
return GetBytesDefaultValueInternal(descriptor); return GetBytesDefaultValueInternal(descriptor);
case FieldDescriptor::TYPE_UINT32: case FieldDescriptor::TYPE_UINT32:
return StrCat(descriptor->default_value_uint32()); return SimpleItoa(descriptor->default_value_uint32());
case FieldDescriptor::TYPE_SFIXED32: case FieldDescriptor::TYPE_SFIXED32:
return StrCat(descriptor->default_value_int32()); return SimpleItoa(descriptor->default_value_int32());
case FieldDescriptor::TYPE_SFIXED64: case FieldDescriptor::TYPE_SFIXED64:
return StrCat(descriptor->default_value_int64()) + "L"; return SimpleItoa(descriptor->default_value_int64()) + "L";
case FieldDescriptor::TYPE_SINT32: case FieldDescriptor::TYPE_SINT32:
return StrCat(descriptor->default_value_int32()); return SimpleItoa(descriptor->default_value_int32());
case FieldDescriptor::TYPE_SINT64: case FieldDescriptor::TYPE_SINT64:
return StrCat(descriptor->default_value_int64()) + "L"; return SimpleItoa(descriptor->default_value_int64()) + "L";
default: default:
GOOGLE_LOG(FATAL)<< "Unknown field type."; GOOGLE_LOG(FATAL)<< "Unknown field type.";
return ""; return "";
...@@ -375,7 +375,7 @@ std::string FieldGeneratorBase::default_value(const FieldDescriptor* descriptor) ...@@ -375,7 +375,7 @@ std::string FieldGeneratorBase::default_value(const FieldDescriptor* descriptor)
} }
std::string FieldGeneratorBase::number() { std::string FieldGeneratorBase::number() {
return StrCat(descriptor_->number()); return SimpleItoa(descriptor_->number());
} }
std::string FieldGeneratorBase::capitalized_type_name() { std::string FieldGeneratorBase::capitalized_type_name() {
......
...@@ -137,7 +137,7 @@ void MessageGenerator::Generate(io::Printer* printer) { ...@@ -137,7 +137,7 @@ void MessageGenerator::Generate(io::Printer* printer) {
for (int i = 0; i < has_bit_field_count_; i++) { for (int i = 0; i < has_bit_field_count_; i++) {
// don't use arrays since all arrays are heap allocated, saving allocations // don't use arrays since all arrays are heap allocated, saving allocations
// use ints instead of bytes since bytes lack bitwise operators, saving casts // use ints instead of bytes since bytes lack bitwise operators, saving casts
printer->Print("private int _hasBits$i$;\n", "i", StrCat(i)); printer->Print("private int _hasBits$i$;\n", "i", SimpleItoa(i));
} }
WriteGeneratedCodeAttributes(printer); WriteGeneratedCodeAttributes(printer);
...@@ -149,10 +149,10 @@ void MessageGenerator::Generate(io::Printer* printer) { ...@@ -149,10 +149,10 @@ void MessageGenerator::Generate(io::Printer* printer) {
// Access the message descriptor via the relevant file descriptor or containing message descriptor. // Access the message descriptor via the relevant file descriptor or containing message descriptor.
if (!descriptor_->containing_type()) { if (!descriptor_->containing_type()) {
vars["descriptor_accessor"] = GetReflectionClassName(descriptor_->file()) vars["descriptor_accessor"] = GetReflectionClassName(descriptor_->file())
+ ".Descriptor.MessageTypes[" + StrCat(descriptor_->index()) + "]"; + ".Descriptor.MessageTypes[" + SimpleItoa(descriptor_->index()) + "]";
} else { } else {
vars["descriptor_accessor"] = GetClassName(descriptor_->containing_type()) vars["descriptor_accessor"] = GetClassName(descriptor_->containing_type())
+ ".Descriptor.NestedTypes[" + StrCat(descriptor_->index()) + "]"; + ".Descriptor.NestedTypes[" + SimpleItoa(descriptor_->index()) + "]";
} }
WriteGeneratedCodeAttributes(printer); WriteGeneratedCodeAttributes(printer);
...@@ -198,7 +198,7 @@ void MessageGenerator::Generate(io::Printer* printer) { ...@@ -198,7 +198,7 @@ void MessageGenerator::Generate(io::Printer* printer) {
"public const int $field_constant_name$ = $index$;\n", "public const int $field_constant_name$ = $index$;\n",
"field_name", fieldDescriptor->name(), "field_name", fieldDescriptor->name(),
"field_constant_name", GetFieldConstantName(fieldDescriptor), "field_constant_name", GetFieldConstantName(fieldDescriptor),
"index", StrCat(fieldDescriptor->number())); "index", SimpleItoa(fieldDescriptor->number()));
std::unique_ptr<FieldGeneratorBase> generator( std::unique_ptr<FieldGeneratorBase> generator(
CreateFieldGeneratorInternal(fieldDescriptor)); CreateFieldGeneratorInternal(fieldDescriptor));
generator->GenerateMembers(printer); generator->GenerateMembers(printer);
...@@ -221,7 +221,7 @@ void MessageGenerator::Generate(io::Printer* printer) { ...@@ -221,7 +221,7 @@ void MessageGenerator::Generate(io::Printer* printer) {
const FieldDescriptor* field = descriptor_->oneof_decl(i)->field(j); const FieldDescriptor* field = descriptor_->oneof_decl(i)->field(j);
printer->Print("$field_property_name$ = $index$,\n", printer->Print("$field_property_name$ = $index$,\n",
"field_property_name", GetPropertyName(field), "field_property_name", GetPropertyName(field),
"index", StrCat(field->number())); "index", SimpleItoa(field->number()));
} }
printer->Outdent(); printer->Outdent();
printer->Print("}\n"); printer->Print("}\n");
...@@ -306,7 +306,7 @@ void MessageGenerator::GenerateCloningCode(io::Printer* printer) { ...@@ -306,7 +306,7 @@ void MessageGenerator::GenerateCloningCode(io::Printer* printer) {
"public $class_name$($class_name$ other) : this() {\n"); "public $class_name$($class_name$ other) : this() {\n");
printer->Indent(); printer->Indent();
for (int i = 0; i < has_bit_field_count_; i++) { for (int i = 0; i < has_bit_field_count_; i++) {
printer->Print("_hasBits$i$ = other._hasBits$i$;\n", "i", StrCat(i)); printer->Print("_hasBits$i$ = other._hasBits$i$;\n", "i", SimpleItoa(i));
} }
// Clone non-oneof fields first // Clone non-oneof fields first
for (int i = 0; i < descriptor_->field_count(); i++) { for (int i = 0; i < descriptor_->field_count(); i++) {
...@@ -545,7 +545,7 @@ void MessageGenerator::GenerateMergingMethods(io::Printer* printer) { ...@@ -545,7 +545,7 @@ void MessageGenerator::GenerateMergingMethods(io::Printer* printer) {
printer->Print( printer->Print(
"$end_tag$:\n" "$end_tag$:\n"
" return;\n", " return;\n",
"end_tag", StrCat(end_tag_)); "end_tag", SimpleItoa(end_tag_));
} }
} }
for (int i = 0; i < fields_by_number().size(); i++) { for (int i = 0; i < fields_by_number().size(); i++) {
...@@ -562,13 +562,13 @@ void MessageGenerator::GenerateMergingMethods(io::Printer* printer) { ...@@ -562,13 +562,13 @@ void MessageGenerator::GenerateMergingMethods(io::Printer* printer) {
printer->Print( printer->Print(
"case $packed_tag$:\n", "case $packed_tag$:\n",
"packed_tag", "packed_tag",
StrCat( SimpleItoa(
internal::WireFormatLite::MakeTag( internal::WireFormatLite::MakeTag(
field->number(), field->number(),
internal::WireFormatLite::WIRETYPE_LENGTH_DELIMITED))); internal::WireFormatLite::WIRETYPE_LENGTH_DELIMITED)));
} }
printer->Print("case $tag$: {\n", "tag", StrCat(tag)); printer->Print("case $tag$: {\n", "tag", SimpleItoa(tag));
printer->Indent(); printer->Indent();
std::unique_ptr<FieldGeneratorBase> generator( std::unique_ptr<FieldGeneratorBase> generator(
CreateFieldGeneratorInternal(field)); CreateFieldGeneratorInternal(field));
......
...@@ -65,11 +65,11 @@ MessageFieldGenerator::MessageFieldGenerator(const FieldDescriptor* descriptor, ...@@ -65,11 +65,11 @@ MessageFieldGenerator::MessageFieldGenerator(const FieldDescriptor* descriptor,
internal::WireFormatLite::WIRETYPE_END_GROUP); internal::WireFormatLite::WIRETYPE_END_GROUP);
uint8 tag_array[5]; uint8 tag_array[5];
io::CodedOutputStream::WriteTagToArray(tag, tag_array); io::CodedOutputStream::WriteTagToArray(tag, tag_array);
string tag_bytes = StrCat(tag_array[0]); string tag_bytes = SimpleItoa(tag_array[0]);
for (int i = 1; i < tag_size; i++) { for (int i = 1; i < tag_size; i++) {
tag_bytes += ", " + StrCat(tag_array[i]); tag_bytes += ", " + SimpleItoa(tag_array[i]);
} }
variables_["end_tag"] = StrCat(tag); variables_["end_tag"] = SimpleItoa(tag);
variables_["end_tag_bytes"] = tag_bytes; variables_["end_tag_bytes"] = tag_bytes;
} }
} }
......
...@@ -186,7 +186,7 @@ void PrimitiveFieldGenerator::GenerateSerializedSizeCode(io::Printer* printer) { ...@@ -186,7 +186,7 @@ void PrimitiveFieldGenerator::GenerateSerializedSizeCode(io::Printer* printer) {
} else { } else {
printer->Print( printer->Print(
"size += $tag_size$ + $fixed_size$;\n", "size += $tag_size$ + $fixed_size$;\n",
"fixed_size", StrCat(fixedSize), "fixed_size", SimpleItoa(fixedSize),
"tag_size", variables_["tag_size"]); "tag_size", variables_["tag_size"]);
} }
printer->Outdent(); printer->Outdent();
......
...@@ -522,7 +522,7 @@ std::string DefaultValue(const FieldDescriptor* field, bool immutable, ...@@ -522,7 +522,7 @@ std::string DefaultValue(const FieldDescriptor* field, bool immutable,
} else if (value != value) { } else if (value != value) {
return "Double.NaN"; return "Double.NaN";
} else { } else {
return StrCat(value) + "D"; return SimpleDtoa(value) + "D";
} }
} }
case FieldDescriptor::CPPTYPE_FLOAT: { case FieldDescriptor::CPPTYPE_FLOAT: {
...@@ -534,7 +534,7 @@ std::string DefaultValue(const FieldDescriptor* field, bool immutable, ...@@ -534,7 +534,7 @@ std::string DefaultValue(const FieldDescriptor* field, bool immutable,
} else if (value != value) { } else if (value != value) {
return "Float.NaN"; return "Float.NaN";
} else { } else {
return StrCat(value) + "F"; return SimpleFtoa(value) + "F";
} }
} }
case FieldDescriptor::CPPTYPE_BOOL: case FieldDescriptor::CPPTYPE_BOOL:
......
...@@ -733,9 +733,9 @@ std::string EscapeBase64(const std::string& in) { ...@@ -733,9 +733,9 @@ std::string EscapeBase64(const std::string& in) {
return result; return result;
} }
// Post-process the result of StrCat to *exactly* match the original codegen's // Post-process the result of SimpleFtoa/SimpleDtoa to *exactly* match the
// formatting (which is just .toString() on java.lang.Double or // original codegen's formatting (which is just .toString() on java.lang.Double
// java.lang.Float). // or java.lang.Float).
std::string PostProcessFloat(std::string result) { std::string PostProcessFloat(std::string result) {
// If inf, -inf or nan, replace with +Infinity, -Infinity or NaN. // If inf, -inf or nan, replace with +Infinity, -Infinity or NaN.
if (result == "inf") { if (result == "inf") {
...@@ -787,12 +787,12 @@ std::string PostProcessFloat(std::string result) { ...@@ -787,12 +787,12 @@ std::string PostProcessFloat(std::string result) {
} }
std::string FloatToString(float value) { std::string FloatToString(float value) {
std::string result = StrCat(value); std::string result = SimpleFtoa(value);
return PostProcessFloat(result); return PostProcessFloat(result);
} }
std::string DoubleToString(double value) { std::string DoubleToString(double value) {
std::string result = StrCat(value); std::string result = SimpleDtoa(value);
return PostProcessFloat(result); return PostProcessFloat(result);
} }
......
...@@ -818,10 +818,10 @@ string DefaultValue(const FieldDescriptor* field) { ...@@ -818,10 +818,10 @@ string DefaultValue(const FieldDescriptor* field) {
return StrCat(field->default_value_uint64()) + "ULL"; return StrCat(field->default_value_uint64()) + "ULL";
case FieldDescriptor::CPPTYPE_DOUBLE: case FieldDescriptor::CPPTYPE_DOUBLE:
return HandleExtremeFloatingPoint( return HandleExtremeFloatingPoint(
StrCat(field->default_value_double()), false); SimpleDtoa(field->default_value_double()), false);
case FieldDescriptor::CPPTYPE_FLOAT: case FieldDescriptor::CPPTYPE_FLOAT:
return HandleExtremeFloatingPoint( return HandleExtremeFloatingPoint(
StrCat(field->default_value_float()), true); SimpleFtoa(field->default_value_float()), true);
case FieldDescriptor::CPPTYPE_BOOL: case FieldDescriptor::CPPTYPE_BOOL:
return field->default_value_bool() ? "YES" : "NO"; return field->default_value_bool() ? "YES" : "NO";
case FieldDescriptor::CPPTYPE_STRING: { case FieldDescriptor::CPPTYPE_STRING: {
......
...@@ -1267,7 +1267,7 @@ bool Parser::ParseDefaultAssignment( ...@@ -1267,7 +1267,7 @@ bool Parser::ParseDefaultAssignment(
double value; double value;
DO(ConsumeNumber(&value, "Expected number.")); DO(ConsumeNumber(&value, "Expected number."));
// And stringify it again. // And stringify it again.
default_value->append(StrCat(value)); default_value->append(SimpleDtoa(value));
break; break;
case FieldDescriptorProto::TYPE_BOOL: case FieldDescriptorProto::TYPE_BOOL:
......
...@@ -879,7 +879,7 @@ void GenerateMessageToPool(const string& name_prefix, const Descriptor* message, ...@@ -879,7 +879,7 @@ void GenerateMessageToPool(const string& name_prefix, const Descriptor* message,
"field", field->name(), "field", field->name(),
"key", ToUpper(key->type_name()), "key", ToUpper(key->type_name()),
"value", ToUpper(val->type_name()), "value", ToUpper(val->type_name()),
"number", StrCat(field->number()), "number", SimpleItoa(field->number()),
"other", EnumOrMessageSuffix(val, true)); "other", EnumOrMessageSuffix(val, true));
} else if (!field->containing_oneof()) { } else if (!field->containing_oneof()) {
printer->Print( printer->Print(
...@@ -888,7 +888,7 @@ void GenerateMessageToPool(const string& name_prefix, const Descriptor* message, ...@@ -888,7 +888,7 @@ void GenerateMessageToPool(const string& name_prefix, const Descriptor* message,
"field", field->name(), "field", field->name(),
"label", LabelForField(field), "label", LabelForField(field),
"type", ToUpper(field->type_name()), "type", ToUpper(field->type_name()),
"number", StrCat(field->number()), "number", SimpleItoa(field->number()),
"other", EnumOrMessageSuffix(field, true)); "other", EnumOrMessageSuffix(field, true));
} }
} }
...@@ -906,7 +906,7 @@ void GenerateMessageToPool(const string& name_prefix, const Descriptor* message, ...@@ -906,7 +906,7 @@ void GenerateMessageToPool(const string& name_prefix, const Descriptor* message,
"\\Google\\Protobuf\\Internal\\GPBType::^type^, ^number^^other^)\n", "\\Google\\Protobuf\\Internal\\GPBType::^type^, ^number^^other^)\n",
"field", field->name(), "field", field->name(),
"type", ToUpper(field->type_name()), "type", ToUpper(field->type_name()),
"number", StrCat(field->number()), "number", SimpleItoa(field->number()),
"other", EnumOrMessageSuffix(field, true)); "other", EnumOrMessageSuffix(field, true));
} }
printer->Print("->finish()\n"); printer->Print("->finish()\n");
......
...@@ -250,7 +250,7 @@ std::string StringifyDefaultValue(const FieldDescriptor& field) { ...@@ -250,7 +250,7 @@ std::string StringifyDefaultValue(const FieldDescriptor& field) {
// infinity * 0 = nan // infinity * 0 = nan
return "(1e10000 * 0)"; return "(1e10000 * 0)";
} else { } else {
return "float(" + StrCat(value) + ")"; return "float(" + SimpleDtoa(value) + ")";
} }
} }
case FieldDescriptor::CPPTYPE_FLOAT: { case FieldDescriptor::CPPTYPE_FLOAT: {
...@@ -266,7 +266,7 @@ std::string StringifyDefaultValue(const FieldDescriptor& field) { ...@@ -266,7 +266,7 @@ std::string StringifyDefaultValue(const FieldDescriptor& field) {
// infinity - infinity = nan // infinity - infinity = nan
return "(1e10000 * 0)"; return "(1e10000 * 0)";
} else { } else {
return "float(" + StrCat(value) + ")"; return "float(" + SimpleFtoa(value) + ")";
} }
} }
case FieldDescriptor::CPPTYPE_BOOL: case FieldDescriptor::CPPTYPE_BOOL:
......
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