Skip to content

Commit

Permalink
[dependencies] ensure Protobuf 3.26 compatibility. (#1537)
Browse files Browse the repository at this point in the history
  • Loading branch information
KerstinKeller authored Apr 17, 2024
1 parent 8d4d4f6 commit f198830
Show file tree
Hide file tree
Showing 3 changed files with 92 additions and 3 deletions.
4 changes: 2 additions & 2 deletions .github/workflows/build-macos.yml
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ jobs:
target: 'desktop'

- name: Install Dependencies
run: brew install ninja doxygen graphviz protobuf@21 [email protected] pkg-config
run: brew install ninja doxygen graphviz protobuf [email protected] pkg-config

- name: Install Cap’n Proto
run: |
Expand Down Expand Up @@ -86,7 +86,7 @@ jobs:
-DECAL_THIRDPARTY_BUILD_QWT=ON \
-DECAL_THIRDPARTY_BUILD_YAML-CPP=ON \
-DCMAKE_BUILD_TYPE=Release \
-DCMAKE_PREFIX_PATH="/usr/local/opt/[email protected]:/usr/local/opt/protobuf@21" \
-DCMAKE_PREFIX_PATH=/usr/local/opt/[email protected] \
-DCMAKE_CXX_STANDARD=17 \
-DCMAKE_FIND_PACKAGE_PREFER_CONFIG=ON \
-DPython_FIND_STRATEGY=LOCATION \
Expand Down
5 changes: 5 additions & 0 deletions ecal/core/include/ecal/msg/protobuf/dynamic_json_subscriber.h
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wunused-parameter"
#endif
#include <google/protobuf/stubs/common.h>
#include <google/protobuf/util/json_util.h>
#include <google/protobuf/util/type_resolver_util.h>
#include <google/protobuf/util/type_resolver.h>
Expand Down Expand Up @@ -244,7 +245,11 @@ namespace eCAL
{

google::protobuf::util::JsonOptions options;
#if GOOGLE_PROTOBUF_VERSION >= 5026000
options.always_print_fields_with_no_presence = true;
#else
options.always_print_primitive_fields = true;
#endif

std::string binary_input;
binary_input.assign(static_cast<char*>(data_->buf), static_cast<size_t>(data_->size));
Expand Down
86 changes: 85 additions & 1 deletion ecal/msg/protobuf/src/ecal_proto_dyn.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -28,11 +28,94 @@
#include <sstream>
#include <fstream>

#include <google/protobuf/stubs/common.h>

namespace eCAL
{
namespace protobuf
{

#if GOOGLE_PROTOBUF_VERSION >= 5026000
class ParserErrorCollector : public google::protobuf::io::ErrorCollector
{
public:
ParserErrorCollector() = default;
~ParserErrorCollector() override = default;

std::string Get() { return(m_ss.str()); }

// Indicates that there was an error in the input at the given line and
// column numbers. The numbers are zero-based, so you may want to add
// 1 to each before printing them.
void RecordError(int line_,
google::protobuf::io::ColumnNumber column_,
absl::string_view message_) override
{
Add(line_, column_, "ERROR", message_);
}

// Indicates that there was a warning in the input at the given line and
// column numbers. The numbers are zero-based, so you may want to add
// 1 to each before printing them.
void RecordWarning(int line_,
google::protobuf::io::ColumnNumber column_,
absl::string_view message_) override
{
Add(line_, column_, "WARNING: ", message_);
}

private:
void Add(int line_, google::protobuf::io::ColumnNumber column_, const std::string& type_, absl::string_view message_)
{
m_ss << line_ << ":" << column_ << " " << type_ << ": " << message_ << std::endl;
}

std::stringstream m_ss;
};

class DescriptorErrorCollector : public google::protobuf::DescriptorPool::ErrorCollector
{
public:
DescriptorErrorCollector() = default;
~DescriptorErrorCollector() override {}

std::string Get() { return(m_ss.str()); }

void RecordError(absl::string_view filename,
absl::string_view element_name,
const google::protobuf::Message* descriptor,
ErrorLocation location,
absl::string_view message) override
{
Add(filename, element_name, descriptor, location, "ERROR", message);
}

void RecordWarning(absl::string_view filename,
absl::string_view element_name,
const google::protobuf::Message* descriptor,
ErrorLocation location,
absl::string_view message) override
{
Add(filename, element_name, descriptor, location, "WARNING", message);
}

private:
void Add(
absl::string_view filename,
absl::string_view element_name,
const google::protobuf::Message* /*descriptor*/,
ErrorLocation location,
const std::string& type,
absl::string_view message
)
{
m_ss << filename << " " << element_name << " " << location << " " << type << ": " << message << std::endl;
}

std::stringstream m_ss;
};

#else
class ParserErrorCollector : public google::protobuf::io::ErrorCollector
{
public:
Expand Down Expand Up @@ -70,7 +153,7 @@ namespace protobuf
{
public:
DescriptorErrorCollector() = default;
~DescriptorErrorCollector() override {}
~DescriptorErrorCollector() override = default;

std::string Get() { return(m_ss.str()); }

Expand Down Expand Up @@ -110,6 +193,7 @@ namespace protobuf

std::stringstream m_ss;
};
#endif

google::protobuf::Message* CProtoDynDecoder::GetProtoMessageFromFile(const std::string& proto_filename_, const std::string& msg_type_, std::string& error_s_)
{
Expand Down

0 comments on commit f198830

Please sign in to comment.