/***************************************************************************
- * Copyright (C) 2005-2015 by the Quassel Project *
+ * Copyright (C) 2005-2020 by the Quassel Project *
* devel@quassel-irc.org *
* *
* This program is free software; you can redistribute it and/or modify *
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
***************************************************************************/
-#ifndef SESSIONTHREAD_H
-#define SESSIONTHREAD_H
+#pragma once
+
+#include <memory>
-#include <QMutex>
#include <QThread>
#include "types.h"
class CoreSession;
+class Peer;
class InternalPeer;
class RemotePeer;
-class QIODevice;
-class SessionThread : public QThread
+class SessionThread : public QObject
{
Q_OBJECT
public:
- SessionThread(UserId user, bool restoreState, QObject *parent = 0);
- ~SessionThread();
-
- void run();
-
- CoreSession *session();
- UserId user();
+ SessionThread(UserId user, bool restoreState, bool strictIdentEnabled, QObject* parent = nullptr);
+ ~SessionThread() override;
public slots:
- void addClient(QObject *peer);
+ void addClient(Peer* peer);
+ void shutdown();
private slots:
- void setSessionInitialized();
+ void onSessionInitialized();
+ void onSessionDestroyed();
signals:
void initialized();
- void shutdown();
+ void shutdownSession();
+ void shutdownComplete(SessionThread*);
- void addRemoteClient(RemotePeer *peer);
- void addInternalClient(InternalPeer *peer);
+ void addClientToWorker(Peer* peer);
private:
- CoreSession *_session;
- UserId _user;
- QList<QObject *> clientQueue;
- bool _sessionInitialized;
- bool _restoreState;
+ QThread _sessionThread;
+ bool _sessionInitialized{false};
- bool isSessionInitialized();
- void addClientToSession(QObject *peer);
- void addRemoteClientToSession(RemotePeer *remotePeer);
- void addInternalClientToSession(InternalPeer *internalPeer);
+ std::vector<Peer*> _clientQueue;
};
-
-
-#endif