Commit 49f24afb authored by Paul Yang's avatar Paul Yang

Merge pull request #815 from TeBoring/third-party

Use std::get where it's available
parents 693cb3d2 7c14dc83
...@@ -82,6 +82,7 @@ ...@@ -82,6 +82,7 @@
namespace google { namespace google {
namespace protobuf { namespace protobuf {
using internal::NewPermanentCallback;
namespace compiler { namespace compiler {
namespace cpp { namespace cpp {
......
...@@ -190,6 +190,8 @@ class LIBPROTOBUF_EXPORT MapKey { ...@@ -190,6 +190,8 @@ class LIBPROTOBUF_EXPORT MapKey {
GOOGLE_LOG(FATAL) << "Can't get here."; GOOGLE_LOG(FATAL) << "Can't get here.";
return false; return false;
} }
GOOGLE_LOG(FATAL) << "Can't get here.";
return false;
} }
void CopyFrom(const MapKey& other) { void CopyFrom(const MapKey& other) {
...@@ -852,6 +854,8 @@ struct hash<google::protobuf::MapKey> { ...@@ -852,6 +854,8 @@ struct hash<google::protobuf::MapKey> {
GOOGLE_LOG(FATAL) << "Can't get here."; GOOGLE_LOG(FATAL) << "Can't get here.";
return 0; return 0;
} }
GOOGLE_LOG(FATAL) << "Can't get here.";
return 0;
} }
bool bool
operator()(const google::protobuf::MapKey& map_key1, operator()(const google::protobuf::MapKey& map_key1,
...@@ -875,6 +879,8 @@ struct hash<google::protobuf::MapKey> { ...@@ -875,6 +879,8 @@ struct hash<google::protobuf::MapKey> {
GOOGLE_LOG(FATAL) << "Can't get here."; GOOGLE_LOG(FATAL) << "Can't get here.";
return true; return true;
} }
GOOGLE_LOG(FATAL) << "Can't get here.";
return true;
} }
}; };
GOOGLE_PROTOBUF_HASH_NAMESPACE_DECLARATION_END GOOGLE_PROTOBUF_HASH_NAMESPACE_DECLARATION_END
......
// Protocol Buffers - Google's data interchange format
// Copyright 2008 Google Inc. All rights reserved.
// https://developers.google.com/protocol-buffers/
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
// met:
//
// * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above
// copyright notice, this list of conditions and the following disclaimer
// in the documentation and/or other materials provided with the
// distribution.
// * Neither the name of Google Inc. nor the names of its
// contributors may be used to endorse or promote products derived from
// this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#ifndef GOOGLE_PROTOBUF_UTIL_PROTO_CAST_H__
#define GOOGLE_PROTOBUF_UTIL_PROTO_CAST_H__
#include <string>
#include <google/protobuf/stubs/logging.h>
#include <google/protobuf/stubs/common.h>
// proto_cast<> is used to simulate over-the-wire conversion of one
// proto message into another. This is primarily useful for unit tests
// which validate the version-compatibility semantics of protobufs.
// Usage is similar to C++-style typecasts:
//
// OldMessage old_message = /*...*/;
// NewMessage new_message = proto_cast<NewMessage>(old_message);
namespace google {
template<typename NewProto,
typename OldProto>
NewProto proto_cast(const OldProto& old_proto) {
string wire_format;
GOOGLE_CHECK(old_proto.SerializeToString(&wire_format));
NewProto new_proto;
GOOGLE_CHECK(new_proto.ParseFromString(wire_format));
return new_proto;
}
} // namespace google
#endif // GOOGLE_PROTOBUF_UTIL_PROTO_CAST_H__
// Protocol Buffers - Google's data interchange format
// Copyright 2008 Google Inc. All rights reserved.
// https://developers.google.com/protocol-buffers/
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
// met:
//
// * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above
// copyright notice, this list of conditions and the following disclaimer
// in the documentation and/or other materials provided with the
// distribution.
// * Neither the name of Google Inc. nor the names of its
// contributors may be used to endorse or promote products derived from
// this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#include <google/protobuf/util/proto_cast.h>
#include <google/protobuf/util/unknown_enum_test.pb.h>
#include <gtest/gtest.h>
#include <gmock/gmock.h>
namespace google {
using google::protobuf::util::UpRevision;
using google::protobuf::util::DownRevision;
namespace {
TEST(ProtoCastTest, V2KnownValue) {
UpRevision sender;
sender.set_value(UpRevision::NONDEFAULT_VALUE);
DownRevision receiver = proto_cast<DownRevision>(sender);
ASSERT_EQ(DownRevision::NONDEFAULT_VALUE, receiver.value());
}
TEST(ProtoCastTest, V2UnknownValue) {
UpRevision sender;
sender.set_value(UpRevision::NEW_VALUE);
DownRevision receiver = proto_cast<DownRevision>(sender);
ASSERT_EQ(DownRevision::DEFAULT_VALUE, receiver.value());
}
} // namespace
} // namespace google
...@@ -325,8 +325,6 @@ class MethodResultCallback_5_2 : public ResultCallback2<R, A1, A2> { ...@@ -325,8 +325,6 @@ class MethodResultCallback_5_2 : public ResultCallback2<R, A1, A2> {
typename remove_reference<P5>::type p5_; typename remove_reference<P5>::type p5_;
}; };
} // namespace internal
// See Closure. // See Closure.
inline Closure* NewCallback(void (*function)()) { inline Closure* NewCallback(void (*function)()) {
return new internal::FunctionClosure0(function, true); return new internal::FunctionClosure0(function, true);
...@@ -452,6 +450,8 @@ inline ResultCallback2<R, A1, A2>* NewPermanentCallback( ...@@ -452,6 +450,8 @@ inline ResultCallback2<R, A1, A2>* NewPermanentCallback(
p2, p3, p4, p5); p2, p3, p4, p5);
} }
} // namespace internal
// A function which does nothing. Useful for creating no-op callbacks, e.g.: // A function which does nothing. Useful for creating no-op callbacks, e.g.:
// Closure* nothing = NewCallback(&DoNothing); // Closure* nothing = NewCallback(&DoNothing);
void LIBPROTOBUF_EXPORT DoNothing(); void LIBPROTOBUF_EXPORT DoNothing();
......
...@@ -146,7 +146,7 @@ namespace internal { ...@@ -146,7 +146,7 @@ namespace internal {
LIBPROTOBUF_EXPORT bool IsStructurallyValidUTF8(const char* buf, int len); LIBPROTOBUF_EXPORT bool IsStructurallyValidUTF8(const char* buf, int len);
inline bool IsStructurallyValidUTF8(const std::string& str) { inline bool IsStructurallyValidUTF8(const std::string& str) {
return IsStructurallyValidUTF8(str.data(), str.length()); return IsStructurallyValidUTF8(str.data(), static_cast<int>(str.length()));
} }
// Returns initial number of bytes of structually valid UTF-8. // Returns initial number of bytes of structually valid UTF-8.
......
...@@ -41,6 +41,8 @@ ...@@ -41,6 +41,8 @@
namespace google { namespace google {
namespace protobuf { namespace protobuf {
using internal::NewCallback;
using internal::NewPermanentCallback;
namespace { namespace {
// TODO(kenton): More tests. // TODO(kenton): More tests.
......
...@@ -41,9 +41,14 @@ ...@@ -41,9 +41,14 @@
#define GOOGLE_PROTOBUF_HAVE_HASH_MAP 1 #define GOOGLE_PROTOBUF_HAVE_HASH_MAP 1
#define GOOGLE_PROTOBUF_HAVE_HASH_SET 1 #define GOOGLE_PROTOBUF_HAVE_HASH_SET 1
// Android
#if defined(__ANDROID__)
# undef GOOGLE_PROTOBUF_HAVE_HASH_MAP
# undef GOOGLE_PROTOBUF_HAVE_HASH_MAP
// Use C++11 unordered_{map|set} if available. // Use C++11 unordered_{map|set} if available.
#if ((_LIBCPP_STD_VER >= 11) || \ #elif ((_LIBCPP_STD_VER >= 11) || \
(((__cplusplus >= 201103L) || defined(__GXX_EXPERIMENTAL_CXX0X)) && \ (((__cplusplus >= 201103L) || defined(__GXX_EXPERIMENTAL_CXX0X)) && \
(__GLIBCXX__ > 20090421))) (__GLIBCXX__ > 20090421)))
# define GOOGLE_PROTOBUF_HAS_CXX11_HASH # define GOOGLE_PROTOBUF_HAS_CXX11_HASH
......
...@@ -188,7 +188,8 @@ std::ostream& operator<<(std::ostream& o, const uint128& b) { ...@@ -188,7 +188,8 @@ std::ostream& operator<<(std::ostream& o, const uint128& b) {
if ((flags & std::ios::adjustfield) == std::ios::left) { if ((flags & std::ios::adjustfield) == std::ios::left) {
rep.append(width - rep.size(), o.fill()); rep.append(width - rep.size(), o.fill());
} else { } else {
rep.insert(0, width - rep.size(), o.fill()); rep.insert(static_cast<std::string::size_type>(0),
width - rep.size(), o.fill());
} }
} }
......
...@@ -43,6 +43,7 @@ ...@@ -43,6 +43,7 @@
namespace google { namespace google {
namespace protobuf { namespace protobuf {
using internal::NewCallback;
namespace { namespace {
class OnceInitTest : public testing::Test { class OnceInitTest : public testing::Test {
...@@ -127,10 +128,11 @@ class OnceInitTest : public testing::Test { ...@@ -127,10 +128,11 @@ class OnceInitTest : public testing::Test {
}; };
TestThread* RunInitOnceInNewThread() { TestThread* RunInitOnceInNewThread() {
return new TestThread(NewCallback(this, &OnceInitTest::InitOnce)); return new TestThread(internal::NewCallback(this, &OnceInitTest::InitOnce));
} }
TestThread* RunInitRecursiveOnceInNewThread() { TestThread* RunInitRecursiveOnceInNewThread() {
return new TestThread(NewCallback(this, &OnceInitTest::InitRecursiveOnce)); return new TestThread(
internal::NewCallback(this, &OnceInitTest::InitRecursiveOnce));
} }
enum State { enum State {
......
// Protocol Buffers - Google's data interchange format
// Copyright 2008 Google Inc. All rights reserved.
// https://developers.google.com/protocol-buffers/
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
// met:
//
// * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above
// copyright notice, this list of conditions and the following disclaimer
// in the documentation and/or other materials provided with the
// distribution.
// * Neither the name of Google Inc. nor the names of its
// contributors may be used to endorse or promote products derived from
// this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#ifndef GOOGLE_PROTOBUF_UTIL_UNKNOWN_ENUM_IMPL_H__
#define GOOGLE_PROTOBUF_UTIL_UNKNOWN_ENUM_IMPL_H__
#include <stdlib.h>
#include <google/protobuf/stubs/common.h>
#include <google/protobuf/bridge/compatibility_mode_support.h>
namespace google {
namespace protobuf {
// google/protobuf/message.h
class Message;
namespace util {
// NOTE: You should not call these functions directly. Instead use either
// HAS_UNKNOWN_ENUM() or GET_UNKNOWN_ENUM(), defined in the public header.
// The macro-versions operate in a type-safe manner and behave appropriately
// for the proto version of the message, whereas these versions assume a
// specific proto version and allow the caller to pass in any arbitrary integer
// value as a field number.
//
// Returns whether the message has unrecognized the enum value for a given
// field. It also stores the value into the unknown_value parameter if the
// function returns true and the pointer is not NULL.
//
// In proto2, invalid enum values will be treated as unknown fields. This
// function checks that case.
bool HasUnknownEnum(const Message& message, int32 field_number,
int32* unknown_value = NULL);
// Same as above, but returns all unknown enums.
bool GetRepeatedEnumUnknowns(const Message& message, int32 field_number,
vector<int32>* unknown_values = NULL);
// In proto1, invalue enum values are stored in the same way as valid enum
// values.
// TODO(karner): Delete this once the migration to proto2 is complete.
bool HasUnknownEnumProto1(const Message& message, int32 field_number,
int32* unknown_value);
// Same as above, but returns all unknown enums.
bool GetRepeatedEnumUnknownsProto1(const Message& message, int32 field_number,
vector<int32>* unknown_values);
// Invokes the appropriate version based on whether the message is proto1
// or proto2.
template <typename T>
bool HasUnknownEnum_Template(const T& message, int32 field_number,
int32* unknown_value = NULL) {
if (internal::is_base_of<bridge::internal::Proto1CompatibleMessage, T>::value ||
!internal::is_base_of<ProtocolMessage, T>::value) {
return HasUnknownEnum(message, field_number, unknown_value);
} else {
return HasUnknownEnumProto1(message, field_number, unknown_value);
}
}
// Invokes the appropriate version based on whether the message is proto1
// or proto2.
template <typename T>
bool GetRepeatedEnumUnknowns_Template(
const T& message, int32 field_number,
vector<int32>* unknown_values = NULL) {
if (internal::is_base_of<bridge::internal::Proto1CompatibleMessage, T>::value ||
!internal::is_base_of<ProtocolMessage, T>::value) {
return GetRepeatedEnumUnknowns(message, field_number, unknown_values);
} else {
return GetRepeatedEnumUnknownsProto1(message, field_number,
unknown_values);
}
}
// NOTE: You should not call these functions directly. Instead use
// CLEAR_UNKNOWN_ENUM(), defined in the public header. The macro-versions
// operate in a type-safe manner and behave appropriately for the proto
// version of the message, whereas these versions assume a specific proto
// version and allow the caller to pass in any arbitrary integer value as a
// field number.
//
// Clears the unknown entries of the given field of the message.
void ClearUnknownEnum(Message* message, int32 field_number);
// In proto1, clears the field if the value is out of range.
// TODO(karner): Delete this or make it proto2-only once the migration
// to proto2 is complete.
void ClearUnknownEnumProto1(Message* message, int32 field_number);
template <typename T>
void ClearUnknownEnum_Template(T* message, int32 field_number) {
if (internal::is_base_of<bridge::internal::Proto1CompatibleMessage, T>::value ||
!internal::is_base_of<ProtocolMessage, T>::value) {
ClearUnknownEnum(message, field_number);
} else {
ClearUnknownEnumProto1(message, field_number);
}
}
// NOTE: You should not call these functions directly. Instead use
// SET_UNKNOWN_ENUM(), defined in the public header. The macro-versions
// operate in a type-safe manner and behave appropriately for the proto
// version of the message, whereas these versions assume a specific proto
// version and allow the caller to pass in any arbitrary integer value as a
// field number.
//
// Sets the given value in the unknown fields of the message.
void SetUnknownEnum(Message* message, int32 field_number, int32 unknown_value);
// In proto1, invalue enum values are stored in the same way as valid enum
// values.
// TODO(karner): Delete this once the migration to proto2 is complete.
void SetUnknownEnumProto1(Message* message, int32 field_number,
int32 unknown_value);
// Invokes the appropriate version based on whether the message is proto1
// or proto2.
template <typename T>
void SetUnknownEnum_Template(T* message, int32 field_number,
int32 unknown_value) {
if (internal::is_base_of<bridge::internal::Proto1CompatibleMessage, T>::value ||
!internal::is_base_of<ProtocolMessage, T>::value) {
SetUnknownEnum(message, field_number, unknown_value);
} else {
SetUnknownEnumProto1(message, field_number, unknown_value);
}
}
} // namespace util
} // namespace protobuf
} // namespace google
#endif // GOOGLE_PROTOBUF_UTIL_UNKNOWN_ENUM_IMPL_H__
// Protocol Buffers - Google's data interchange format
// Copyright 2008 Google Inc. All rights reserved.
// https://developers.google.com/protocol-buffers/
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
// met:
//
// * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above
// copyright notice, this list of conditions and the following disclaimer
// in the documentation and/or other materials provided with the
// distribution.
// * Neither the name of Google Inc. nor the names of its
// contributors may be used to endorse or promote products derived from
// this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// Definitions of protos for testing cross-version compatibility. The
// UpRevision message acts as if it were a newer version of the DownRevision
// message. That is, UpRevision shares all the same fields as DownRevision,
// but UpRevision can add fields and add enum values.
syntax = "proto2";
package google.protobuf.util;
option csharp_namespace = "Google.ProtocolBuffers.TestProtos";
message DownRevision {
enum Enum {
DEFAULT_VALUE = 2;
NONDEFAULT_VALUE = 3;
}
optional Enum value = 1 [default = DEFAULT_VALUE];
repeated Enum values = 2;
}
message UpRevision {
enum Enum {
DEFAULT_VALUE = 2;
NONDEFAULT_VALUE = 3;
NEW_VALUE = 4;
NEW_VALUE_2 = 5;
NEW_VALUE_3 = 6;
}
optional Enum value = 1 [default = DEFAULT_VALUE];
repeated Enum values = 2;
}
...@@ -1129,7 +1129,7 @@ Status ProtoStreamObjectWriter::RenderFieldMask(ProtoStreamObjectWriter* ow, ...@@ -1129,7 +1129,7 @@ Status ProtoStreamObjectWriter::RenderFieldMask(ProtoStreamObjectWriter* ow,
// conversions as much as possible. Because ToSnakeCase sometimes returns the // conversions as much as possible. Because ToSnakeCase sometimes returns the
// wrong value. // wrong value.
google::protobuf::scoped_ptr<ResultCallback1<util::Status, StringPiece> > callback( google::protobuf::scoped_ptr<ResultCallback1<util::Status, StringPiece> > callback(
NewPermanentCallback(&RenderOneFieldPath, ow)); google::protobuf::internal::NewPermanentCallback(&RenderOneFieldPath, ow));
return DecodeCompactFieldMaskPaths(data.str(), callback.get()); return DecodeCompactFieldMaskPaths(data.str(), callback.get());
} }
......
...@@ -159,7 +159,12 @@ class BaseProtoStreamObjectWriterTest ...@@ -159,7 +159,12 @@ class BaseProtoStreamObjectWriterTest
MATCHER_P(HasObjectLocation, expected, MATCHER_P(HasObjectLocation, expected,
"Verifies the expected object location") { "Verifies the expected object location") {
string actual = std::tr1::get<0>(arg).ToString(); string actual;
#if __cplusplus >= 201103L
actual = std::get<0>(arg).ToString();
#else
actual = std::tr1::get<0>(arg).ToString();
#endif
if (actual.compare(expected) == 0) return true; if (actual.compare(expected) == 0) return true;
*result_listener << "actual location is: " << actual; *result_listener << "actual location is: " << actual;
return false; return false;
......
...@@ -1363,9 +1363,11 @@ bool MessageDifferencer::MatchRepeatedFieldIndices( ...@@ -1363,9 +1363,11 @@ bool MessageDifferencer::MatchRepeatedFieldIndices(
// doesn't neccessarily imply Compare(b, c). Therefore a naive greedy // doesn't neccessarily imply Compare(b, c). Therefore a naive greedy
// algorithm will fail to find a maximum matching. // algorithm will fail to find a maximum matching.
// Here we use the argumenting path algorithm. // Here we use the argumenting path algorithm.
MaximumMatcher::NodeMatchCallback* callback = NewPermanentCallback( MaximumMatcher::NodeMatchCallback* callback =
this, &MessageDifferencer::IsMatch, repeated_field, key_comparator, google::protobuf::internal::NewPermanentCallback(
&message1, &message2, parent_fields); this, &MessageDifferencer::IsMatch,
repeated_field, key_comparator,
&message1, &message2, parent_fields);
MaximumMatcher matcher(count1, count2, callback, match_list1, MaximumMatcher matcher(count1, count2, callback, match_list1,
match_list2); match_list2);
// If diff info is not needed, we should end the matching process as // If diff info is not needed, we should end the matching process as
......
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