Program Listing for File message_initializer.hpp

Return to documentation for file (include/performance_test/utilities/message_initializer.hpp)

// Copyright 2024 Apex.AI, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

#ifndef PERFORMANCE_TEST__UTILITIES__MESSAGE_INITIALIZER_HPP_
#define PERFORMANCE_TEST__UTILITIES__MESSAGE_INITIALIZER_HPP_

#include <cstdint>

#include "performance_test/experiment_configuration/experiment_configuration.hpp"
#include "performance_test/utilities/msg_traits.hpp"
#include "performance_test/utilities/timestamp_provider.hpp"

namespace performance_test
{

class MessageInitializer
{
public:
  explicit MessageInitializer(const ExperimentConfiguration & ec)
  : m_ec(ec) {}

  template<typename T>
  inline void init_msg(
    T & msg,
    const TimestampProvider & timestamp_provider,
    std::uint64_t sample_id)
  {
    init_bounded_sequence(msg);
    init_unbounded_sequence(msg);
    init_unbounded_string(msg);
    init_sample_id(msg, sample_id);
    init_timestamp(msg, timestamp_provider);
  }

private:
  const ExperimentConfiguration & m_ec;

  template<typename T>
  inline
  void init_bounded_sequence(T & msg)
  {
    if constexpr (MsgTraits::has_bounded_sequence<T>::value) {
      msg.bounded_sequence.resize(msg.bounded_sequence.capacity());
    } else if constexpr (MsgTraits::has_bounded_sequence_func<T>::value) {
      msg.bounded_sequence().resize(msg.bounded_sequence().capacity());
    }
  }

  template<typename T>
  inline
  void init_unbounded_sequence(T & msg)
  {
    if constexpr (MsgTraits::has_unbounded_sequence<T>::value) {
      msg.unbounded_sequence.resize(m_ec.unbounded_msg_size);
    } else if constexpr (MsgTraits::has_unbounded_sequence_func<T>::value) {
      msg.unbounded_sequence().resize(m_ec.unbounded_msg_size);
    }
  }

  template<typename T>
  inline
  void init_unbounded_string(T & msg)
  {
    if constexpr (MsgTraits::has_unbounded_string<T>::value) {
      msg.unbounded_string.resize(m_ec.unbounded_msg_size);
    } else if constexpr (MsgTraits::has_unbounded_string_func<T>::value) {
      msg.unbounded_string().resize(m_ec.unbounded_msg_size);
    }
  }

  template<typename T>
  inline void init_sample_id(
    T & msg,
    std::uint64_t sample_id)
  {
    if constexpr (MsgTraits::has_id_object<T>::value) {
      msg.id = sample_id;
    } else if constexpr (MsgTraits::has_id_function<T>::value) {
      msg.id(sample_id);
    }
  }

  template<typename T>
  inline void init_timestamp(
    T & msg,
    const TimestampProvider & timestamp_provider)
  {
    if constexpr (MsgTraits::has_time_object<T>::value) {
      msg.time = timestamp_provider.get();
    } else if constexpr (MsgTraits::has_time_function<T>::value) {
      msg.time(timestamp_provider.get());
    }
  }
};
}  // namespace performance_test

#endif  // PERFORMANCE_TEST__UTILITIES__MESSAGE_INITIALIZER_HPP_