-
Notifications
You must be signed in to change notification settings - Fork 443
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support protobuf 3.22 or upper #2163
Support protobuf 3.22 or upper #2163
Conversation
Codecov Report
Additional details and impacted files@@ Coverage Diff @@
## main #2163 +/- ##
==========================================
- Coverage 87.62% 87.52% -0.10%
==========================================
Files 198 199 +1
Lines 5856 5981 +125
==========================================
+ Hits 5131 5234 +103
- Misses 725 747 +22
|
Signed-off-by: owent <[email protected]>
Signed-off-by: owent <[email protected]>
Signed-off-by: owent <[email protected]>
… gRPC Signed-off-by: owent <[email protected]>
904b15c
to
f95fd57
Compare
Signed-off-by: owent <[email protected]>
Signed-off-by: owent <[email protected]>
Signed-off-by: owent <[email protected]>
ce406cb
to
0dc7575
Compare
Signed-off-by: owent <[email protected]>
Signed-off-by: owent <[email protected]>
Signed-off-by: owent <[email protected]>
Signed-off-by: owent <[email protected]>
be9b3f9
to
6fa4e95
Compare
Signed-off-by: owent <[email protected]>
Signed-off-by: owent <[email protected]>
Signed-off-by: owent <[email protected]>
a45451a
to
8956193
Compare
Signed-off-by: owent <[email protected]>
Signed-off-by: owent <[email protected]>
…erent cmake CONFIG Signed-off-by: owent <[email protected]>
Signed-off-by: owent <[email protected]>
Signed-off-by: owent <[email protected]>
Signed-off-by: owent <[email protected]>
Signed-off-by: owent <[email protected]>
Signed-off-by: owent <[email protected]>
There seems some syntax error for modern protobuf without abseil. Is this expected, or modern protobuf does require abseil? |
@@ -63,6 +51,146 @@ namespace otlp | |||
namespace | |||
{ | |||
|
|||
using Base64EscapeChars = const unsigned char[64]; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
should these methods be moved to https://github.com/open-telemetry/opentelemetry-cpp/blob/main/api/include/opentelemetry/common/string_util.h ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There are a lot of codes here, do you think it's better to move it into sdk?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah good point, not required. We can move it later if need to share with other components. Thanks.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
base64 algorithm is moved into sdk now.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Really sorry if my comment above was not clear. I did realize that this will bloat the sdk, and we should move it only when we need to share it with other components.
I just tested this CI job and find protobuf can not work when both external and internal abseil-cpp exists.Because they share the same header paths and namespace and will have conflicts with each other. @lalitb This PR is ready to be reviewed again and thanks, |
Thanks for your analysis @owent. This would be helpful. |
@owent - Seems you missed my comment here - #2163 (comment) . Actually, I didn't ask for moving base64 from otlp to sdk in my subsequent comments. But if you want, we can keep it in sdk for now, and have a separate PR to move back to otlp. Rest of the PR looks good. |
Thanks. I can move it back to otlp exporter later in another PR. |
Fixes #2095
Changes
Protobuf depends on abseil-cpp 20230125 from v22/v4.22.
It removed
stringpiece.h
,google::protobuf::Base64Escape
and useabsl::Base64Escape
for alternative.We have encountered multiple problems related to the usage of CMake packages in the past (#705 #1359). As a solution, I have added a patch scriptcmake/patch-imported-config.cmake
that allows users to use prebuilt packages with different CONFIG settings when building otel-cpp.BTW: gRPC v1.55.0 also depend the new protobuf and abseil-cpp, so I also test the new gRPC version in the new CI job.
cmake_modern_protobuf_grpc_test
) to test building with new protobuf and gRPC.Patch imported target in cmake CONFIG packages to enable users to use prebuilt packages with different CONFIG settings.--experimental_allow_proto3_optional
when running protoc when we use protobuf 3.16 or upper. (It's not experimental any more)For significant contributions please make sure you have completed the following items:
CHANGELOG.md
updated for non-trivial changes