Commit 375d32d3 authored by Allen Webb's avatar Allen Webb

cpp_generator: Add support for --cpp_out=speed:...

Previously --cpp_out:lite was available to force the optimization mode
to the lite runtime. This adds --cpp_out=speed:...
which is needed to override the file specific options in cases where
libprotobuf-mutator is used for fuzzing since it depends on reflection.
Signed-off-by: 's avatarAllen Webb <allenwebb@google.com>
parent 2f28980f
...@@ -92,9 +92,12 @@ bool CppGenerator::Generate(const FileDescriptor* file, ...@@ -92,9 +92,12 @@ bool CppGenerator::Generate(const FileDescriptor* file,
file_options.annotation_pragma_name = options[i].second; file_options.annotation_pragma_name = options[i].second;
} else if (options[i].first == "annotation_guard_name") { } else if (options[i].first == "annotation_guard_name") {
file_options.annotation_guard_name = options[i].second; file_options.annotation_guard_name = options[i].second;
} else if (options[i].first == "speed") {
file_options.enforce_mode = EnforceOptimizeMode::kSpeed;
} else if (options[i].first == "lite") { } else if (options[i].first == "lite") {
file_options.enforce_lite = true; file_options.enforce_mode = EnforceOptimizeMode::kLiteRuntime;
} else if (options[i].first == "lite_implicit_weak_fields") { } else if (options[i].first == "lite_implicit_weak_fields") {
file_options.enforce_mode = EnforceOptimizeMode::kLiteRuntime;
file_options.lite_implicit_weak_fields = true; file_options.lite_implicit_weak_fields = true;
if (!options[i].second.empty()) { if (!options[i].second.empty()) {
file_options.num_cc_files = strto32(options[i].second.c_str(), file_options.num_cc_files = strto32(options[i].second.c_str(),
......
...@@ -353,7 +353,7 @@ inline bool HasFastArraySerialization(const FileDescriptor* file, ...@@ -353,7 +353,7 @@ inline bool HasFastArraySerialization(const FileDescriptor* file,
inline bool IsProto2MessageSet(const Descriptor* descriptor, inline bool IsProto2MessageSet(const Descriptor* descriptor,
const Options& options) { const Options& options) {
return !options.opensource_runtime && return !options.opensource_runtime &&
!options.enforce_lite && options.enforce_mode != EnforceOptimizeMode::kLiteRuntime &&
!options.lite_implicit_weak_fields && !options.lite_implicit_weak_fields &&
descriptor->options().message_set_wire_format() && descriptor->options().message_set_wire_format() &&
descriptor->full_name() == "google.protobuf.bridge.MessageSet"; descriptor->full_name() == "google.protobuf.bridge.MessageSet";
...@@ -362,7 +362,7 @@ inline bool IsProto2MessageSet(const Descriptor* descriptor, ...@@ -362,7 +362,7 @@ inline bool IsProto2MessageSet(const Descriptor* descriptor,
inline bool IsProto2MessageSetFile(const FileDescriptor* file, inline bool IsProto2MessageSetFile(const FileDescriptor* file,
const Options& options) { const Options& options) {
return !options.opensource_runtime && return !options.opensource_runtime &&
!options.enforce_lite && options.enforce_mode != EnforceOptimizeMode::kLiteRuntime &&
!options.lite_implicit_weak_fields && !options.lite_implicit_weak_fields &&
file->name() == "net/proto2/bridge/proto/message_set.proto"; file->name() == "net/proto2/bridge/proto/message_set.proto";
} }
...@@ -419,9 +419,15 @@ bool IsWellKnownMessage(const FileDescriptor* descriptor); ...@@ -419,9 +419,15 @@ bool IsWellKnownMessage(const FileDescriptor* descriptor);
inline FileOptions_OptimizeMode GetOptimizeFor(const FileDescriptor* file, inline FileOptions_OptimizeMode GetOptimizeFor(const FileDescriptor* file,
const Options& options) { const Options& options) {
return options.enforce_lite switch (options.enforce_mode) {
? FileOptions::LITE_RUNTIME case EnforceOptimizeMode::kSpeed:
: file->options().optimize_for(); return FileOptions::SPEED;
case EnforceOptimizeMode::kLiteRuntime:
return FileOptions::LITE_RUNTIME;
case EnforceOptimizeMode::kNoEnforcement:
default:
return file->options().optimize_for();
}
} }
// This orders the messages in a .pb.cc as it's outputted by file.cc // This orders the messages in a .pb.cc as it's outputted by file.cc
......
...@@ -42,6 +42,12 @@ class AccessInfoMap; ...@@ -42,6 +42,12 @@ class AccessInfoMap;
namespace cpp { namespace cpp {
enum class EnforceOptimizeMode {
kNoEnforcement, // Use the runtime specified by the file specific options.
kSpeed, // This is the full runtime.
kLiteRuntime,
};
// Generator options (see generator.cc for a description of each): // Generator options (see generator.cc for a description of each):
struct Options { struct Options {
std::string dllexport_decl; std::string dllexport_decl;
...@@ -49,7 +55,7 @@ struct Options { ...@@ -49,7 +55,7 @@ struct Options {
bool proto_h = false; bool proto_h = false;
bool transitive_pb_h = true; bool transitive_pb_h = true;
bool annotate_headers = false; bool annotate_headers = false;
bool enforce_lite = false; EnforceOptimizeMode enforce_mode = EnforceOptimizeMode::kNoEnforcement;
bool table_driven_parsing = false; bool table_driven_parsing = false;
bool table_driven_serialization = false; bool table_driven_serialization = false;
bool lite_implicit_weak_fields = false; bool lite_implicit_weak_fields = false;
......
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