From f66e49c5da348326755f3c777bc0bfc9cfef8ed8 Mon Sep 17 00:00:00 2001 From: Vitaly Goldshteyn Date: Wed, 27 Nov 2024 05:38:38 -0800 Subject: [PATCH] Use newly introduced `Clone` method in `LazyField` in order to avoid looking up prototype (`GetPrototypeForLazyMessage`) during copy. PiperOrigin-RevId: 700667703 --- src/google/protobuf/extension_set.cc | 6 ++---- src/google/protobuf/extension_set.h | 4 +++- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/src/google/protobuf/extension_set.cc b/src/google/protobuf/extension_set.cc index e6a61e1a5f2ba..00b2c48417173 100644 --- a/src/google/protobuf/extension_set.cc +++ b/src/google/protobuf/extension_set.cc @@ -1092,10 +1092,8 @@ void ExtensionSet::InternalExtensionMergeFromIntoUninitializedExtension( case WireFormatLite::CPPTYPE_MESSAGE: { if (other_extension.is_lazy) { dst_extension.ptr.lazymessage_value = - other_extension.ptr.lazymessage_value->New(arena_); - dst_extension.ptr.lazymessage_value->MergeFrom( - GetPrototypeForLazyMessage(extendee, number), - *other_extension.ptr.lazymessage_value, arena_, other_arena); + other_extension.ptr.lazymessage_value->Clone( + arena_, *other_extension.ptr.lazymessage_value, other_arena); } else { dst_extension.ptr.message_value = other_extension.ptr.message_value->New(arena_); diff --git a/src/google/protobuf/extension_set.h b/src/google/protobuf/extension_set.h index 1a3b606055f4e..e7e407b66c116 100644 --- a/src/google/protobuf/extension_set.h +++ b/src/google/protobuf/extension_set.h @@ -624,7 +624,9 @@ class PROTOBUF_EXPORT ExtensionSet { LazyMessageExtension& operator=(const LazyMessageExtension&) = delete; virtual ~LazyMessageExtension() = default; - virtual LazyMessageExtension* New(Arena* arena) const = 0; + virtual LazyMessageExtension* Clone(Arena* arena, + const LazyMessageExtension& other, + Arena* other_arena) const = 0; virtual const MessageLite& GetMessage(const MessageLite& prototype, Arena* arena) const = 0; virtual const MessageLite& GetMessageIgnoreUnparsed(