LinkManager.h 2.5 KB
Newer Older
pixhawk's avatar
pixhawk committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
/*=====================================================================
 
PIXHAWK Micro Air Vehicle Flying Robotics Toolkit
 
(c) 2009, 2010 PIXHAWK PROJECT  <http://pixhawk.ethz.ch>
 
This file is part of the PIXHAWK project
 
    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.
 
    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.
 
    You should have received a copy of the GNU General Public License
    along with PIXHAWK. If not, see <http://www.gnu.org/licenses/>.
 
======================================================================*/
 
/**
 * @file
 *   @brief Manage communication links
 *
 *   @author Lorenz Meier <mavteam@student.ethz.ch>
 *
 */

#ifndef _LINKMANAGER_H_
#define _LINKMANAGER_H_

#include <QThread>
#include <QList>
37
#include <QMultiMap>
pixhawk's avatar
pixhawk committed
38 39 40 41 42 43 44 45 46
#include <LinkInterface.h>
#include <ProtocolInterface.h>

/**
 * The Link Manager organizes the physical Links. It can manage arbitrary
 * links and takes care of connecting them as well assigning the correct
 * protocol instance to transport the link data into the application.
 *
 **/
47 48
class LinkManager : public QObject
{
pixhawk's avatar
pixhawk committed
49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
    Q_OBJECT

public:
    static LinkManager* instance();
    ~LinkManager();

    void run();

    QList<LinkInterface*> getLinksForProtocol(ProtocolInterface* protocol);

    /** @brief Get the link for this id */
    LinkInterface* getLinkForId(int id);

    /** @brief Get a list of all links */
    const QList<LinkInterface*> getLinks();

65 66 67
    /** @brief Get a list of all protocols */
    const QList<ProtocolInterface*> getProtocols() { return protocolLinks.uniqueKeys(); }

pixhawk's avatar
pixhawk committed
68 69 70 71 72
public slots:

    void add(LinkInterface* link);
    void addProtocol(LinkInterface* link, ProtocolInterface* protocol);

73
    void removeLink(QObject* link);
74 75
    bool removeLink(LinkInterface* link);

pixhawk's avatar
pixhawk committed
76 77 78 79 80 81 82 83 84
    bool connectAll();
    bool connectLink(LinkInterface* link);

    bool disconnectAll();
    bool disconnectLink(LinkInterface* link);

protected:
    LinkManager();
    QList<LinkInterface*> links;
85
    QMultiMap<ProtocolInterface*,LinkInterface*> protocolLinks;
pixhawk's avatar
pixhawk committed
86 87 88 89 90 91 92 93 94 95

private:
    static LinkManager* _instance;

signals:
    void newLink(LinkInterface* link);

};

#endif // _LINKMANAGER_H_