dataparser.h
Go to the documentation of this file.
1 
2 // Copyright (c) 2003-2021 Xsens Technologies B.V. or subsidiaries worldwide.
3 // All rights reserved.
4 //
5 // Redistribution and use in source and binary forms, with or without modification,
6 // are permitted provided that the following conditions are met:
7 //
8 // 1. Redistributions of source code must retain the above copyright notice,
9 // this list of conditions, and the following disclaimer.
10 //
11 // 2. Redistributions in binary form must reproduce the above copyright notice,
12 // this list of conditions, and the following disclaimer in the documentation
13 // and/or other materials provided with the distribution.
14 //
15 // 3. Neither the names of the copyright holders nor the names of their contributors
16 // may be used to endorse or promote products derived from this software without
17 // specific prior written permission.
18 //
19 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
20 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
21 // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
22 // THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23 // SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
24 // OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25 // HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY OR
26 // TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
27 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.THE LAWS OF THE NETHERLANDS
28 // SHALL BE EXCLUSIVELY APPLICABLE AND ANY DISPUTES SHALL BE FINALLY SETTLED UNDER THE RULES
29 // OF ARBITRATION OF THE INTERNATIONAL CHAMBER OF COMMERCE IN THE HAGUE BY ONE OR MORE
30 // ARBITRATORS APPOINTED IN ACCORDANCE WITH SAID RULES.
31 //
32 
33 
34 // Copyright (c) 2003-2021 Xsens Technologies B.V. or subsidiaries worldwide.
35 // All rights reserved.
36 //
37 // Redistribution and use in source and binary forms, with or without modification,
38 // are permitted provided that the following conditions are met:
39 //
40 // 1. Redistributions of source code must retain the above copyright notice,
41 // this list of conditions, and the following disclaimer.
42 //
43 // 2. Redistributions in binary form must reproduce the above copyright notice,
44 // this list of conditions, and the following disclaimer in the documentation
45 // and/or other materials provided with the distribution.
46 //
47 // 3. Neither the names of the copyright holders nor the names of their contributors
48 // may be used to endorse or promote products derived from this software without
49 // specific prior written permission.
50 //
51 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
52 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
53 // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
54 // THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
55 // SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
56 // OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
57 // HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY OR
58 // TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
59 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.THE LAWS OF THE NETHERLANDS
60 // SHALL BE EXCLUSIVELY APPLICABLE AND ANY DISPUTES SHALL BE FINALLY SETTLED UNDER THE RULES
61 // OF ARBITRATION OF THE INTERNATIONAL CHAMBER OF COMMERCE IN THE HAGUE BY ONE OR MORE
62 // ARBITRATORS APPOINTED IN ACCORDANCE WITH SAID RULES.
63 //
64 
65 #ifndef DATAPARSER_H
66 #define DATAPARSER_H
67 
68 #include <deque>
69 #include <xstypes/xsresultvalue.h>
70 #include <xscommon/threading.h>
71 #include <xstypes/xsbytearray.h>
72 #include <queue>
73 
74 struct XsMessage;
75 
77 {
78 public:
79  DataParser();
80  ~DataParser() override;
81 
86  virtual XsResultValue readDataToBuffer(XsByteArray& raw) = 0;
87 
93  virtual XsResultValue processBufferedData(const XsByteArray& rawIn, std::deque<XsMessage>& messages) = 0;
94 
96  virtual void handleMessage(const XsMessage& message) = 0;
97 
98  void addRawData(const XsByteArray& arr);
99  void clear();
100  void terminate();
101 
103  virtual const char* parserType() const
104  {
105  return "DataParser";
106  }
107 
108 protected:
109  void initFunction() override;
110  int32_t innerFunction() override;
111  void signalStopThread(void) override;
112 
113 private:
115  std::queue<XsByteArray> m_incoming;
117  char m_parserType[128];
118 };
119 
120 #endif
XsByteArray
A list of uint8_t values.
DataParser::m_parserType
char m_parserType[128]
Definition: dataparser.h:117
DataParser::signalStopThread
void signalStopThread(void) override
Tells the thread to stop but does not wait for it to end.
Definition: dataparser.cpp:168
DataParser::parserType
virtual const char * parserType() const
Definition: dataparser.h:103
DataParser::processBufferedData
virtual XsResultValue processBufferedData(const XsByteArray &rawIn, std::deque< XsMessage > &messages)=0
Read all messages from the buffered read data after adding new data supplied in rawIn.
DataParser::initFunction
void initFunction() override
Initializes the thread.
Definition: dataparser.cpp:150
DataParser::~DataParser
~DataParser() override
Definition: dataparser.cpp:81
XsResultValue
XsResultValue
Xsens result values.
Definition: xsresultvalue.h:82
DataParser::innerFunction
int32_t innerFunction() override
The inner thread function.
Definition: dataparser.cpp:105
DataParser::DataParser
DataParser()
Default constructor.
Definition: dataparser.cpp:76
xsens::WaitEvent
An event that can be set/reset and that can be waited for.
Definition: xsens_mutex.h:1839
xsens::Mutex
A base mutex class.
Definition: xsens_mutex.h:132
DataParser::handleMessage
virtual void handleMessage(const XsMessage &message)=0
Handles a message.
XsMessage
Structure for storing a single message.
Definition: xsmessage.h:202
DataParser::m_incomingMutex
xsens::Mutex m_incomingMutex
Definition: dataparser.h:114
threading.h
xsens::StandardThread
A class for a standard thread that has to perform the same action repeatedly.
Definition: threading.h:83
DataParser::readDataToBuffer
virtual XsResultValue readDataToBuffer(XsByteArray &raw)=0
Read available data from the open IO device.
int32_t
signed int int32_t
Definition: pstdint.h:515
DataParser
A class for the data parsing on a separete thread.
Definition: dataparser.h:76
DataParser::clear
void clear()
Clears the data queue.
Definition: dataparser.cpp:160
xsbytearray.h
DataParser::m_newDataEvent
xsens::WaitEvent m_newDataEvent
Definition: dataparser.h:116
DataParser::m_incoming
std::queue< XsByteArray > m_incoming
Definition: dataparser.h:115
xsresultvalue.h
DataParser::terminate
void terminate()
Terminates the thread.
Definition: dataparser.cpp:176
DataParser::addRawData
void addRawData(const XsByteArray &arr)
Adds the raw data to an array.
Definition: dataparser.cpp:95


xsens_mti_driver
Author(s):
autogenerated on Sun Sep 3 2023 02:43:20