Commit acd5b05e authored by Feng Xiao's avatar Feng Xiao

Fix failing tests.

1. Fix C++ tests.
  * Add missing files to Makefile.am and fix distcheck in tests.sh
  * Remove BUILT_SOURCES from conformance/Makefile.am.
  * Add some missing override keyword.
  * Add a type cast to int64 because our StrCat() in stubs can't handle size_t.
2. Fix Java tests.
  * Add missing test dependency on guava in pom.xml.
  * Include newly referenced test data in test resources.
  * Manually fix map_lite_test.proto which is overwritten because it's mapped
    from map_test.proto in google3.
  * Add back "optimize_for = LITE_RUNTIME" which is still needed to keep the
    opensource test passing as it's still running lite tests.
  * Add a type cast in newBuilder() because without it the code doesn't compile
    with openjdk javac 1.8 (the compiler can't figure if it's the right type
    due to complex generic typing).
3. Fix Python tests.
  * Remove/replace references to <hash_map>.
  * Suppress more warnings in setup.py.
  * Replace incorrect header inclusion for google/protobuf/proto_api.h.
  * Add strings::EndsWith to google/protobuf/stubs/strutil.h because it's
    referenced in the updated python C extension code.
  * Replace proto2 with google::protobuf. The proto2 name is leaked to
    opensource because we removed the subsitition rule for proto2 namespace
    but only fixed C++ source code and forgot to update python C extension code.
