From fc80fad9d543922f5cfaed06e39bc93f07f6baa6 Mon Sep 17 00:00:00 2001 From: Josh Haberman Date: Fri, 28 Aug 2015 16:34:48 -0700 Subject: [PATCH 1/2] Fix for https://github.com/google/protobuf/issues/758 Change-Id: I590b34b96c84a3ba6e094a0bd86f153147ade3d3 --- python/google/protobuf/pyext/message.cc | 31 ++++++++++++++----------- 1 file changed, 17 insertions(+), 14 deletions(-) diff --git a/python/google/protobuf/pyext/message.cc b/python/google/protobuf/pyext/message.cc index aa3ab97a6..ed07de164 100644 --- a/python/google/protobuf/pyext/message.cc +++ b/python/google/protobuf/pyext/message.cc @@ -1776,22 +1776,25 @@ class PythonFieldValuePrinter : public TextFormat::FieldValuePrinter { // Python floats to ensure consistency. string PrintFloat(float value) const { return PrintDouble(value); } string PrintDouble(double value) const { - // Same as float.__str__() - char* buf = PyOS_double_to_string( - value, -#if PY_MAJOR_VERSION < 3 - 'g', PyFloat_STR_PRECISION, // Output is rounded to 12 digits. -#else - 'r', 0, -#endif - Py_DTSF_ADD_DOT_0, // Trailing .0 is always printed. - NULL); - if (!buf) { + // This implementation is not highly optimized (it allocates two temporary + // Python objects) but it is simple and portable. If this is shown to be a + // performance bottleneck, we can optimize it, but the results will likely + // be more complicated to accommodate the differing behavior of double + // formatting between Python 2 and Python 3. + // + // (Though a valid question is: do we really want to make out output + // dependent on the Python version?) + ScopedPyObjectPtr py_value(PyFloat_FromDouble(value)); + if (!py_value.get()) { return string(); } - string result(buf); - PyMem_Free(buf); - return result; + + ScopedPyObjectPtr py_str(PyObject_Str(py_value.get())); + if (!py_str.get()) { + return string(); + } + + return string(PyString_AsString(py_str.get())); } }; From 4472b4ad15827c61d2759776dccadff48a973061 Mon Sep 17 00:00:00 2001 From: Josh Haberman Date: Fri, 28 Aug 2015 19:21:49 -0700 Subject: [PATCH 2/2] Fixed assignment syntax error. Change-Id: Ifef8a300258214aae8f6b8516fbc61b7335b5724 --- python/google/protobuf/pyext/message.cc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/python/google/protobuf/pyext/message.cc b/python/google/protobuf/pyext/message.cc index ed07de164..62c7c478f 100644 --- a/python/google/protobuf/pyext/message.cc +++ b/python/google/protobuf/pyext/message.cc @@ -340,7 +340,7 @@ static int InsertEmptyWeakref(PyTypeObject *base_type) { } // namespace message_meta -PyTypeObject PyMessageMeta_Type { +PyTypeObject PyMessageMeta_Type = { PyVarObject_HEAD_INIT(&PyType_Type, 0) FULL_MODULE_NAME ".MessageMeta", // tp_name sizeof(PyMessageMeta), // tp_basicsize