Commit 00700b72 authored by Josh Haberman's avatar Josh Haberman

Removed all warnings from the Python/C++ build.

Also made the Travis build ensure that no warnings
are present.

These builds were previously spewing many warnings,
which was hiding warnings for important things like
accidentally using C++11-only features.

Change-Id: I56caeee9db48bc78756a3e8d7c14874630627037
parent 12fb61b2
...@@ -232,7 +232,7 @@ static PyObject* GetOrBuildOptions(const DescriptorClass *descriptor) { ...@@ -232,7 +232,7 @@ static PyObject* GetOrBuildOptions(const DescriptorClass *descriptor) {
} }
// Cache the result. // Cache the result.
Py_INCREF(value); Py_INCREF(value.get());
(*pool->descriptor_options)[descriptor] = value.get(); (*pool->descriptor_options)[descriptor] = value.get();
return value.release(); return value.release();
...@@ -1489,7 +1489,8 @@ static bool AddEnumValues(PyTypeObject *type, ...@@ -1489,7 +1489,8 @@ static bool AddEnumValues(PyTypeObject *type,
if (obj == NULL) { if (obj == NULL) {
return false; return false;
} }
if (PyDict_SetItemString(type->tp_dict, value->name().c_str(), obj) < 0) { if (PyDict_SetItemString(type->tp_dict, value->name().c_str(), obj.get()) <
0) {
return false; return false;
} }
} }
...@@ -1498,7 +1499,7 @@ static bool AddEnumValues(PyTypeObject *type, ...@@ -1498,7 +1499,7 @@ static bool AddEnumValues(PyTypeObject *type,
static bool AddIntConstant(PyTypeObject *type, const char* name, int value) { static bool AddIntConstant(PyTypeObject *type, const char* name, int value) {
ScopedPyObjectPtr obj(PyInt_FromLong(value)); ScopedPyObjectPtr obj(PyInt_FromLong(value));
if (PyDict_SetItemString(type->tp_dict, name, obj) < 0) { if (PyDict_SetItemString(type->tp_dict, name, obj.get()) < 0) {
return false; return false;
} }
return true; return true;
......
...@@ -355,7 +355,7 @@ static int DescriptorSequence_Equal(PyContainer* self, PyObject* other) { ...@@ -355,7 +355,7 @@ static int DescriptorSequence_Equal(PyContainer* self, PyObject* other) {
if (value2 == NULL) { if (value2 == NULL) {
return -1; return -1;
} }
int cmp = PyObject_RichCompareBool(value1, value2, Py_EQ); int cmp = PyObject_RichCompareBool(value1.get(), value2, Py_EQ);
if (cmp != 1) // error or not equal if (cmp != 1) // error or not equal
return cmp; return cmp;
} }
...@@ -399,12 +399,12 @@ static int DescriptorMapping_Equal(PyContainer* self, PyObject* other) { ...@@ -399,12 +399,12 @@ static int DescriptorMapping_Equal(PyContainer* self, PyObject* other) {
if (value1 == NULL) { if (value1 == NULL) {
return -1; return -1;
} }
PyObject* value2 = PyDict_GetItem(other, key); PyObject* value2 = PyDict_GetItem(other, key.get());
if (value2 == NULL) { if (value2 == NULL) {
// Not found in the other dictionary // Not found in the other dictionary
return 0; return 0;
} }
int cmp = PyObject_RichCompareBool(value1, value2, Py_EQ); int cmp = PyObject_RichCompareBool(value1.get(), value2, Py_EQ);
if (cmp != 1) // error or not equal if (cmp != 1) // error or not equal
return cmp; return cmp;
} }
......
...@@ -394,7 +394,7 @@ PyObject* Add(PyDescriptorPool* self, PyObject* file_descriptor_proto) { ...@@ -394,7 +394,7 @@ PyObject* Add(PyDescriptorPool* self, PyObject* file_descriptor_proto) {
if (serialized_pb == NULL) { if (serialized_pb == NULL) {
return NULL; return NULL;
} }
return AddSerializedFile(self, serialized_pb); return AddSerializedFile(self, serialized_pb.get());
} }
static PyMethodDef Methods[] = { static PyMethodDef Methods[] = {
......
...@@ -211,7 +211,7 @@ PyObject* _FindExtensionByName(ExtensionDict* self, PyObject* name) { ...@@ -211,7 +211,7 @@ PyObject* _FindExtensionByName(ExtensionDict* self, PyObject* name) {
if (extensions_by_name == NULL) { if (extensions_by_name == NULL) {
return NULL; return NULL;
} }
PyObject* result = PyDict_GetItem(extensions_by_name, name); PyObject* result = PyDict_GetItem(extensions_by_name.get(), name);
if (result == NULL) { if (result == NULL) {
Py_RETURN_NONE; Py_RETURN_NONE;
} else { } else {
......
This diff is collapsed.
...@@ -155,7 +155,7 @@ static PyObject* GetCMessage(MessageMapContainer* self, Message* entry) { ...@@ -155,7 +155,7 @@ static PyObject* GetCMessage(MessageMapContainer* self, Message* entry) {
Message* message = entry->GetReflection()->MutableMessage( Message* message = entry->GetReflection()->MutableMessage(
entry, self->value_field_descriptor); entry, self->value_field_descriptor);
ScopedPyObjectPtr key(PyLong_FromVoidPtr(message)); ScopedPyObjectPtr key(PyLong_FromVoidPtr(message));
PyObject* ret = PyDict_GetItem(self->message_dict, key); PyObject* ret = PyDict_GetItem(self->message_dict, key.get());
if (ret == NULL) { if (ret == NULL) {
CMessage* cmsg = cmessage::NewEmptyMessage(self->subclass_init, CMessage* cmsg = cmessage::NewEmptyMessage(self->subclass_init,
...@@ -169,7 +169,7 @@ static PyObject* GetCMessage(MessageMapContainer* self, Message* entry) { ...@@ -169,7 +169,7 @@ static PyObject* GetCMessage(MessageMapContainer* self, Message* entry) {
cmsg->message = message; cmsg->message = message;
cmsg->parent = self->parent; cmsg->parent = self->parent;
if (PyDict_SetItem(self->message_dict, key, ret) < 0) { if (PyDict_SetItem(self->message_dict, key.get(), ret) < 0) {
Py_DECREF(ret); Py_DECREF(ret);
return NULL; return NULL;
} }
...@@ -202,7 +202,7 @@ int MapKeyMatches(MessageMapContainer* self, const Message* entry, ...@@ -202,7 +202,7 @@ int MapKeyMatches(MessageMapContainer* self, const Message* entry,
// TODO(haberman): do we need more strict type checking? // TODO(haberman): do we need more strict type checking?
ScopedPyObjectPtr entry_key( ScopedPyObjectPtr entry_key(
cmessage::InternalGetScalar(entry, self->key_field_descriptor)); cmessage::InternalGetScalar(entry, self->key_field_descriptor));
int ret = PyObject_RichCompareBool(key, entry_key, Py_EQ); int ret = PyObject_RichCompareBool(key, entry_key.get(), Py_EQ);
return ret; return ret;
} }
...@@ -237,7 +237,7 @@ int SetItem(PyObject *_self, PyObject *key, PyObject *v) { ...@@ -237,7 +237,7 @@ int SetItem(PyObject *_self, PyObject *key, PyObject *v) {
if (matches < 0) return -1; if (matches < 0) return -1;
if (matches) { if (matches) {
found = true; found = true;
if (i != size - 1) { if (i != (int)size - 1) {
reflection->SwapElements(message, self->parent_field_descriptor, i, reflection->SwapElements(message, self->parent_field_descriptor, i,
size - 1); size - 1);
} }
...@@ -266,7 +266,7 @@ PyObject* GetIterator(PyObject *_self) { ...@@ -266,7 +266,7 @@ PyObject* GetIterator(PyObject *_self) {
return PyErr_Format(PyExc_KeyError, "Could not allocate iterator"); return PyErr_Format(PyExc_KeyError, "Could not allocate iterator");
} }
MessageMapIterator* iter = GetIter(obj); MessageMapIterator* iter = GetIter(obj.get());
Py_INCREF(self); Py_INCREF(self);
iter->container = self; iter->container = self;
...@@ -354,7 +354,7 @@ PyObject* Contains(PyObject* _self, PyObject* key) { ...@@ -354,7 +354,7 @@ PyObject* Contains(PyObject* _self, PyObject* key) {
// via linear search. // via linear search.
// //
// TODO(haberman): add lookup API to Reflection API. // TODO(haberman): add lookup API to Reflection API.
size_t size = int size =
reflection->FieldSize(*message, self->parent_field_descriptor); reflection->FieldSize(*message, self->parent_field_descriptor);
for (int i = 0; i < size; i++) { for (int i = 0; i < size; i++) {
Message* entry = reflection->MutableRepeatedMessage( Message* entry = reflection->MutableRepeatedMessage(
...@@ -405,12 +405,6 @@ PyObject* Get(PyObject* self, PyObject* args) { ...@@ -405,12 +405,6 @@ PyObject* Get(PyObject* self, PyObject* args) {
} }
} }
static PyMappingMethods MpMethods = {
Length, // mp_length
GetItem, // mp_subscript
SetItem, // mp_ass_subscript
};
static void Dealloc(PyObject* _self) { static void Dealloc(PyObject* _self) {
MessageMapContainer* self = GetMap(_self); MessageMapContainer* self = GetMap(_self);
self->owner.reset(); self->owner.reset();
...@@ -485,6 +479,12 @@ PyObject* IterNext(PyObject* _self) { ...@@ -485,6 +479,12 @@ PyObject* IterNext(PyObject* _self) {
PyObject *MessageMapContainer_Type; PyObject *MessageMapContainer_Type;
#else #else
static PyMappingMethods MpMethods = {
message_map_container::Length, // mp_length
message_map_container::GetItem, // mp_subscript
message_map_container::SetItem, // mp_ass_subscript
};
PyTypeObject MessageMapContainer_Type = { PyTypeObject MessageMapContainer_Type = {
PyVarObject_HEAD_INIT(&PyType_Type, 0) PyVarObject_HEAD_INIT(&PyType_Type, 0)
FULL_MODULE_NAME ".MessageMapContainer", // tp_name FULL_MODULE_NAME ".MessageMapContainer", // tp_name
...@@ -498,7 +498,7 @@ PyObject* IterNext(PyObject* _self) { ...@@ -498,7 +498,7 @@ PyObject* IterNext(PyObject* _self) {
0, // tp_repr 0, // tp_repr
0, // tp_as_number 0, // tp_as_number
0, // tp_as_sequence 0, // tp_as_sequence
&message_map_container::MpMethods, // tp_as_mapping &MpMethods, // tp_as_mapping
0, // tp_hash 0, // tp_hash
0, // tp_call 0, // tp_call
0, // tp_str 0, // tp_str
......
...@@ -116,7 +116,7 @@ static int UpdateChildMessages(RepeatedCompositeContainer* self) { ...@@ -116,7 +116,7 @@ static int UpdateChildMessages(RepeatedCompositeContainer* self) {
cmsg->owner = self->owner; cmsg->owner = self->owner;
cmsg->message = const_cast<Message*>(&sub_message); cmsg->message = const_cast<Message*>(&sub_message);
cmsg->parent = self->parent; cmsg->parent = self->parent;
if (PyList_Append(self->child_messages, py_cmsg) < 0) { if (PyList_Append(self->child_messages, py_cmsg.get()) < 0) {
return -1; return -1;
} }
} }
...@@ -202,8 +202,8 @@ PyObject* Extend(RepeatedCompositeContainer* self, PyObject* value) { ...@@ -202,8 +202,8 @@ PyObject* Extend(RepeatedCompositeContainer* self, PyObject* value) {
return NULL; return NULL;
} }
ScopedPyObjectPtr next; ScopedPyObjectPtr next;
while ((next.reset(PyIter_Next(iter))) != NULL) { while ((next.reset(PyIter_Next(iter.get()))) != NULL) {
if (!PyObject_TypeCheck(next, &CMessage_Type)) { if (!PyObject_TypeCheck(next.get(), &CMessage_Type)) {
PyErr_SetString(PyExc_TypeError, "Not a cmessage"); PyErr_SetString(PyExc_TypeError, "Not a cmessage");
return NULL; return NULL;
} }
...@@ -212,7 +212,8 @@ PyObject* Extend(RepeatedCompositeContainer* self, PyObject* value) { ...@@ -212,7 +212,8 @@ PyObject* Extend(RepeatedCompositeContainer* self, PyObject* value) {
return NULL; return NULL;
} }
CMessage* new_cmessage = reinterpret_cast<CMessage*>(new_message.get()); CMessage* new_cmessage = reinterpret_cast<CMessage*>(new_message.get());
if (ScopedPyObjectPtr(cmessage::MergeFrom(new_cmessage, next)) == NULL) { if (ScopedPyObjectPtr(cmessage::MergeFrom(new_cmessage, next.get())) ==
NULL) {
return NULL; return NULL;
} }
} }
...@@ -294,7 +295,7 @@ static PyObject* Remove(RepeatedCompositeContainer* self, PyObject* value) { ...@@ -294,7 +295,7 @@ static PyObject* Remove(RepeatedCompositeContainer* self, PyObject* value) {
return NULL; return NULL;
} }
ScopedPyObjectPtr py_index(PyLong_FromLong(index)); ScopedPyObjectPtr py_index(PyLong_FromLong(index));
if (AssignSubscript(self, py_index, NULL) < 0) { if (AssignSubscript(self, py_index.get(), NULL) < 0) {
return NULL; return NULL;
} }
Py_RETURN_NONE; Py_RETURN_NONE;
...@@ -318,17 +319,17 @@ static PyObject* RichCompare(RepeatedCompositeContainer* self, ...@@ -318,17 +319,17 @@ static PyObject* RichCompare(RepeatedCompositeContainer* self,
if (full_slice == NULL) { if (full_slice == NULL) {
return NULL; return NULL;
} }
ScopedPyObjectPtr list(Subscript(self, full_slice)); ScopedPyObjectPtr list(Subscript(self, full_slice.get()));
if (list == NULL) { if (list == NULL) {
return NULL; return NULL;
} }
ScopedPyObjectPtr other_list( ScopedPyObjectPtr other_list(
Subscript( Subscript(reinterpret_cast<RepeatedCompositeContainer*>(other),
reinterpret_cast<RepeatedCompositeContainer*>(other), full_slice)); full_slice.get()));
if (other_list == NULL) { if (other_list == NULL) {
return NULL; return NULL;
} }
return PyObject_RichCompare(list, other_list, opid); return PyObject_RichCompare(list.get(), other_list.get(), opid);
} else { } else {
Py_INCREF(Py_NotImplemented); Py_INCREF(Py_NotImplemented);
return Py_NotImplemented; return Py_NotImplemented;
...@@ -365,7 +366,7 @@ static int SortPythonMessages(RepeatedCompositeContainer* self, ...@@ -365,7 +366,7 @@ static int SortPythonMessages(RepeatedCompositeContainer* self,
ScopedPyObjectPtr m(PyObject_GetAttrString(self->child_messages, "sort")); ScopedPyObjectPtr m(PyObject_GetAttrString(self->child_messages, "sort"));
if (m == NULL) if (m == NULL)
return -1; return -1;
if (PyObject_Call(m, args, kwds) == NULL) if (PyObject_Call(m.get(), args, kwds) == NULL)
return -1; return -1;
if (self->message != NULL) { if (self->message != NULL) {
ReorderAttached(self); ReorderAttached(self);
...@@ -429,7 +430,7 @@ static PyObject* Pop(RepeatedCompositeContainer* self, ...@@ -429,7 +430,7 @@ static PyObject* Pop(RepeatedCompositeContainer* self,
return NULL; return NULL;
} }
ScopedPyObjectPtr py_index(PyLong_FromSsize_t(index)); ScopedPyObjectPtr py_index(PyLong_FromSsize_t(index));
if (AssignSubscript(self, py_index, NULL) < 0) { if (AssignSubscript(self, py_index.get(), NULL) < 0) {
return NULL; return NULL;
} }
return item; return item;
......
...@@ -108,9 +108,6 @@ PyObject *NewContainer( ...@@ -108,9 +108,6 @@ PyObject *NewContainer(
const FieldDescriptor* parent_field_descriptor, const FieldDescriptor* parent_field_descriptor,
PyObject *concrete_class); PyObject *concrete_class);
// Returns the number of items in this repeated composite container.
static Py_ssize_t Length(RepeatedCompositeContainer* self);
// Appends a new CMessage to the container and returns it. The // Appends a new CMessage to the container and returns it. The
// CMessage is initialized using the content of kwargs. // CMessage is initialized using the content of kwargs.
// //
......
...@@ -105,7 +105,7 @@ static int AssignItem(RepeatedScalarContainer* self, ...@@ -105,7 +105,7 @@ static int AssignItem(RepeatedScalarContainer* self,
if (arg == NULL) { if (arg == NULL) {
ScopedPyObjectPtr py_index(PyLong_FromLong(index)); ScopedPyObjectPtr py_index(PyLong_FromLong(index));
return cmessage::InternalDeleteRepeatedField(self->parent, field_descriptor, return cmessage::InternalDeleteRepeatedField(self->parent, field_descriptor,
py_index, NULL); py_index.get(), NULL);
} }
if (PySequence_Check(arg) && !(PyBytes_Check(arg) || PyUnicode_Check(arg))) { if (PySequence_Check(arg) && !(PyBytes_Check(arg) || PyUnicode_Check(arg))) {
...@@ -172,7 +172,7 @@ static int AssignItem(RepeatedScalarContainer* self, ...@@ -172,7 +172,7 @@ static int AssignItem(RepeatedScalarContainer* self,
ScopedPyObjectPtr s(PyObject_Str(arg)); ScopedPyObjectPtr s(PyObject_Str(arg));
if (s != NULL) { if (s != NULL) {
PyErr_Format(PyExc_ValueError, "Unknown enum value: %s", PyErr_Format(PyExc_ValueError, "Unknown enum value: %s",
PyString_AsString(s)); PyString_AsString(s.get()));
} }
return -1; return -1;
} }
...@@ -334,7 +334,7 @@ static PyObject* Subscript(RepeatedScalarContainer* self, PyObject* slice) { ...@@ -334,7 +334,7 @@ static PyObject* Subscript(RepeatedScalarContainer* self, PyObject* slice) {
break; break;
} }
ScopedPyObjectPtr s(Item(self, index)); ScopedPyObjectPtr s(Item(self, index));
PyList_Append(list, s); PyList_Append(list, s.get());
} }
} else { } else {
if (step > 0) { if (step > 0) {
...@@ -345,7 +345,7 @@ static PyObject* Subscript(RepeatedScalarContainer* self, PyObject* slice) { ...@@ -345,7 +345,7 @@ static PyObject* Subscript(RepeatedScalarContainer* self, PyObject* slice) {
break; break;
} }
ScopedPyObjectPtr s(Item(self, index)); ScopedPyObjectPtr s(Item(self, index));
PyList_Append(list, s); PyList_Append(list, s.get());
} }
} }
return list; return list;
...@@ -414,7 +414,7 @@ PyObject* Append(RepeatedScalarContainer* self, PyObject* item) { ...@@ -414,7 +414,7 @@ PyObject* Append(RepeatedScalarContainer* self, PyObject* item) {
ScopedPyObjectPtr s(PyObject_Str(item)); ScopedPyObjectPtr s(PyObject_Str(item));
if (s != NULL) { if (s != NULL) {
PyErr_Format(PyExc_ValueError, "Unknown enum value: %s", PyErr_Format(PyExc_ValueError, "Unknown enum value: %s",
PyString_AsString(s)); PyString_AsString(s.get()));
} }
return NULL; return NULL;
} }
...@@ -483,15 +483,15 @@ static int AssSubscript(RepeatedScalarContainer* self, ...@@ -483,15 +483,15 @@ static int AssSubscript(RepeatedScalarContainer* self,
if (full_slice == NULL) { if (full_slice == NULL) {
return -1; return -1;
} }
ScopedPyObjectPtr new_list(Subscript(self, full_slice)); ScopedPyObjectPtr new_list(Subscript(self, full_slice.get()));
if (new_list == NULL) { if (new_list == NULL) {
return -1; return -1;
} }
if (PySequence_SetSlice(new_list, from, to, value) < 0) { if (PySequence_SetSlice(new_list.get(), from, to, value) < 0) {
return -1; return -1;
} }
return InternalAssignRepeatedField(self, new_list); return InternalAssignRepeatedField(self, new_list.get());
} }
PyObject* Extend(RepeatedScalarContainer* self, PyObject* value) { PyObject* Extend(RepeatedScalarContainer* self, PyObject* value) {
...@@ -511,8 +511,8 @@ PyObject* Extend(RepeatedScalarContainer* self, PyObject* value) { ...@@ -511,8 +511,8 @@ PyObject* Extend(RepeatedScalarContainer* self, PyObject* value) {
return NULL; return NULL;
} }
ScopedPyObjectPtr next; ScopedPyObjectPtr next;
while ((next.reset(PyIter_Next(iter))) != NULL) { while ((next.reset(PyIter_Next(iter.get()))) != NULL) {
if (ScopedPyObjectPtr(Append(self, next)) == NULL) { if (ScopedPyObjectPtr(Append(self, next.get())) == NULL) {
return NULL; return NULL;
} }
} }
...@@ -529,11 +529,11 @@ static PyObject* Insert(RepeatedScalarContainer* self, PyObject* args) { ...@@ -529,11 +529,11 @@ static PyObject* Insert(RepeatedScalarContainer* self, PyObject* args) {
return NULL; return NULL;
} }
ScopedPyObjectPtr full_slice(PySlice_New(NULL, NULL, NULL)); ScopedPyObjectPtr full_slice(PySlice_New(NULL, NULL, NULL));
ScopedPyObjectPtr new_list(Subscript(self, full_slice)); ScopedPyObjectPtr new_list(Subscript(self, full_slice.get()));
if (PyList_Insert(new_list, index, value) < 0) { if (PyList_Insert(new_list.get(), index, value) < 0) {
return NULL; return NULL;
} }
int ret = InternalAssignRepeatedField(self, new_list); int ret = InternalAssignRepeatedField(self, new_list.get());
if (ret < 0) { if (ret < 0) {
return NULL; return NULL;
} }
...@@ -544,7 +544,7 @@ static PyObject* Remove(RepeatedScalarContainer* self, PyObject* value) { ...@@ -544,7 +544,7 @@ static PyObject* Remove(RepeatedScalarContainer* self, PyObject* value) {
Py_ssize_t match_index = -1; Py_ssize_t match_index = -1;
for (Py_ssize_t i = 0; i < Len(self); ++i) { for (Py_ssize_t i = 0; i < Len(self); ++i) {
ScopedPyObjectPtr elem(Item(self, i)); ScopedPyObjectPtr elem(Item(self, i));
if (PyObject_RichCompareBool(elem, value, Py_EQ)) { if (PyObject_RichCompareBool(elem.get(), value, Py_EQ)) {
match_index = i; match_index = i;
break; break;
} }
...@@ -579,15 +579,15 @@ static PyObject* RichCompare(RepeatedScalarContainer* self, ...@@ -579,15 +579,15 @@ static PyObject* RichCompare(RepeatedScalarContainer* self,
ScopedPyObjectPtr other_list_deleter; ScopedPyObjectPtr other_list_deleter;
if (PyObject_TypeCheck(other, &RepeatedScalarContainer_Type)) { if (PyObject_TypeCheck(other, &RepeatedScalarContainer_Type)) {
other_list_deleter.reset(Subscript( other_list_deleter.reset(Subscript(
reinterpret_cast<RepeatedScalarContainer*>(other), full_slice)); reinterpret_cast<RepeatedScalarContainer*>(other), full_slice.get()));
other = other_list_deleter.get(); other = other_list_deleter.get();
} }
ScopedPyObjectPtr list(Subscript(self, full_slice)); ScopedPyObjectPtr list(Subscript(self, full_slice.get()));
if (list == NULL) { if (list == NULL) {
return NULL; return NULL;
} }
return PyObject_RichCompare(list, other, opid); return PyObject_RichCompare(list.get(), other, opid);
} }
PyObject* Reduce(RepeatedScalarContainer* unused_self) { PyObject* Reduce(RepeatedScalarContainer* unused_self) {
...@@ -618,19 +618,19 @@ static PyObject* Sort(RepeatedScalarContainer* self, ...@@ -618,19 +618,19 @@ static PyObject* Sort(RepeatedScalarContainer* self,
if (full_slice == NULL) { if (full_slice == NULL) {
return NULL; return NULL;
} }
ScopedPyObjectPtr list(Subscript(self, full_slice)); ScopedPyObjectPtr list(Subscript(self, full_slice.get()));
if (list == NULL) { if (list == NULL) {
return NULL; return NULL;
} }
ScopedPyObjectPtr m(PyObject_GetAttrString(list, "sort")); ScopedPyObjectPtr m(PyObject_GetAttrString(list.get(), "sort"));
if (m == NULL) { if (m == NULL) {
return NULL; return NULL;
} }
ScopedPyObjectPtr res(PyObject_Call(m, args, kwds)); ScopedPyObjectPtr res(PyObject_Call(m.get(), args, kwds));
if (res == NULL) { if (res == NULL) {
return NULL; return NULL;
} }
int ret = InternalAssignRepeatedField(self, list); int ret = InternalAssignRepeatedField(self, list.get());
if (ret < 0) { if (ret < 0) {
return NULL; return NULL;
} }
...@@ -688,7 +688,7 @@ static int InitializeAndCopyToParentContainer( ...@@ -688,7 +688,7 @@ static int InitializeAndCopyToParentContainer(
if (full_slice == NULL) { if (full_slice == NULL) {
return -1; return -1;
} }
ScopedPyObjectPtr values(Subscript(from, full_slice)); ScopedPyObjectPtr values(Subscript(from, full_slice.get()));
if (values == NULL) { if (values == NULL) {
return -1; return -1;
} }
...@@ -697,7 +697,7 @@ static int InitializeAndCopyToParentContainer( ...@@ -697,7 +697,7 @@ static int InitializeAndCopyToParentContainer(
to->parent_field_descriptor = from->parent_field_descriptor; to->parent_field_descriptor = from->parent_field_descriptor;
to->message = new_message; to->message = new_message;
to->owner.reset(new_message); to->owner.reset(new_message);
if (InternalAssignRepeatedField(to, values) < 0) { if (InternalAssignRepeatedField(to, values.get()) < 0) {
return -1; return -1;
} }
return 0; return 0;
......
...@@ -94,7 +94,7 @@ PyObject *NewContainer( ...@@ -94,7 +94,7 @@ PyObject *NewContainer(
"Could not allocate new container."); "Could not allocate new container.");
} }
ScalarMapContainer* self = GetMap(obj); ScalarMapContainer* self = GetMap(obj.get());
self->message = parent->message; self->message = parent->message;
self->parent = parent; self->parent = parent;
...@@ -160,7 +160,7 @@ int MapKeyMatches(ScalarMapContainer* self, const Message* entry, ...@@ -160,7 +160,7 @@ int MapKeyMatches(ScalarMapContainer* self, const Message* entry,
// TODO(haberman): do we need more strict type checking? // TODO(haberman): do we need more strict type checking?
ScopedPyObjectPtr entry_key( ScopedPyObjectPtr entry_key(
cmessage::InternalGetScalar(entry, self->key_field_descriptor)); cmessage::InternalGetScalar(entry, self->key_field_descriptor));
int ret = PyObject_RichCompareBool(key, entry_key, Py_EQ); int ret = PyObject_RichCompareBool(key, entry_key.get(), Py_EQ);
return ret; return ret;
} }
...@@ -251,7 +251,7 @@ int SetItem(PyObject *_self, PyObject *key, PyObject *v) { ...@@ -251,7 +251,7 @@ int SetItem(PyObject *_self, PyObject *key, PyObject *v) {
if (matches < 0) return -1; if (matches < 0) return -1;
if (matches) { if (matches) {
found = true; found = true;
if (i != size - 1) { if (i != (int)size - 1) {
reflection->SwapElements(message, self->parent_field_descriptor, i, reflection->SwapElements(message, self->parent_field_descriptor, i,
size - 1); size - 1);
} }
...@@ -303,7 +303,7 @@ PyObject* GetIterator(PyObject *_self) { ...@@ -303,7 +303,7 @@ PyObject* GetIterator(PyObject *_self) {
// TODO(haberman): add lookup API to Reflection API. // TODO(haberman): add lookup API to Reflection API.
size_t size = size_t size =
reflection->FieldSize(*message, self->parent_field_descriptor); reflection->FieldSize(*message, self->parent_field_descriptor);
for (int i = 0; i < size; i++) { for (size_t i = 0; i < size; i++) {
Message* entry = reflection->MutableRepeatedMessage( Message* entry = reflection->MutableRepeatedMessage(
message, self->parent_field_descriptor, i); message, self->parent_field_descriptor, i);
ScopedPyObjectPtr key( ScopedPyObjectPtr key(
...@@ -382,12 +382,6 @@ PyObject* Get(PyObject* self, PyObject* args) { ...@@ -382,12 +382,6 @@ PyObject* Get(PyObject* self, PyObject* args) {
} }
} }
static PyMappingMethods MpMethods = {
Length, // mp_length
GetItem, // mp_subscript
SetItem, // mp_ass_subscript
};
static void Dealloc(PyObject* _self) { static void Dealloc(PyObject* _self) {
ScalarMapContainer* self = GetMap(_self); ScalarMapContainer* self = GetMap(_self);
self->owner.reset(); self->owner.reset();
...@@ -458,6 +452,12 @@ PyObject* IterNext(PyObject* _self) { ...@@ -458,6 +452,12 @@ PyObject* IterNext(PyObject* _self) {
}; };
PyObject *ScalarMapContainer_Type; PyObject *ScalarMapContainer_Type;
#else #else
static PyMappingMethods MpMethods = {
scalar_map_container::Length, // mp_length
scalar_map_container::GetItem, // mp_subscript
scalar_map_container::SetItem, // mp_ass_subscript
};
PyTypeObject ScalarMapContainer_Type = { PyTypeObject ScalarMapContainer_Type = {
PyVarObject_HEAD_INIT(&PyType_Type, 0) PyVarObject_HEAD_INIT(&PyType_Type, 0)
FULL_MODULE_NAME ".ScalarMapContainer", // tp_name FULL_MODULE_NAME ".ScalarMapContainer", // tp_name
...@@ -471,7 +471,7 @@ PyObject* IterNext(PyObject* _self) { ...@@ -471,7 +471,7 @@ PyObject* IterNext(PyObject* _self) {
0, // tp_repr 0, // tp_repr
0, // tp_as_number 0, // tp_as_number
0, // tp_as_sequence 0, // tp_as_sequence
&scalar_map_container::MpMethods, // tp_as_mapping &MpMethods, // tp_as_mapping
0, // tp_hash 0, // tp_hash
0, // tp_call 0, // tp_call
0, // tp_str 0, // tp_str
......
...@@ -60,11 +60,6 @@ class ScopedPyObjectPtr { ...@@ -60,11 +60,6 @@ class ScopedPyObjectPtr {
return ptr_; return ptr_;
} }
// ScopedPyObjectPtr should not be copied.
// We explicitly list and delete this overload to avoid automatic conversion
// to PyObject*, which is wrong in this case.
PyObject* reset(const ScopedPyObjectPtr& other) = delete;
// Releases ownership of the object. // Releases ownership of the object.
// The caller now owns the returned reference. // The caller now owns the returned reference.
PyObject* release() { PyObject* release() {
...@@ -73,8 +68,6 @@ class ScopedPyObjectPtr { ...@@ -73,8 +68,6 @@ class ScopedPyObjectPtr {
return p; return p;
} }
operator PyObject*() { return ptr_; }
PyObject* operator->() const { PyObject* operator->() const {
assert(ptr_ != NULL); assert(ptr_ != NULL);
return ptr_; return ptr_;
......
...@@ -148,17 +148,24 @@ class build_py(_build_py): ...@@ -148,17 +148,24 @@ class build_py(_build_py):
if __name__ == '__main__': if __name__ == '__main__':
ext_module_list = [] ext_module_list = []
cpp_impl = '--cpp_implementation' cpp_impl = '--cpp_implementation'
warnings_as_errors = '--warnings_as_errors'
if cpp_impl in sys.argv: if cpp_impl in sys.argv:
sys.argv.remove(cpp_impl) sys.argv.remove(cpp_impl)
extra_compile_args = ['-Wno-write-strings']
if warnings_as_errors in sys.argv:
extra_compile_args.append('-Werror')
sys.argv.remove(warnings_as_errors)
# C++ implementation extension # C++ implementation extension
ext_module_list.append( ext_module_list.append(
Extension( Extension(
"google.protobuf.pyext._message", "google.protobuf.pyext._message",
glob.glob('google/protobuf/pyext/*.cc'), glob.glob('google/protobuf/pyext/*.cc'),
define_macros=[('GOOGLE_PROTOBUF_HAS_ONEOF', '1')],
include_dirs=[".", "../src"], include_dirs=[".", "../src"],
libraries=['protobuf'], libraries=['protobuf'],
library_dirs=['../src/.libs'], library_dirs=['../src/.libs'],
extra_compile_args=extra_compile_args,
) )
) )
os.environ['PROTOCOL_BUFFERS_PYTHON_IMPLEMENTATION'] = 'cpp' os.environ['PROTOCOL_BUFFERS_PYTHON_IMPLEMENTATION'] = 'cpp'
......
...@@ -13,7 +13,7 @@ setenv = ...@@ -13,7 +13,7 @@ setenv =
commands = commands =
python setup.py -q build_py python setup.py -q build_py
python: python setup.py -q build python: python setup.py -q build
cpp: python setup.py -q build --cpp_implementation cpp: python setup.py -q build --cpp_implementation --warnings_as_errors
python: python setup.py -q test -q python: python setup.py -q test -q
cpp: python setup.py -q test -q --cpp_implementation cpp: python setup.py -q test -q --cpp_implementation
deps = deps =
......
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