Program Listing for File ParseMonitoringCaseData.h

Return to documentation for file (/tmp/ws/src/sick_safetyscanners_base/include/sick_safetyscanners_base/data_processing/ParseMonitoringCaseData.h)

// this is for emacs file handling -*- mode: c++; indent-tabs-mode: nil -*-

// -- BEGIN LICENSE BLOCK ----------------------------------------------

// -- END LICENSE BLOCK ------------------------------------------------

//----------------------------------------------------------------------
//----------------------------------------------------------------------

#ifndef SICK_SAFETYSCANNERS_BASE_DATA_PROCESSING_PARSEMONITORINGCASEDATA_H
#define SICK_SAFETYSCANNERS_BASE_DATA_PROCESSING_PARSEMONITORINGCASEDATA_H

#include "sick_safetyscanners_base/datastructure/Data.h"
#include "sick_safetyscanners_base/datastructure/MonitoringCaseData.h"
#include "sick_safetyscanners_base/datastructure/PacketBuffer.h"

#include "sick_safetyscanners_base/data_processing/ReadWriteHelper.hpp"

#include <vector>

namespace sick {

namespace data_processing {


class ParseMonitoringCaseData
{
public:
  ParseMonitoringCaseData();

  bool parseTCPSequence(const datastructure::PacketBuffer& buffer,
                        datastructure::MonitoringCaseData& monitoring_case_data) const;

private:
  bool isValid(std::vector<uint8_t>::const_iterator data_ptr) const;
  uint16_t readMonitoringCaseNumber(std::vector<uint8_t>::const_iterator data_ptr) const;
  uint16_t readFieldIndex(std::vector<uint8_t>::const_iterator data_ptr,
                          const uint8_t& index) const;
  bool readFieldValid(std::vector<uint8_t>::const_iterator data_ptr, const uint8_t& index) const;
};

} // namespace data_processing
} // namespace sick

#endif // SICK_SAFETYSCANNERS_BASE_DATA_PROCESSING_PARSEFIELDGEOMETRYDATA_H