parent 8e4fd1b4
...@@ -689,6 +689,18 @@ php_EXTRA_DIST= \ ...@@ -689,6 +689,18 @@ php_EXTRA_DIST= \
php/src/Google/Protobuf/Internal/SourceCodeInfo/Location.php \ php/src/Google/Protobuf/Internal/SourceCodeInfo/Location.php \
php/src/Google/Protobuf/Internal/UninterpretedOption.php \ php/src/Google/Protobuf/Internal/UninterpretedOption.php \
php/src/Google/Protobuf/Internal/UninterpretedOption/NamePart.php \ php/src/Google/Protobuf/Internal/UninterpretedOption/NamePart.php \
php/src/Google/Protobuf/Internal/DescriptorProto_ExtensionRange.php \
php/src/Google/Protobuf/Internal/DescriptorProto_ReservedRange.php \
php/src/Google/Protobuf/Internal/EnumDescriptorProto_EnumReservedRange.php \
php/src/Google/Protobuf/Internal/FieldDescriptorProto_Label.php \
php/src/Google/Protobuf/Internal/FieldDescriptorProto_Type.php \
php/src/Google/Protobuf/Internal/FieldOptions_CType.php \
php/src/Google/Protobuf/Internal/FieldOptions_JSType.php \
php/src/Google/Protobuf/Internal/FileOptions_OptimizeMode.php \
php/src/Google/Protobuf/Internal/GeneratedCodeInfo_Annotation.php \
php/src/Google/Protobuf/Internal/MethodOptions_IdempotencyLevel.php \
php/src/Google/Protobuf/Internal/SourceCodeInfo_Location.php \
php/src/Google/Protobuf/Internal/UninterpretedOption_NamePart.php \
php/src/Google/Protobuf/ListValue.php \ php/src/Google/Protobuf/ListValue.php \
php/src/Google/Protobuf/Method.php \ php/src/Google/Protobuf/Method.php \
php/src/Google/Protobuf/Mixin.php \ php/src/Google/Protobuf/Mixin.php \
...@@ -804,7 +816,6 @@ python_EXTRA_DIST= \ ...@@ -804,7 +816,6 @@ python_EXTRA_DIST= \
python/google/protobuf/json_format.py \ python/google/protobuf/json_format.py \
python/google/protobuf/message.py \ python/google/protobuf/message.py \
python/google/protobuf/message_factory.py \ python/google/protobuf/message_factory.py \
python/google/protobuf/python_api.h \
python/google/protobuf/python_protobuf.h \ python/google/protobuf/python_protobuf.h \
python/google/protobuf/proto_api.h \ python/google/protobuf/proto_api.h \
python/google/protobuf/proto_builder.py \ python/google/protobuf/proto_builder.py \
...@@ -825,6 +836,10 @@ python_EXTRA_DIST= \ ...@@ -825,6 +836,10 @@ python_EXTRA_DIST= \
python/google/protobuf/pyext/map_container.h \ python/google/protobuf/pyext/map_container.h \
python/google/protobuf/pyext/message.cc \ python/google/protobuf/pyext/message.cc \
python/google/protobuf/pyext/message.h \ python/google/protobuf/pyext/message.h \
python/google/protobuf/pyext/field.cc \
python/google/protobuf/pyext/field.h \
python/google/protobuf/pyext/unknown_fields.cc \
python/google/protobuf/pyext/unknown_fields.h \
python/google/protobuf/pyext/message_factory.cc \ python/google/protobuf/pyext/message_factory.cc \
python/google/protobuf/pyext/message_factory.h \ python/google/protobuf/pyext/message_factory.h \
python/google/protobuf/pyext/message_module.cc \ python/google/protobuf/pyext/message_module.cc \
......
...@@ -279,8 +279,6 @@ $(protoc_outputs): protoc_middleman ...@@ -279,8 +279,6 @@ $(protoc_outputs): protoc_middleman
$(other_language_protoc_outputs): protoc_middleman $(other_language_protoc_outputs): protoc_middleman
BUILT_SOURCES = $(protoc_outputs) $(other_language_protoc_outputs)
CLEANFILES = $(protoc_outputs) protoc_middleman javac_middleman conformance-java javac_middleman_lite conformance-java-lite conformance-csharp conformance-php conformance-php-c $(other_language_protoc_outputs) CLEANFILES = $(protoc_outputs) protoc_middleman javac_middleman conformance-java javac_middleman_lite conformance-java-lite conformance-csharp conformance-php conformance-php-c $(other_language_protoc_outputs)
MAINTAINERCLEANFILES = \ MAINTAINERCLEANFILES = \
......
...@@ -34,6 +34,11 @@ ...@@ -34,6 +34,11 @@
<artifactId>easymockclassextension</artifactId> <artifactId>easymockclassextension</artifactId>
<scope>test</scope> <scope>test</scope>
</dependency> </dependency>
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<scope>test</scope>
</dependency>
</dependencies> </dependencies>
<build> <build>
...@@ -57,6 +62,15 @@ ...@@ -57,6 +62,15 @@
</includes> </includes>
</resource> </resource>
</resources> </resources>
<testResources>
<testResource>
<directory>${protobuf.source.dir}</directory>
<includes>
<include>google/protobuf/testdata/golden_message_oneof_implemented</include>
<include>google/protobuf/testdata/golden_packed_fields_message</include>
</includes>
</testResource>
</testResources>
<plugins> <plugins>
<!-- Use Antrun plugin to generate sources with protoc --> <!-- Use Antrun plugin to generate sources with protoc -->
......
...@@ -30,9 +30,10 @@ ...@@ -30,9 +30,10 @@
syntax = "proto3"; syntax = "proto3";
package map_test; package map_lite_test;
option java_package = "map_test"; option optimize_for = LITE_RUNTIME;
option java_package = "map_lite_test";
option java_outer_classname = "MapTestProto"; option java_outer_classname = "MapTestProto";
message TestMap { message TestMap {
......
...@@ -38,6 +38,7 @@ syntax = "proto2"; ...@@ -38,6 +38,7 @@ syntax = "proto2";
package protobuf_unittest; package protobuf_unittest;
option optimize_for = LITE_RUNTIME;
import "com/google/protobuf/non_nested_extension_lite.proto"; import "com/google/protobuf/non_nested_extension_lite.proto";
......
...@@ -36,6 +36,7 @@ syntax = "proto2"; ...@@ -36,6 +36,7 @@ syntax = "proto2";
package protobuf_unittest; package protobuf_unittest;
option optimize_for = LITE_RUNTIME;
message MessageLiteToBeExtended { message MessageLiteToBeExtended {
extensions 1 to max; extensions 1 to max;
......
...@@ -37,7 +37,6 @@ ...@@ -37,7 +37,6 @@
#include <Python.h> #include <Python.h>
#include <memory> #include <memory>
#include <hash_map>
#include <google/protobuf/pyext/message.h> #include <google/protobuf/pyext/message.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/pyext/field.h>
#include <google/protobuf/descriptor.h>
#include <google/protobuf/pyext/descriptor.h>
#include <google/protobuf/pyext/message.h>
#if PY_MAJOR_VERSION >= 3
#define PyString_FromFormat PyUnicode_FromFormat
#endif
namespace google {
namespace protobuf {
namespace python {
namespace field {
static PyObject* Repr(PyMessageFieldProperty* self) {
return PyString_FromFormat("<field property '%s'>",
self->field_descriptor->full_name().c_str());
}
static PyObject* DescrGet(PyMessageFieldProperty* self, PyObject* obj,
PyObject* type) {
if (obj == NULL) {
Py_INCREF(self);
return reinterpret_cast<PyObject*>(self);
}
return cmessage::GetFieldValue(reinterpret_cast<CMessage*>(obj),
self->field_descriptor);
}
static int DescrSet(PyMessageFieldProperty* self, PyObject* obj,
PyObject* value) {
if (value == NULL) {
PyErr_SetString(PyExc_AttributeError, "Cannot delete field attribute");
return -1;
}
return cmessage::SetFieldValue(reinterpret_cast<CMessage*>(obj),
self->field_descriptor, value);
}
static PyObject* GetDescriptor(PyMessageFieldProperty* self, void* closure) {
return PyFieldDescriptor_FromDescriptor(self->field_descriptor);
}
static PyObject* GetDoc(PyMessageFieldProperty* self, void* closure) {
return PyString_FromFormat("Field %s",
self->field_descriptor->full_name().c_str());
}
static PyGetSetDef Getters[] = {
{"DESCRIPTOR", (getter)GetDescriptor, NULL, "Field descriptor"},
{"__doc__", (getter)GetDoc, NULL, NULL},
{NULL}};
} // namespace field
static PyTypeObject _CFieldProperty_Type = {
PyVarObject_HEAD_INIT(&PyType_Type, 0) // head
FULL_MODULE_NAME ".FieldProperty", // tp_name
sizeof(PyMessageFieldProperty), // tp_basicsize
0, // tp_itemsize
0, // tp_dealloc
0, // tp_print
0, // tp_getattr
0, // tp_setattr
0, // tp_compare
(reprfunc)field::Repr, // tp_repr
0, // tp_as_number
0, // tp_as_sequence
0, // tp_as_mapping
0, // tp_hash
0, // tp_call
0, // tp_str
0, // tp_getattro
0, // tp_setattro
0, // tp_as_buffer
Py_TPFLAGS_DEFAULT, // tp_flags
"Field property of a Message", // tp_doc
0, // tp_traverse
0, // tp_clear
0, // tp_richcompare
0, // tp_weaklistoffset
0, // tp_iter
0, // tp_iternext
0, // tp_methods
0, // tp_members
field::Getters, // tp_getset
0, // tp_base
0, // tp_dict
(descrgetfunc)field::DescrGet, // tp_descr_get
(descrsetfunc)field::DescrSet, // tp_descr_set
0, // tp_dictoffset
0, // tp_init
0, // tp_alloc
0, // tp_new
};
PyTypeObject* CFieldProperty_Type = &_CFieldProperty_Type;
PyObject* NewFieldProperty(const FieldDescriptor* field_descriptor) {
// Create a new descriptor object
PyMessageFieldProperty* property =
PyObject_New(PyMessageFieldProperty, CFieldProperty_Type);
if (property == NULL) {
return NULL;
}
property->field_descriptor = field_descriptor;
return reinterpret_cast<PyObject*>(property);
}
} // namespace python
} // namespace protobuf
} // namespace google
// 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_PYTHON_CPP_FIELD_H__
#define GOOGLE_PROTOBUF_PYTHON_CPP_FIELD_H__
#include <Python.h>
namespace google {
namespace protobuf {
class FieldDescriptor;
namespace python {
// A data descriptor that represents a field in a Message class.
struct PyMessageFieldProperty {
PyObject_HEAD;
// This pointer is owned by the same pool as the Message class it belongs to.
const FieldDescriptor* field_descriptor;
};
extern PyTypeObject* CFieldProperty_Type;
PyObject* NewFieldProperty(const FieldDescriptor* field_descriptor);
} // namespace python
} // namespace protobuf
} // namespace google
#endif // GOOGLE_PROTOBUF_PYTHON_CPP_FIELD_H__
...@@ -75,7 +75,7 @@ class MapReflectionFriend { ...@@ -75,7 +75,7 @@ class MapReflectionFriend {
struct MapIterator { struct MapIterator {
PyObject_HEAD; PyObject_HEAD;
std::unique_ptr<::proto2::MapIterator> iter; std::unique_ptr<google::protobuf::MapIterator> iter;
// A pointer back to the container, so we can notice changes to the version. // A pointer back to the container, so we can notice changes to the version.
// We own a ref on this. // We own a ref on this.
...@@ -314,7 +314,7 @@ static MapContainer* GetMap(PyObject* obj) { ...@@ -314,7 +314,7 @@ static MapContainer* GetMap(PyObject* obj) {
Py_ssize_t MapReflectionFriend::Length(PyObject* _self) { Py_ssize_t MapReflectionFriend::Length(PyObject* _self) {
MapContainer* self = GetMap(_self); MapContainer* self = GetMap(_self);
const proto2::Message* message = self->message; const Message* message = self->message;
return message->GetReflection()->MapSize(*message, return message->GetReflection()->MapSize(*message,
self->parent_field_descriptor); self->parent_field_descriptor);
} }
...@@ -423,7 +423,7 @@ int MapContainer::Release() { ...@@ -423,7 +423,7 @@ int MapContainer::Release() {
// ScalarMap /////////////////////////////////////////////////////////////////// // ScalarMap ///////////////////////////////////////////////////////////////////
PyObject *NewScalarMapContainer( PyObject *NewScalarMapContainer(
CMessage* parent, const proto2::FieldDescriptor* parent_field_descriptor) { CMessage* parent, const FieldDescriptor* parent_field_descriptor) {
if (!CheckFieldBelongsToMessage(parent_field_descriptor, parent->message)) { if (!CheckFieldBelongsToMessage(parent_field_descriptor, parent->message)) {
return NULL; return NULL;
} }
...@@ -548,7 +548,7 @@ PyObject* MapReflectionFriend::ScalarMapToStr(PyObject* _self) { ...@@ -548,7 +548,7 @@ PyObject* MapReflectionFriend::ScalarMapToStr(PyObject* _self) {
MapContainer* self = GetMap(_self); MapContainer* self = GetMap(_self);
Message* message = self->GetMutableMessage(); Message* message = self->GetMutableMessage();
const Reflection* reflection = message->GetReflection(); const Reflection* reflection = message->GetReflection();
for (proto2::MapIterator it = reflection->MapBegin( for (google::protobuf::MapIterator it = reflection->MapBegin(
message, self->parent_field_descriptor); message, self->parent_field_descriptor);
it != reflection->MapEnd(message, self->parent_field_descriptor); it != reflection->MapEnd(message, self->parent_field_descriptor);
++it) { ++it) {
...@@ -704,7 +704,7 @@ static PyObject* GetCMessage(MessageMapContainer* self, Message* message, ...@@ -704,7 +704,7 @@ static PyObject* GetCMessage(MessageMapContainer* self, Message* message,
} }
PyObject* NewMessageMapContainer( PyObject* NewMessageMapContainer(
CMessage* parent, const proto2::FieldDescriptor* parent_field_descriptor, CMessage* parent, const FieldDescriptor* parent_field_descriptor,
CMessageClass* message_class) { CMessageClass* message_class) {
if (!CheckFieldBelongsToMessage(parent_field_descriptor, parent->message)) { if (!CheckFieldBelongsToMessage(parent_field_descriptor, parent->message)) {
return NULL; return NULL;
...@@ -837,7 +837,7 @@ PyObject* MapReflectionFriend::MessageMapToStr(PyObject* _self) { ...@@ -837,7 +837,7 @@ PyObject* MapReflectionFriend::MessageMapToStr(PyObject* _self) {
MessageMapContainer* self = GetMessageMap(_self); MessageMapContainer* self = GetMessageMap(_self);
Message* message = self->GetMutableMessage(); Message* message = self->GetMutableMessage();
const Reflection* reflection = message->GetReflection(); const Reflection* reflection = message->GetReflection();
for (proto2::MapIterator it = reflection->MapBegin( for (google::protobuf::MapIterator it = reflection->MapBegin(
message, self->parent_field_descriptor); message, self->parent_field_descriptor);
it != reflection->MapEnd(message, self->parent_field_descriptor); it != reflection->MapEnd(message, self->parent_field_descriptor);
++it) { ++it) {
...@@ -1011,7 +1011,7 @@ PyObject* MapReflectionFriend::GetIterator(PyObject *_self) { ...@@ -1011,7 +1011,7 @@ PyObject* MapReflectionFriend::GetIterator(PyObject *_self) {
Message* message = self->GetMutableMessage(); Message* message = self->GetMutableMessage();
const Reflection* reflection = message->GetReflection(); const Reflection* reflection = message->GetReflection();
iter->iter.reset(new ::proto2::MapIterator( iter->iter.reset(new google::protobuf::MapIterator(
reflection->MapBegin(message, self->parent_field_descriptor))); reflection->MapBegin(message, self->parent_field_descriptor)));
} }
......
...@@ -171,7 +171,7 @@ static int AddDescriptors(PyObject* cls, const Descriptor* descriptor) { ...@@ -171,7 +171,7 @@ static int AddDescriptors(PyObject* cls, const Descriptor* descriptor) {
// <message descriptor>.extensions_by_name[name] // <message descriptor>.extensions_by_name[name]
// which was defined previously. // which was defined previously.
for (int i = 0; i < descriptor->extension_count(); ++i) { for (int i = 0; i < descriptor->extension_count(); ++i) {
const proto2::FieldDescriptor* field = descriptor->extension(i); const FieldDescriptor* field = descriptor->extension(i);
ScopedPyObjectPtr extension_field(PyFieldDescriptor_FromDescriptor(field)); ScopedPyObjectPtr extension_field(PyFieldDescriptor_FromDescriptor(field));
if (extension_field == NULL) { if (extension_field == NULL) {
return -1; return -1;
...@@ -2344,7 +2344,7 @@ static PyObject* RichCompare(CMessage* self, PyObject* other, int opid) { ...@@ -2344,7 +2344,7 @@ static PyObject* RichCompare(CMessage* self, PyObject* other, int opid) {
if (!PyObject_TypeCheck(other, CMessage_Type)) { if (!PyObject_TypeCheck(other, CMessage_Type)) {
equals = false; equals = false;
} }
const proto2::Message* other_message = const Message* other_message =
reinterpret_cast<CMessage*>(other)->message; reinterpret_cast<CMessage*>(other)->message;
// If messages don't have the same descriptors, they are not equal. // If messages don't have the same descriptors, they are not equal.
if (equals && if (equals &&
...@@ -2352,7 +2352,7 @@ static PyObject* RichCompare(CMessage* self, PyObject* other, int opid) { ...@@ -2352,7 +2352,7 @@ static PyObject* RichCompare(CMessage* self, PyObject* other, int opid) {
equals = false; equals = false;
} }
// Check the message contents. // Check the message contents.
if (equals && !proto2::util::MessageDifferencer::Equals( if (equals && !util::MessageDifferencer::Equals(
*self->message, *self->message,
*reinterpret_cast<CMessage*>(other)->message)) { *reinterpret_cast<CMessage*>(other)->message)) {
equals = false; equals = false;
......
...@@ -38,7 +38,7 @@ ...@@ -38,7 +38,7 @@
#include <memory> #include <memory>
#include <string> #include <string>
#include <hash_map> #include <unordered_map>
#include <google/protobuf/stubs/common.h> #include <google/protobuf/stubs/common.h>
#include <google/protobuf/pyext/thread_unsafe_shared_ptr.h> #include <google/protobuf/pyext/thread_unsafe_shared_ptr.h>
...@@ -105,7 +105,7 @@ typedef struct CMessage { ...@@ -105,7 +105,7 @@ typedef struct CMessage {
// Also cache extension fields. // Also cache extension fields.
// The FieldDescriptor is owned by the message's pool; PyObject references // The FieldDescriptor is owned by the message's pool; PyObject references
// are owned. // are owned.
typedef __gnu_cxx::hash_map<const FieldDescriptor*, PyObject*> typedef std::unordered_map<const FieldDescriptor*, PyObject*>
CompositeFieldsMap; CompositeFieldsMap;
CompositeFieldsMap* composite_fields; CompositeFieldsMap* composite_fields;
......
...@@ -31,19 +31,19 @@ ...@@ -31,19 +31,19 @@
#include <Python.h> #include <Python.h>
#include <google/protobuf/pyext/message.h> #include <google/protobuf/pyext/message.h>
#include <google/protobuf/python/proto_api.h> #include <google/protobuf/proto_api.h>
#include <google/protobuf/message_lite.h> #include <google/protobuf/message_lite.h>
namespace { namespace {
// C++ API. Clients get at this via proto_api.h // C++ API. Clients get at this via proto_api.h
struct ApiImplementation : proto2::python::PyProto_API { struct ApiImplementation : google::protobuf::python::PyProto_API {
const proto2::Message* GetMessagePointer(PyObject* msg) const override { const google::protobuf::Message* GetMessagePointer(PyObject* msg) const override {
return proto2::python::PyMessage_GetMessagePointer(msg); return google::protobuf::python::PyMessage_GetMessagePointer(msg);
} }
proto2::Message* GetMutableMessagePointer(PyObject* msg) const override { google::protobuf::Message* GetMutableMessagePointer(PyObject* msg) const override {
return proto2::python::PyMessage_GetMutableMessagePointer(msg); return google::protobuf::python::PyMessage_GetMutableMessagePointer(msg);
} }
}; };
...@@ -58,7 +58,7 @@ static const char module_docstring[] = ...@@ -58,7 +58,7 @@ static const char module_docstring[] =
static PyMethodDef ModuleMethods[] = { static PyMethodDef ModuleMethods[] = {
{"SetAllowOversizeProtos", {"SetAllowOversizeProtos",
(PyCFunction)proto2::python::cmessage::SetAllowOversizeProtos, (PyCFunction)google::protobuf::python::cmessage::SetAllowOversizeProtos,
METH_O, "Enable/disable oversize proto parsing."}, METH_O, "Enable/disable oversize proto parsing."},
// DO NOT USE: For migration and testing only. // DO NOT USE: For migration and testing only.
{ NULL, NULL} { NULL, NULL}
...@@ -94,7 +94,7 @@ PyMODINIT_FUNC INITFUNC() { ...@@ -94,7 +94,7 @@ PyMODINIT_FUNC INITFUNC() {
return INITFUNC_ERRORVAL; return INITFUNC_ERRORVAL;
} }
if (!proto2::python::InitProto2MessageModule(m)) { if (!google::protobuf::python::InitProto2MessageModule(m)) {
Py_DECREF(m); Py_DECREF(m);
return INITFUNC_ERRORVAL; return INITFUNC_ERRORVAL;
} }
...@@ -102,7 +102,7 @@ PyMODINIT_FUNC INITFUNC() { ...@@ -102,7 +102,7 @@ PyMODINIT_FUNC INITFUNC() {
// Adds the C++ API // Adds the C++ API
if (PyObject* api = if (PyObject* api =
PyCapsule_New(new ApiImplementation(), PyCapsule_New(new ApiImplementation(),
proto2::python::PyProtoAPICapsuleName(), NULL)) { google::protobuf::python::PyProtoAPICapsuleName(), NULL)) {
PyModule_AddObject(m, "proto_API", api); PyModule_AddObject(m, "proto_API", api);
} else { } else {
return INITFUNC_ERRORVAL; return INITFUNC_ERRORVAL;
......
This diff is collapsed.
// 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_PYTHON_CPP_UNKNOWN_FIELDS_H__
#define GOOGLE_PROTOBUF_PYTHON_CPP_UNKNOWN_FIELDS_H__
#include <Python.h>
#include <memory>
#include <set>
#include <google/protobuf/pyext/message.h>
namespace google {
namespace protobuf {
class UnknownField;
class UnknownFieldSet;
namespace python {
struct CMessage;
typedef struct PyUnknownFields {
PyObject_HEAD;
// Strong pointer to the parent CMessage or PyUnknownFields.
// The top PyUnknownFields holds a reference to its parent CMessage
// object before release.
// Sub PyUnknownFields holds reference to parent PyUnknownFields.
PyObject* parent;
// Pointer to the C++ UnknownFieldSet.
// PyUnknownFields does not own this pointer.
const UnknownFieldSet* fields;
// Weak references to child unknown fields.
std::set<PyUnknownFields*> sub_unknown_fields;
} PyUnknownFields;
typedef struct PyUnknownFieldRef {
PyObject_HEAD;
// Every Python PyUnknownFieldRef holds a reference to its parent
// PyUnknownFields in order to keep it alive.
PyUnknownFields* parent;
// The UnknownField index in UnknownFields.
Py_ssize_t index;
} UknownFieldRef;
extern PyTypeObject PyUnknownFields_Type;
extern PyTypeObject PyUnknownFieldRef_Type;
namespace unknown_fields {
// Builds an PyUnknownFields for a specific message.
PyObject* NewPyUnknownFields(CMessage *parent);
void Clear(PyUnknownFields* self);
} // namespace unknown_fields
} // namespace python
} // namespace protobuf
} // namespace google
#endif // GOOGLE_PROTOBUF_PYTHON_CPP_UNKNOWN_FIELDS_H__
...@@ -185,8 +185,12 @@ if __name__ == '__main__': ...@@ -185,8 +185,12 @@ if __name__ == '__main__':
extra_compile_args.append('-Wno-write-strings') extra_compile_args.append('-Wno-write-strings')
extra_compile_args.append('-Wno-invalid-offsetof') extra_compile_args.append('-Wno-invalid-offsetof')
extra_compile_args.append('-Wno-sign-compare') extra_compile_args.append('-Wno-sign-compare')
extra_compile_args.append('-Wno-unused-variable')
extra_compile_args.append('-std=c++11') extra_compile_args.append('-std=c++11')
if sys.platform == 'darwin':
extra_compile_args.append("-Wno-shorten-64-to-32");
# https://github.com/Theano/Theano/issues/4926 # https://github.com/Theano/Theano/issues/4926
if sys.platform == 'win32': if sys.platform == 'win32':
extra_compile_args.append('-D_hypot=hypot') extra_compile_args.append('-D_hypot=hypot')
......
...@@ -112,6 +112,9 @@ nobase_include_HEADERS = \ ...@@ -112,6 +112,9 @@ nobase_include_HEADERS = \
google/protobuf/message_lite.h \ google/protobuf/message_lite.h \
google/protobuf/metadata.h \ google/protobuf/metadata.h \
google/protobuf/metadata_lite.h \ google/protobuf/metadata_lite.h \
google/protobuf/port.h \
google/protobuf/port_def.inc \
google/protobuf/port_undef.inc \
google/protobuf/reflection.h \ google/protobuf/reflection.h \
google/protobuf/reflection_ops.h \ google/protobuf/reflection_ops.h \
google/protobuf/repeated_field.h \ google/protobuf/repeated_field.h \
...@@ -690,6 +693,7 @@ COMMON_TEST_SOURCES = \ ...@@ -690,6 +693,7 @@ COMMON_TEST_SOURCES = \
google/protobuf/test_util.cc \ google/protobuf/test_util.cc \
google/protobuf/test_util.h \ google/protobuf/test_util.h \
google/protobuf/test_util.inc \ google/protobuf/test_util.inc \
google/protobuf/test_util2.h \
google/protobuf/testing/googletest.cc \ google/protobuf/testing/googletest.cc \
google/protobuf/testing/googletest.h \ google/protobuf/testing/googletest.h \
google/protobuf/testing/file.cc \ google/protobuf/testing/file.cc \
...@@ -743,6 +747,7 @@ protobuf_test_SOURCES = \ ...@@ -743,6 +747,7 @@ protobuf_test_SOURCES = \
google/protobuf/proto3_arena_lite_unittest.cc \ google/protobuf/proto3_arena_lite_unittest.cc \
google/protobuf/proto3_arena_unittest.cc \ google/protobuf/proto3_arena_unittest.cc \
google/protobuf/proto3_lite_unittest.cc \ google/protobuf/proto3_lite_unittest.cc \
google/protobuf/proto3_lite_unittest.inc \
google/protobuf/reflection_ops_unittest.cc \ google/protobuf/reflection_ops_unittest.cc \
google/protobuf/repeated_field_reflection_unittest.cc \ google/protobuf/repeated_field_reflection_unittest.cc \
google/protobuf/repeated_field_unittest.cc \ google/protobuf/repeated_field_unittest.cc \
......
...@@ -737,10 +737,10 @@ void ImmutableMessageLiteGenerator::GenerateSerializeOneExtensionRange( ...@@ -737,10 +737,10 @@ void ImmutableMessageLiteGenerator::GenerateSerializeOneExtensionRange(
void ImmutableMessageLiteGenerator::GenerateBuilder(io::Printer* printer) { void ImmutableMessageLiteGenerator::GenerateBuilder(io::Printer* printer) {
printer->Print( printer->Print(
"public static Builder newBuilder() {\n" "public static Builder newBuilder() {\n"
" return DEFAULT_INSTANCE.createBuilder();\n" " return (Builder) DEFAULT_INSTANCE.createBuilder();\n"
"}\n" "}\n"
"public static Builder newBuilder($classname$ prototype) {\n" "public static Builder newBuilder($classname$ prototype) {\n"
" return DEFAULT_INSTANCE.createBuilder(prototype);\n" " return (Builder) DEFAULT_INSTANCE.createBuilder(prototype);\n"
"}\n" "}\n"
"\n", "\n",
"classname", name_resolver_->GetImmutableClassName(descriptor_)); "classname", name_resolver_->GetImmutableClassName(descriptor_));
......
...@@ -164,7 +164,7 @@ class LIBPROTOBUF_EXPORT SimpleDescriptorDatabase : public DescriptorDatabase { ...@@ -164,7 +164,7 @@ class LIBPROTOBUF_EXPORT SimpleDescriptorDatabase : public DescriptorDatabase {
bool FindAllExtensionNumbers(const string& extendee_type, bool FindAllExtensionNumbers(const string& extendee_type,
std::vector<int>* output) override; std::vector<int>* output) override;
bool FindAllFileNames(std::vector<string>* output); bool FindAllFileNames(std::vector<string>* output) override;
private: private:
// So that it can use DescriptorIndex. // So that it can use DescriptorIndex.
......
...@@ -913,6 +913,15 @@ LIBPROTOBUF_EXPORT void CleanStringLineEndings(const string& src, string* dst, ...@@ -913,6 +913,15 @@ LIBPROTOBUF_EXPORT void CleanStringLineEndings(const string& src, string* dst,
LIBPROTOBUF_EXPORT void CleanStringLineEndings(string* str, LIBPROTOBUF_EXPORT void CleanStringLineEndings(string* str,
bool auto_end_last_line); bool auto_end_last_line);
namespace strings {
inline bool EndsWith(StringPiece text, StringPiece suffix) {
return suffix.empty() ||
(text.size() >= suffix.size() &&
memcmp(text.data() + (text.size() - suffix.size()), suffix.data(),
suffix.size()) == 0);
}
} // namespace strings
} // namespace protobuf } // namespace protobuf
} // namespace google } // namespace google
......
...@@ -1356,7 +1356,8 @@ bool CheckParseInputSize(StringPiece input, ...@@ -1356,7 +1356,8 @@ bool CheckParseInputSize(StringPiece input,
io::ErrorCollector* error_collector) { io::ErrorCollector* error_collector) {
if (input.size() > INT_MAX) { if (input.size() > INT_MAX) {
error_collector->AddError( error_collector->AddError(
-1, 0, StrCat("Input size too large: ", input.size(), " bytes", -1, 0, StrCat("Input size too large: ",
static_cast<int64>(input.size()), " bytes",
" > ", INT_MAX, " bytes.")); " > ", INT_MAX, " bytes."));
return false; return false;
} }
......
...@@ -56,10 +56,10 @@ build_cpp_distcheck() { ...@@ -56,10 +56,10 @@ build_cpp_distcheck() {
# Check if every file exists in the dist tar file. # Check if every file exists in the dist tar file.
FILES_MISSING="" FILES_MISSING=""
for FILE in $(<../dist.lst); do for FILE in $(<../dist.lst); do
if ! file $FILE &>/dev/null; then [ -f "$FILE" ] || {
echo "$FILE is not found!" echo "$FILE is not found!"
FILES_MISSING="$FILE $FILES_MISSING" FILES_MISSING="$FILE $FILES_MISSING"
fi }
done done
cd .. cd ..
if [ ! -z "$FILES_MISSING" ]; then if [ ! -z "$FILES_MISSING" ]; then
......
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