Move service watching into avahi lib
This commit is contained in:
parent
b118d85e11
commit
7ff39b3e6d
@ -11,24 +11,6 @@ namespace QCP {
|
|||||||
connect(m_av_browse, SIGNAL(stopped()), this, SIGNAL(stopped()));
|
connect(m_av_browse, SIGNAL(stopped()), this, SIGNAL(stopped()));
|
||||||
}
|
}
|
||||||
|
|
||||||
WatchShare *Browse::watch(const Avahi::Service &service, QObject *parent) {
|
|
||||||
ShareData *sd = shareData(service);
|
|
||||||
WatchShare *ws;
|
|
||||||
if (!sd) return 0;
|
|
||||||
|
|
||||||
sd->watcherList.append(ws = new WatchShare(parent, Share(this, service)));
|
|
||||||
ws->m_list_it = sd->watcherList.end()-1;
|
|
||||||
|
|
||||||
return ws;
|
|
||||||
}
|
|
||||||
|
|
||||||
void Browse::removeWatch(WatcherList::iterator it, const Avahi::Service &service) {
|
|
||||||
ShareData *sd = shareData(service);
|
|
||||||
if (!sd || WatcherList::iterator() == it) return;
|
|
||||||
|
|
||||||
sd->watcherList.erase(it);
|
|
||||||
}
|
|
||||||
|
|
||||||
void Browse::foundService(Avahi::Service s) {
|
void Browse::foundService(Avahi::Service s) {
|
||||||
ShareData *sd = new ShareData();
|
ShareData *sd = new ShareData();
|
||||||
s.setData(sd);
|
s.setData(sd);
|
||||||
@ -39,23 +21,8 @@ namespace QCP {
|
|||||||
emit lost(Share(this, s));
|
emit lost(Share(this, s));
|
||||||
ShareData *sd = shareData(s);
|
ShareData *sd = shareData(s);
|
||||||
if (0 != sd) {
|
if (0 != sd) {
|
||||||
while (!sd->watcherList.empty()) {
|
|
||||||
WatchShare *ws = sd->watcherList.first();
|
|
||||||
emit ws->lost();
|
|
||||||
if (ws == sd->watcherList.first()) {
|
|
||||||
ws->m_list_it = WatcherList::iterator();
|
|
||||||
sd->watcherList.pop_front();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
delete sd;
|
delete sd;
|
||||||
}
|
}
|
||||||
sd->data = 0;
|
sd->data = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
WatchShare *Share::watch(QObject *parent) {
|
|
||||||
return m_browse->watch(m_service, parent);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
31
libqcp/qcp.h
31
libqcp/qcp.h
@ -21,11 +21,8 @@ namespace QCP {
|
|||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
private:
|
private:
|
||||||
friend class QCP::Share;
|
friend class QCP::Share;
|
||||||
friend class QCP::WatchShare;
|
|
||||||
|
|
||||||
typedef QLinkedList<WatchShare*> WatcherList;
|
|
||||||
struct ShareData {
|
struct ShareData {
|
||||||
WatcherList watcherList;
|
|
||||||
void *data;
|
void *data;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -49,9 +46,6 @@ namespace QCP {
|
|||||||
void lostService(Avahi::Service s);
|
void lostService(Avahi::Service s);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
WatchShare *watch(const Avahi::Service &service, QObject *parent);
|
|
||||||
void removeWatch(WatcherList::iterator it, const Avahi::Service &service);
|
|
||||||
|
|
||||||
static inline ShareData* shareData(const Avahi::Service &service) {
|
static inline ShareData* shareData(const Avahi::Service &service) {
|
||||||
return static_cast<ShareData*>(service.data());
|
return static_cast<ShareData*>(service.data());
|
||||||
}
|
}
|
||||||
@ -70,8 +64,6 @@ namespace QCP {
|
|||||||
public:
|
public:
|
||||||
Avahi::Service avahiService() const { return m_service; }
|
Avahi::Service avahiService() const { return m_service; }
|
||||||
|
|
||||||
WatchShare *watch(QObject *parent = 0);
|
|
||||||
|
|
||||||
void* data() const { Browse::ShareData *sd = Browse::shareData(m_service); return sd ? sd->data : 0; }
|
void* data() const { Browse::ShareData *sd = Browse::shareData(m_service); return sd ? sd->data : 0; }
|
||||||
void setData(void *data) const { Browse::ShareData *sd = Browse::shareData(m_service); if (sd) sd->data = data; }
|
void setData(void *data) const { Browse::ShareData *sd = Browse::shareData(m_service); if (sd) sd->data = data; }
|
||||||
|
|
||||||
@ -79,29 +71,6 @@ namespace QCP {
|
|||||||
QCP::Browse *m_browse;
|
QCP::Browse *m_browse;
|
||||||
Avahi::Service m_service;
|
Avahi::Service m_service;
|
||||||
};
|
};
|
||||||
|
|
||||||
class LIBQCPSHARED_EXPORT WatchShare : public QObject {
|
|
||||||
Q_OBJECT
|
|
||||||
|
|
||||||
friend class QCP::Share;
|
|
||||||
friend class QCP::Browse;
|
|
||||||
private:
|
|
||||||
inline WatchShare(QObject *parent, Share share) : QObject(parent), m_share(share) { }
|
|
||||||
|
|
||||||
public:
|
|
||||||
virtual ~WatchShare() {
|
|
||||||
m_share.m_browse->removeWatch(m_list_it, m_share.m_service);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline Share share() { return m_share; }
|
|
||||||
|
|
||||||
signals:
|
|
||||||
void lost();
|
|
||||||
|
|
||||||
private:
|
|
||||||
Share m_share;
|
|
||||||
Browse::WatcherList::iterator m_list_it;
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // QCP_H
|
#endif // QCP_H
|
||||||
|
@ -93,7 +93,7 @@ namespace Avahi {
|
|||||||
QList<Service> l = m_list.values();
|
QList<Service> l = m_list.values();
|
||||||
m_list.clear();
|
m_list.clear();
|
||||||
for (int i = 0; i < l.size(); ++i) {
|
for (int i = 0; i < l.size(); ++i) {
|
||||||
emit m_parent->lost(l.at(i));
|
m_parent->lostService(l.at(i));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -164,7 +164,7 @@ namespace Avahi {
|
|||||||
Service s = m_list.value(k);
|
Service s = m_list.value(k);
|
||||||
if (s.valid()) {
|
if (s.valid()) {
|
||||||
m_list.remove(k);
|
m_list.remove(k);
|
||||||
emit m_parent->lost(s);
|
m_parent->lostService(s);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -213,12 +213,12 @@ namespace Avahi {
|
|||||||
Service s = m_list.value(k);
|
Service s = m_list.value(k);
|
||||||
if (s.valid()) {
|
if (s.valid()) {
|
||||||
m_list.remove(k);
|
m_list.remove(k);
|
||||||
emit m_parent->lost(s);
|
m_parent->lostService(s);
|
||||||
}
|
}
|
||||||
|
|
||||||
s = Service(QString::fromUtf8(name), QString::fromUtf8(host_name), QString::fromUtf8(domain), fromAvahiAddress(address, interface), interface, protocol, port, qtxt);
|
s = Service(QString::fromUtf8(name), QString::fromUtf8(host_name), QString::fromUtf8(domain), fromAvahiAddress(address, interface), interface, protocol, port, qtxt);
|
||||||
m_list.insert(k, s);
|
m_list.insert(k, s);
|
||||||
emit m_parent->found(s);
|
m_parent->foundService(s);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -525,6 +525,17 @@ namespace Avahi {
|
|||||||
return m_priv->m_list.values();
|
return m_priv->m_list.values();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Browse::foundService(Avahi::Service s) {
|
||||||
|
emit found(s);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Browse::lostService(Avahi::Service s) {
|
||||||
|
emit lost(s);
|
||||||
|
if (s.m_priv && s.m_priv->m_watcher) {
|
||||||
|
emit s.m_priv->m_watcher->lost(s);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
Announce::Announce(QString serviceType, QString name, quint16 port, QHash<QString,QString> txt, QObject *parent)
|
Announce::Announce(QString serviceType, QString name, quint16 port, QHash<QString,QString> txt, QObject *parent)
|
||||||
: QObject(parent), m_priv(new priv::AnnounceP(serviceType, name, port, txt, this)) {
|
: QObject(parent), m_priv(new priv::AnnounceP(serviceType, name, port, txt, this)) {
|
||||||
|
@ -24,6 +24,7 @@ inline uint qHash(const Avahi::ServiceKey& k);
|
|||||||
#include "qtavahi_p.h"
|
#include "qtavahi_p.h"
|
||||||
|
|
||||||
namespace Avahi {
|
namespace Avahi {
|
||||||
|
typedef Avahi::priv::ServiceWatch ServiceWatch;
|
||||||
|
|
||||||
class LIBQTAVAHISHARED_EXPORT Service {
|
class LIBQTAVAHISHARED_EXPORT Service {
|
||||||
public:
|
public:
|
||||||
@ -50,8 +51,11 @@ namespace Avahi {
|
|||||||
inline void* data() const { return m_priv ? m_priv->m_data : 0; }
|
inline void* data() const { return m_priv ? m_priv->m_data : 0; }
|
||||||
inline void setData(void *data) const { if (m_priv) m_priv->m_data = data; }
|
inline void setData(void *data) const { if (m_priv) m_priv->m_data = data; }
|
||||||
|
|
||||||
|
inline Avahi::ServiceWatch* watcher() const { return m_priv ? m_priv->watcher() : 0; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
friend class Avahi::ServiceKey;
|
friend class Avahi::ServiceKey;
|
||||||
|
friend class Avahi::Browse;
|
||||||
|
|
||||||
inline void assign(Avahi::priv::ServiceP *p) {
|
inline void assign(Avahi::priv::ServiceP *p) {
|
||||||
if (p == m_priv) return;
|
if (p == m_priv) return;
|
||||||
@ -128,9 +132,12 @@ namespace Avahi {
|
|||||||
private:
|
private:
|
||||||
void clearList();
|
void clearList();
|
||||||
|
|
||||||
|
void foundService(Avahi::Service s);
|
||||||
|
void lostService(Avahi::Service s);
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void found(Avahi::Service i);
|
void found(Avahi::Service s);
|
||||||
void lost(Avahi::Service i);
|
void lost(Avahi::Service s);
|
||||||
|
|
||||||
void started();
|
void started();
|
||||||
void stopped();
|
void stopped();
|
||||||
|
@ -1,30 +1,64 @@
|
|||||||
#ifndef QTAVAHI_P_H
|
#ifndef QTAVAHI_P_H
|
||||||
#define QTAVAHI_P_H
|
#define QTAVAHI_P_H
|
||||||
|
|
||||||
|
#include "libqtavahi_global.h"
|
||||||
|
|
||||||
namespace Avahi {
|
namespace Avahi {
|
||||||
|
class LIBQTAVAHISHARED_EXPORT Service;
|
||||||
|
class LIBQTAVAHISHARED_EXPORT ServiceKey;
|
||||||
|
class LIBQTAVAHISHARED_EXPORT Browse;
|
||||||
|
class LIBQTAVAHISHARED_EXPORT Announce;
|
||||||
|
|
||||||
namespace priv {
|
namespace priv {
|
||||||
|
class LIBQTAVAHISHARED_EXPORT ServiceWatch;
|
||||||
class LIBQTAVAHISHARED_EXPORT ServiceP;
|
class LIBQTAVAHISHARED_EXPORT ServiceP;
|
||||||
class BrowseP;
|
class BrowseP;
|
||||||
class AnnounceP;
|
class AnnounceP;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#include <QObject>
|
||||||
|
#include <QHostAddress>
|
||||||
|
|
||||||
namespace Avahi {
|
namespace Avahi {
|
||||||
namespace priv {
|
namespace priv {
|
||||||
|
class LIBQTAVAHISHARED_EXPORT ServiceWatch : public QObject {
|
||||||
|
Q_OBJECT
|
||||||
|
private:
|
||||||
|
friend class Avahi::priv::ServiceP;
|
||||||
|
friend class Avahi::Browse;
|
||||||
|
|
||||||
|
inline ServiceWatch() { }
|
||||||
|
|
||||||
|
signals:
|
||||||
|
void lost(Avahi::Service s);
|
||||||
|
};
|
||||||
|
|
||||||
class LIBQTAVAHISHARED_EXPORT ServiceP {
|
class LIBQTAVAHISHARED_EXPORT ServiceP {
|
||||||
private:
|
private:
|
||||||
friend class Avahi::Service;
|
friend class Avahi::Service;
|
||||||
friend class Avahi::ServiceKey;
|
friend class Avahi::ServiceKey;
|
||||||
friend class Avahi::Browse;
|
friend class Avahi::Browse;
|
||||||
inline ServiceP(QString name, QString hostname, QString domain, QHostAddress address, int interface, int protocol, quint16 port, QHash<QString, QString> txt)
|
inline ServiceP(QString name, QString hostname, QString domain, QHostAddress address, int interface, int protocol, quint16 port, QHash<QString, QString> txt)
|
||||||
: m_ref(1), m_name(name), m_hostname(hostname), m_domain(domain), m_address(address), m_interface(interface), m_protocol(protocol), m_port(port), m_txt(txt), m_data(0) { }
|
: m_ref(1), m_name(name), m_hostname(hostname), m_domain(domain), m_address(address), m_interface(interface), m_protocol(protocol), m_port(port), m_txt(txt),
|
||||||
|
m_data(0), m_watcher(0) { }
|
||||||
|
|
||||||
|
~ServiceP() {
|
||||||
|
delete m_watcher;
|
||||||
|
}
|
||||||
|
|
||||||
Q_DISABLE_COPY(ServiceP);
|
Q_DISABLE_COPY(ServiceP);
|
||||||
|
|
||||||
inline void ref() { m_ref.ref(); }
|
inline void ref() { m_ref.ref(); }
|
||||||
inline void deref() { if (!m_ref.deref()) { delete this; } }
|
inline void deref() { if (!m_ref.deref()) { delete this; } }
|
||||||
|
|
||||||
|
inline Avahi::priv::ServiceWatch* watcher() {
|
||||||
|
if (!m_watcher) {
|
||||||
|
m_watcher = new Avahi::priv::ServiceWatch();
|
||||||
|
}
|
||||||
|
return m_watcher;
|
||||||
|
}
|
||||||
|
|
||||||
QAtomicInt m_ref;
|
QAtomicInt m_ref;
|
||||||
|
|
||||||
QString m_name, m_hostname, m_domain;
|
QString m_name, m_hostname, m_domain;
|
||||||
@ -34,6 +68,7 @@ namespace Avahi {
|
|||||||
QHash<QString, QString> m_txt;
|
QHash<QString, QString> m_txt;
|
||||||
|
|
||||||
void *m_data;
|
void *m_data;
|
||||||
|
Avahi::priv::ServiceWatch *m_watcher;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef enum { TCP, UDP } Protocol;
|
typedef enum { TCP, UDP } Protocol;
|
||||||
@ -47,4 +82,6 @@ namespace Avahi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#include "qtavahi.h"
|
||||||
|
|
||||||
#endif // QTAVAHI_P_H
|
#endif // QTAVAHI_P_H
|
||||||
|
@ -110,7 +110,6 @@ namespace Avahi {
|
|||||||
void remove(const Avahi::Service &s);
|
void remove(const Avahi::Service &s);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Avahi::Browse *m_browse;
|
|
||||||
QMap<Avahi::ServiceKey, EntryList*> m_services;
|
QMap<Avahi::ServiceKey, EntryList*> m_services;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user