ProtocolInterface.h 2.92 KB
Newer Older
pixhawk's avatar
pixhawk committed
1
/*=====================================================================
lm's avatar
lm committed
2

pixhawk's avatar
pixhawk committed
3
PIXHAWK Micro Air Vehicle Flying Robotics Toolkit
lm's avatar
lm committed
4

pixhawk's avatar
pixhawk committed
5
(c) 2009, 2010 PIXHAWK PROJECT  <http://pixhawk.ethz.ch>
lm's avatar
lm committed
6

pixhawk's avatar
pixhawk committed
7
This file is part of the PIXHAWK project
lm's avatar
lm committed
8

pixhawk's avatar
pixhawk committed
9 10 11 12
    PIXHAWK is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.
lm's avatar
lm committed
13

pixhawk's avatar
pixhawk committed
14 15 16 17
    PIXHAWK is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.
lm's avatar
lm committed
18

pixhawk's avatar
pixhawk committed
19 20
    You should have received a copy of the GNU General Public License
    along with PIXHAWK. If not, see <http://www.gnu.org/licenses/>.
lm's avatar
lm committed
21

pixhawk's avatar
pixhawk committed
22
======================================================================*/
lm's avatar
lm committed
23

pixhawk's avatar
pixhawk committed
24 25 26 27 28 29 30 31 32 33 34 35 36
/**
 * @file
 *   @brief Interface class for protocols
 *
 *   @author Lorenz Meier <mavteam@student.ethz.ch>
 *
 */

#ifndef _PROTOCOLINTERFACE_H_
#define _PROTOCOLINTERFACE_H_

#include <QThread>
#include <QString>
37
#include <QByteArray>
pixhawk's avatar
pixhawk committed
38 39 40 41 42 43 44
#include "LinkInterface.h"

/**
 * @brief Interface for all protocols.
 *
 * This class defines the interface for
 * communication packets transported by the LinkManager.
45
 *
pixhawk's avatar
pixhawk committed
46
 * @see LinkManager.
47
 *
pixhawk's avatar
pixhawk committed
48
 **/
Lorenz Meier's avatar
Lorenz Meier committed
49
class ProtocolInterface : public QThread
pixhawk's avatar
pixhawk committed
50
{
lm's avatar
lm committed
51
    Q_OBJECT
pixhawk's avatar
pixhawk committed
52
public:
53
    virtual ~ProtocolInterface () {}
lm's avatar
lm committed
54
    virtual QString getName() = 0;
55 56 57 58 59
    /**
     * Retrieve a total of all successfully parsed packets for the specified link.
     * @param link The link to return metadata about.
     * @returns -1 if this is not available for this protocol, # of packets otherwise.
     */
60
    virtual qint32 getReceivedPacketCount(const LinkInterface *link) const = 0;
61 62 63 64 65
    /**
     * Retrieve a total of all parsing errors for the specified link.
     * @param link The link to return metadata about.
     * @returns -1 if this is not available for this protocol, # of errors otherwise.
     */
66
    virtual qint32 getParsingErrorCount(const LinkInterface *link) const = 0;
67 68 69 70 71
    /**
     * Retrieve a total of all dropped packets for the specified link.
     * @param link The link to return metadata about.
     * @returns -1 if this is not available for this protocol, # of packets otherwise.
     */
72 73 74 75 76 77 78
    virtual qint32 getDroppedPacketCount(const LinkInterface *link) const = 0;
    /**
     * Reset the received, error, and dropped counts for the given link. Useful for
     * when reconnecting a link.
     * @param link The link to reset metadata for.
     */
    virtual void resetMetadataForLink(const LinkInterface *link) = 0;
lm's avatar
lm committed
79

pixhawk's avatar
pixhawk committed
80
public slots:
81
    virtual void receiveBytes(LinkInterface *link, QByteArray b) = 0;
82
    virtual void linkStatusChanged(bool connected) = 0;
lm's avatar
lm committed
83 84

signals:
pixhawk's avatar
pixhawk committed
85 86
    /** @brief Update the packet loss from one system */
    void receiveLossChanged(int uasId, float loss);
lm's avatar
lm committed
87

pixhawk's avatar
pixhawk committed
88 89 90
};

#endif // _PROTOCOLINTERFACE_H_