Skip to content
ProtocolInterface.h 2.92 KiB
Newer Older
pixhawk's avatar
pixhawk committed
/*=====================================================================
lm's avatar
lm committed

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

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

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

pixhawk's avatar
pixhawk committed
    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

pixhawk's avatar
pixhawk committed
    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

pixhawk's avatar
pixhawk committed
    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

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

pixhawk's avatar
pixhawk committed
/**
 * @file
 *   @brief Interface class for protocols
 *
 *   @author Lorenz Meier <mavteam@student.ethz.ch>
 *
 */

#ifndef _PROTOCOLINTERFACE_H_
#define _PROTOCOLINTERFACE_H_

#include <QThread>
#include <QString>
pixhawk's avatar
pixhawk committed
#include "LinkInterface.h"

/**
 * @brief Interface for all protocols.
 *
 * This class defines the interface for
 * communication packets transported by the LinkManager.
pixhawk's avatar
pixhawk committed
 * @see LinkManager.
pixhawk's avatar
pixhawk committed
 **/
Lorenz Meier's avatar
Lorenz Meier committed
class ProtocolInterface : public QThread
pixhawk's avatar
pixhawk committed
{
lm's avatar
lm committed
    Q_OBJECT
pixhawk's avatar
pixhawk committed
public:
lm's avatar
lm committed
    virtual QString getName() = 0;
    /**
     * 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.
     */
    virtual qint32 getReceivedPacketCount(const LinkInterface *link) const = 0;
    /**
     * 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.
     */
    virtual qint32 getParsingErrorCount(const LinkInterface *link) const = 0;
    /**
     * 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.
     */
    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

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

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

pixhawk's avatar
pixhawk committed
};

#endif // _PROTOCOLINTERFACE_H_