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