X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtui.cpp;h=f2b0ec903fdcfa25b35e068254606b284d2834a0;hp=2a0883608cd507410cf2919a59fc0b78d134e8a9;hb=fdfd62334f728bd05470c5191194d55027fec86e;hpb=2e9492d9ef198bde37da1f858602ab9624c0a12a diff --git a/src/qtui/qtui.cpp b/src/qtui/qtui.cpp index 2a088360..f2b0ec90 100644 --- a/src/qtui/qtui.cpp +++ b/src/qtui/qtui.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-09 by the Quassel Project * + * Copyright (C) 2005-2012 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -37,8 +37,8 @@ # include #endif -QPointer QtUi::_instance = 0; -QPointer QtUi::_mainWin = 0; +QtUi *QtUi::_instance = 0; +MainWin *QtUi::_mainWin = 0; QList QtUi::_notificationBackends; QList QtUi::_notifications; @@ -62,17 +62,22 @@ QtUi::QtUi() : GraphicalUi() { connect(_mainWin, SIGNAL(connectToCore(const QVariantMap &)), this, SIGNAL(connectToCore(const QVariantMap &))); connect(_mainWin, SIGNAL(disconnectFromCore()), this, SIGNAL(disconnectFromCore())); + connect(Client::instance(), SIGNAL(bufferMarkedAsRead(BufferId)), SLOT(closeNotifications(BufferId))); } QtUi::~QtUi() { unregisterAllNotificationBackends(); delete _mainWin; + _mainWin = 0; + _instance = 0; } void QtUi::init() { _mainWin->init(); QtUiSettings uiSettings; uiSettings.initAndNotify("UseSystemTrayIcon", this, SLOT(useSystemTrayChanged(QVariant)), true); + + GraphicalUi::init(); // needs to be called after the mainWin is initialized } MessageModel *QtUi::createMessageModel(QObject *parent) { @@ -89,6 +94,7 @@ void QtUi::connectedToCore() { void QtUi::disconnectedFromCore() { _mainWin->disconnectedFromCore(); + GraphicalUi::disconnectedFromCore(); } void QtUi::useSystemTrayChanged(const QVariant &v) { @@ -195,3 +201,9 @@ void QtUi::notificationActivated(uint notificationId) { activateMainWidget(); } + +void QtUi::bufferMarkedAsRead(BufferId bufferId) { + if(bufferId.isValid()) { + closeNotifications(bufferId); + } +}