Merge 3.11.0-rc1 changes to master (#6917)
* Update CHANGES.txt with 3.11.0-RC1 release notes (#6909) * Revert "Make shared libraries be able to link to MSVC static runtime libraries, so that VC runtime is not required." (#6914) * Marked update_compatibility_version.py as executable (#6916)
This commit is contained in:
parent
3cae867740
commit
de75651d7a
52
CHANGES.txt
52
CHANGES.txt
@ -1,3 +1,55 @@
|
|||||||
|
2019-11-19 version 3.11.0 (C++/Java/Python/PHP/Objective-C/C#/Ruby/JavaScript)
|
||||||
|
|
||||||
|
C++
|
||||||
|
* Make serialization method naming consistent
|
||||||
|
* Make proto runtime + generated code free of deprecation warnings
|
||||||
|
* Moved ShutdownProtobufLibrary() to message_lite.h. For backward compatibility a declaration is still available in stubs/common.h, but users should prefer message_lite.h
|
||||||
|
* Removed non-namespace macro EXPECT_OK()
|
||||||
|
* Removed mathlimits.h from stubs in favor of using std::numeric_limits from C++11
|
||||||
|
* Fixed bug in parser when ending on a group tag
|
||||||
|
* Add a helper function to UnknownFieldSet to deal with the changing return value of message::unknown_fields()
|
||||||
|
* Fix incorrect use of string_view iterators
|
||||||
|
* Support direct pickling of nested messages
|
||||||
|
* Skip extension tag validation for MessageSet if unknown dependencies are allowed
|
||||||
|
* Updated deprecation macros to annotate deprecated code (#6612)
|
||||||
|
* Remove conversion warning in MapEntryFuncs::ByteSizeLong (#6766)
|
||||||
|
|
||||||
|
Java
|
||||||
|
* Remove the usage of MethodHandle, so that Android users prior to API version 26 can use protobuf-java
|
||||||
|
* Publish ProGuard config for javalite
|
||||||
|
* Fix for StrictMode disk read violation in ExtensionRegistryLite
|
||||||
|
* Include part of the ByteString's content in its toString().
|
||||||
|
* Include unknown fields when merging proto3 messages in Java lite builders
|
||||||
|
|
||||||
|
Python
|
||||||
|
* Add float_precision option in json format printer
|
||||||
|
* Optionally print bytes fields as messages in unknown fields, if possible
|
||||||
|
* FieldPath: fix testing IsSet on root path ''
|
||||||
|
* Experimental code gen (fast import protobuf module) which only work with cpp generated code linked in
|
||||||
|
|
||||||
|
JavaScript
|
||||||
|
* Remove guard for Symbol iterator for jspb.Map
|
||||||
|
|
||||||
|
PHP
|
||||||
|
* Avoid too much overhead in layout_init (#6716)
|
||||||
|
* Lazily Create Singular Wrapper Message (#6833)
|
||||||
|
|
||||||
|
Ruby
|
||||||
|
* Ruby lazy wrappers optimization (#6797)
|
||||||
|
|
||||||
|
C#
|
||||||
|
* (RepeatedField): Capacity property to resize the internal array (#6530)
|
||||||
|
* Experimental proto2 support is now officially available (#4642, #5183, #5350, #5936)
|
||||||
|
* Getting started doc: https://github.com/protocolbuffers/protobuf/blob/master/docs/csharp/proto2.md
|
||||||
|
* Add length checks to ExtensionCollection (#6759)
|
||||||
|
* Optimize parsing of some primitive and wrapper types (#6843)
|
||||||
|
* Use 3 parameter Encoding.GetString for default string values (#6828)
|
||||||
|
* Change _Extensions property to normal body rather than expression (#6856)
|
||||||
|
|
||||||
|
Objective C
|
||||||
|
* Fixed unaligned reads for 32bit arm with newer Xcode versions (#6678)
|
||||||
|
|
||||||
|
|
||||||
2019-09-03 version 3.10.0 (C++/Java/Python/PHP/Objective-C/C#/Ruby/JavaScript)
|
2019-09-03 version 3.10.0 (C++/Java/Python/PHP/Objective-C/C#/Ruby/JavaScript)
|
||||||
|
|
||||||
C++
|
C++
|
||||||
|
@ -40,6 +40,8 @@ else (BUILD_SHARED_LIBS)
|
|||||||
endif (BUILD_SHARED_LIBS)
|
endif (BUILD_SHARED_LIBS)
|
||||||
option(protobuf_BUILD_SHARED_LIBS "Build Shared Libraries" ${protobuf_BUILD_SHARED_LIBS_DEFAULT})
|
option(protobuf_BUILD_SHARED_LIBS "Build Shared Libraries" ${protobuf_BUILD_SHARED_LIBS_DEFAULT})
|
||||||
include(CMakeDependentOption)
|
include(CMakeDependentOption)
|
||||||
|
cmake_dependent_option(protobuf_MSVC_STATIC_RUNTIME "Link static runtime libraries" ON
|
||||||
|
"NOT protobuf_BUILD_SHARED_LIBS" OFF)
|
||||||
set(protobuf_WITH_ZLIB_DEFAULT ON)
|
set(protobuf_WITH_ZLIB_DEFAULT ON)
|
||||||
option(protobuf_WITH_ZLIB "Build with zlib support" ${protobuf_WITH_ZLIB_DEFAULT})
|
option(protobuf_WITH_ZLIB "Build with zlib support" ${protobuf_WITH_ZLIB_DEFAULT})
|
||||||
set(protobuf_DEBUG_POSTFIX "d"
|
set(protobuf_DEBUG_POSTFIX "d"
|
||||||
@ -153,22 +155,22 @@ if (protobuf_BUILD_SHARED_LIBS)
|
|||||||
set(protobuf_SHARED_OR_STATIC "SHARED")
|
set(protobuf_SHARED_OR_STATIC "SHARED")
|
||||||
else (protobuf_BUILD_SHARED_LIBS)
|
else (protobuf_BUILD_SHARED_LIBS)
|
||||||
set(protobuf_SHARED_OR_STATIC "STATIC")
|
set(protobuf_SHARED_OR_STATIC "STATIC")
|
||||||
|
# In case we are building static libraries, link also the runtime library statically
|
||||||
|
# so that MSVCR*.DLL is not required at runtime.
|
||||||
|
# https://msdn.microsoft.com/en-us/library/2kzt1wy3.aspx
|
||||||
|
# This is achieved by replacing msvc option /MD with /MT and /MDd with /MTd
|
||||||
|
# http://www.cmake.org/Wiki/CMake_FAQ#How_can_I_build_my_MSVC_application_with_a_static_runtime.3F
|
||||||
|
if (MSVC AND protobuf_MSVC_STATIC_RUNTIME)
|
||||||
|
foreach(flag_var
|
||||||
|
CMAKE_CXX_FLAGS CMAKE_CXX_FLAGS_DEBUG CMAKE_CXX_FLAGS_RELEASE
|
||||||
|
CMAKE_CXX_FLAGS_MINSIZEREL CMAKE_CXX_FLAGS_RELWITHDEBINFO)
|
||||||
|
if(${flag_var} MATCHES "/MD")
|
||||||
|
string(REGEX REPLACE "/MD" "/MT" ${flag_var} "${${flag_var}}")
|
||||||
|
endif(${flag_var} MATCHES "/MD")
|
||||||
|
endforeach(flag_var)
|
||||||
|
endif (MSVC AND protobuf_MSVC_STATIC_RUNTIME)
|
||||||
endif (protobuf_BUILD_SHARED_LIBS)
|
endif (protobuf_BUILD_SHARED_LIBS)
|
||||||
|
|
||||||
# In case we are linking the runtime library statically so that MSVCR*.DLL is not required at runtime.
|
|
||||||
# https://msdn.microsoft.com/en-us/library/2kzt1wy3.aspx
|
|
||||||
# This is achieved by replacing msvc option /MD with /MT and /MDd with /MTd
|
|
||||||
# http://www.cmake.org/Wiki/CMake_FAQ#How_can_I_build_my_MSVC_application_with_a_static_runtime.3F
|
|
||||||
if (MSVC AND protobuf_MSVC_STATIC_RUNTIME)
|
|
||||||
foreach(flag_var
|
|
||||||
CMAKE_CXX_FLAGS CMAKE_CXX_FLAGS_DEBUG CMAKE_CXX_FLAGS_RELEASE
|
|
||||||
CMAKE_CXX_FLAGS_MINSIZEREL CMAKE_CXX_FLAGS_RELWITHDEBINFO)
|
|
||||||
if(${flag_var} MATCHES "/MD")
|
|
||||||
string(REGEX REPLACE "/MD" "/MT" ${flag_var} "${${flag_var}}")
|
|
||||||
endif(${flag_var} MATCHES "/MD")
|
|
||||||
endforeach(flag_var)
|
|
||||||
endif (MSVC AND protobuf_MSVC_STATIC_RUNTIME)
|
|
||||||
|
|
||||||
if (MSVC)
|
if (MSVC)
|
||||||
# Build with multiple processes
|
# Build with multiple processes
|
||||||
add_definitions(/MP)
|
add_definitions(/MP)
|
||||||
|
0
update_compatibility_version.py
Normal file → Executable file
0
update_compatibility_version.py
Normal file → Executable file
Loading…
Reference in New Issue
Block a user