summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'kde-base/kopete')
-rw-r--r--kde-base/kopete/ChangeLog10
-rw-r--r--kde-base/kopete/files/digest-kopete-3.4.0-r11
-rw-r--r--kde-base/kopete/files/kdenetwork-3.4.0-kopete-logout.patch534
-rw-r--r--kde-base/kopete/files/kdenetwork-3.4.0-kopete-spaces.patch225
-rw-r--r--kde-base/kopete/kopete-3.4.0-r1.ebuild20
5 files changed, 789 insertions, 1 deletions
diff --git a/kde-base/kopete/ChangeLog b/kde-base/kopete/ChangeLog
index 7225dcf2d8f5..73d4a932d97d 100644
--- a/kde-base/kopete/ChangeLog
+++ b/kde-base/kopete/ChangeLog
@@ -1,6 +1,14 @@
# ChangeLog for kde-base/kopete
# Copyright 1999-2005 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/kde-base/kopete/ChangeLog,v 1.7 2005/03/26 00:41:47 weeve Exp $
+# $Header: /var/cvsroot/gentoo-x86/kde-base/kopete/ChangeLog,v 1.8 2005/04/03 23:46:26 greg_g Exp $
+
+*kopete-3.4.0-r1 (03 Apr 2005)
+
+ 03 Apr 2005; Gregorio Guidi <greg_g@gentoo.org>
+ +files/kdenetwork-3.4.0-kopete-logout.patch,
+ +files/kdenetwork-3.4.0-kopete-spaces.patch, +kopete-3.4.0-r1.ebuild:
+ Add patches for bug #86446 (crash on logout) and for bug #87485 (handling of
+ names with spaces).
26 Mar 2005; Jason Wever <weeve@gentoo.org> kopete-3.4.0.ebuild:
Added ~sparc keyword.
diff --git a/kde-base/kopete/files/digest-kopete-3.4.0-r1 b/kde-base/kopete/files/digest-kopete-3.4.0-r1
new file mode 100644
index 000000000000..8bdd86e1c2ed
--- /dev/null
+++ b/kde-base/kopete/files/digest-kopete-3.4.0-r1
@@ -0,0 +1 @@
+MD5 47a8d21ce486426caf56bf6129ce993f kdenetwork-3.4.0.tar.bz2 7327047
diff --git a/kde-base/kopete/files/kdenetwork-3.4.0-kopete-logout.patch b/kde-base/kopete/files/kdenetwork-3.4.0-kopete-logout.patch
new file mode 100644
index 000000000000..ae1d402a00da
--- /dev/null
+++ b/kde-base/kopete/files/kdenetwork-3.4.0-kopete-logout.patch
@@ -0,0 +1,534 @@
+diff -Nur kdenetwork-3.4.0.orig/kopete/kopete/chatwindow/kopetechatwindow.cpp kdenetwork-3.4.0/kopete/kopete/chatwindow/kopetechatwindow.cpp
+--- kdenetwork-3.4.0.orig/kopete/kopete/chatwindow/kopetechatwindow.cpp 2005-02-23 11:30:49.000000000 +0100
++++ kdenetwork-3.4.0/kopete/kopete/chatwindow/kopetechatwindow.cpp 2005-04-04 00:12:30.000000000 +0200
+@@ -26,6 +26,7 @@
+ #include <qtooltip.h>
+ #include <qfileinfo.h>
+
++#include <kapplication.h>
+ #include <kcursor.h>
+ #include <klocale.h>
+ #include <kmenubar.h>
+@@ -49,6 +50,7 @@
+ #include "chatmessagepart.h"
+ #include "chattexteditpart.h"
+ #include "chatview.h"
++#include "../kopeteapplication.h"
+ #include "kopetechatwindow.h"
+ #include "kopeteemoticonaction.h"
+ #include "kopetegroup.h"
+@@ -214,6 +216,7 @@
+ KGlobal::config()->setGroup( QString::fromLatin1("ChatWindowSettings") );
+ m_alwaysShowTabs = KGlobal::config()->readBoolEntry( QString::fromLatin1("AlwaysShowTabs"), false );
+ // kdDebug( 14010 ) << k_funcinfo << "Open Windows: " << windows.count() << endl;
++ kapp->ref();
+ }
+
+ KopeteChatWindow::~KopeteChatWindow()
+@@ -261,6 +264,7 @@
+ }
+
+ delete anim;
++ kapp->deref();
+ }
+
+ void KopeteChatWindow::windowListChanged()
+@@ -1030,13 +1034,8 @@
+ m_activeView->addText( sm );
+ }
+
+-void KopeteChatWindow::closeEvent( QCloseEvent *e )
++bool KopeteChatWindow::queryClose()
+ {
+-// kdDebug( 14010 ) << k_funcinfo << endl;
+-
+- // FIXME: This should only check if it *can* close
+- // and not start closing if the close can be aborted halfway, it would
+- // leave us with half the chats open and half of them closed. - Martijn
+ bool canClose = true;
+
+ // kdDebug( 14010 ) << " Windows left open:" << endl;
+@@ -1049,6 +1048,10 @@
+ // move out of the way before view is removed
+ ++it;
+
++ // FIXME: This should only check if it *can* close
++ // and not start closing if the close can be aborted halfway, it would
++ // leave us with half the chats open and half of them closed. - Martijn
++
+ // if the view is closed, it is removed from chatViewList for us
+ if ( !view->closeView() )
+ {
+@@ -1056,21 +1059,44 @@
+ canClose = false;
+ }
+ }
++ return canClose;
++}
+
+- if ( canClose )
++bool KopeteChatWindow::queryExit()
++{
++ KopeteApplication *app = static_cast<KopeteApplication *>( kapp );
++ if ( app->sessionSaving()
++ || app->isShuttingDown() /* only set if KopeteApplication::quitKopete() or
++ KopeteApplication::commitData() called */
++ || !KopetePrefs::prefs()->showTray() /* also close if our tray icon is hidden! */
++ || !isShown() )
+ {
++ Kopete::PluginManager::self()->shutdown();
++ return true;
++ }
++ else
++ return false;
++}
++
++void KopeteChatWindow::closeEvent( QCloseEvent * e )
++{
++ // if there's a system tray applet and we are not shutting down then just do what needs to be done if a
++ // window is closed.
++ KopeteApplication *app = static_cast<KopeteApplication *>( kapp );
++ if ( KopetePrefs::prefs()->showTray() && !app->isShuttingDown() && !app->sessionSaving() ) {
++ hide();
++/* // BEGIN of code borrowed from KMainWindow::closeEvent
+ // Save settings if auto-save is enabled, and settings have changed
+ if ( settingsDirty() && autoSaveSettings() )
+ saveAutoSaveSettings();
+-
+- e->accept();
+-
+- // DO NOT call base class's closeEvent - see comment in KopeteApplication constructor for reason
++
++ if ( queryClose() ) {
++ e->accept();
++ }
++ // END of code borrowed from KMainWindow::closeEvent*/
+ }
+ else
+- {
+- e->ignore();
+- }
++ KMainWindow::closeEvent( e );
+ }
+
+ void KopeteChatWindow::slotConfKeys()
+diff -Nur kdenetwork-3.4.0.orig/kopete/kopete/chatwindow/kopetechatwindow.h kdenetwork-3.4.0/kopete/kopete/chatwindow/kopetechatwindow.h
+--- kdenetwork-3.4.0.orig/kopete/kopete/chatwindow/kopetechatwindow.h 2004-11-17 13:05:31.000000000 +0100
++++ kdenetwork-3.4.0/kopete/kopete/chatwindow/kopetechatwindow.h 2005-04-04 00:12:30.000000000 +0200
+@@ -94,6 +94,13 @@
+ void updateMembersActions();
+ void setStatus( const QString & );
+
++ /**
++ * Reimplemented from KMainWindow - asks each ChatView in the window if it is ok to close the window
++ * @return true if no ChatView objects to closing.
++ */
++ virtual bool queryClose();
++ virtual bool queryExit();
++
+ KTempFile *backgroundFile;
+ QPtrList<ChatView> chatViewList;
+
+diff -Nur kdenetwork-3.4.0.orig/kopete/kopete/kopeteapplication.cpp kdenetwork-3.4.0/kopete/kopete/kopeteapplication.cpp
+--- kdenetwork-3.4.0.orig/kopete/kopete/kopeteapplication.cpp 2005-02-03 23:52:01.000000000 +0100
++++ kdenetwork-3.4.0/kopete/kopete/kopeteapplication.cpp 2005-04-04 00:12:30.000000000 +0200
+@@ -55,25 +55,7 @@
+ m_isShuttingDown = false;
+ m_mainWindow = new KopeteWindow( 0, "mainWindow" );
+
+- /* KMainWindow is very broken from our point of view - it deref()'s the app
+- * when the last visible KMainWindow is destroyed. This is broken for a number
+- * of reasons, not least because it can happen more than once within a single
+- * instance of Kopete. Also, our main window is hidden when it's in the tray,
+- * and closing the last chatwindow when in that state can cause the app to quit.
+- *
+- * KopeteApplication's reference counting scheme is different to that of a normal
+- * KDE application. It works as follows: the Kopete::PluginManager has a reference
+- * to the application. No windows ever call KMainWindow::closeEvent, so KMainWindow
+- * doesn't stupidly deref() our application. This ensures that the application
+- * reference counting still works properly, and that the application terminates
+- * neither too early (bug 75805) nor too late (bug 71657). - Richard
+- */
+-
+- // KApplication sets the reference count to 1 on startup. Kopete::PluginManager has a
+- // reference to us once created, so create it and drop our own reference.
+ Kopete::PluginManager::self();
+- deref();
+-
+
+ Kopete::UI::Global::setMainWidget( m_mainWindow );
+
+@@ -106,6 +88,8 @@
+
+ //Create the emoticon installer
+ m_emoticonHandler = new Kopete::EmoticonMimeTypeHandler;
++
++ QObject::connect( this, SIGNAL( aboutToQuit() ), SLOT( slotCleanShutdown() ) );
+ }
+
+ KopeteApplication::~KopeteApplication()
+@@ -223,7 +207,6 @@
+ }
+ }
+
+-
+ void KopeteApplication::slotAllPluginsLoaded()
+ {
+ KCmdLineArgs *args = KCmdLineArgs::parsedArgs();
+@@ -320,41 +303,28 @@
+ {
+ kdDebug( 14000 ) << k_funcinfo << endl;
+
+- if ( !m_isShuttingDown )
+- {
+- m_isShuttingDown = true;
++ m_isShuttingDown = true;
+
+-#if KDE_VERSION < KDE_MAKE_VERSION( 3, 1, 90 )
+- // When we close Kopete through KSystemTray, kdelibs will close all open
+- // windows first. However, despite the destructive close the main window
+- // is _NOT_ yet deleted at this point (it's a scheduled deleteLater()
+- // call).
+- // Due to a bug in KMainWindow prior to KDE 3.2 calling close() a second
+- // time also derefs KApplication a second time, which causes a premature
+- // call to KApplication::quit(), so we never go through the plugin
+- // manager's shutdown process.
+- // Unfortunately we can't assume close() ever being called though,
+- // because the code paths not using the system tray still need this.
+- // As a workaround we schedule a call to quitKopete() through a timer,
+- // so the event loop is processed and the window is already deleted.
+- // - Martijn
+- QTimer::singleShot( 0, this, SLOT( quitKopete() ) );
+- return;
+-#endif
++ // close all windows
++ QPtrListIterator<KMainWindow> it(*KMainWindow::memberList);
++ for (it.toFirst(); it.current(); ++it)
++ {
++ if ( !it.current()->close() )
++ {
++ m_isShuttingDown = false;
++ break;
++ }
+ }
++}
+
+- if ( !m_mainWindow.isNull() )
+- m_mainWindow->close();
+-
++void KopeteApplication::slotCleanShutdown()
++{
+ // save the contact list now, just in case a change was made very recently
+ // and it hasn't autosaved yet
+ Kopete::ContactList::self()->save();
+ Kopete::AccountManager::self()->save();
+
+- //unload plugins and shutdown
+- Kopete::PluginManager::self()->shutdown();
+ }
+-
+ void KopeteApplication::commitData( QSessionManager &sm )
+ {
+ m_isShuttingDown = true;
+diff -Nur kdenetwork-3.4.0.orig/kopete/kopete/kopeteapplication.h kdenetwork-3.4.0/kopete/kopete/kopeteapplication.h
+--- kdenetwork-3.4.0.orig/kopete/kopete/kopeteapplication.h 2004-02-29 04:52:59.000000000 +0100
++++ kdenetwork-3.4.0/kopete/kopete/kopeteapplication.h 2005-04-04 00:12:30.000000000 +0200
+@@ -58,7 +58,8 @@
+
+ public slots:
+ /**
+- * Quit Kopete. This method marks Kopete as 'shutting down' to avoid
++ * Quit Kopete, closing all the windows, which causes application shutdown
++ * This method marks Kopete as 'shutting down' to avoid
+ * showing the message box that Kopete will be left running in the
+ * system tray before calling qApp->quit().
+ */
+@@ -75,7 +76,7 @@
+ * auto-connect
+ */
+ void slotAllPluginsLoaded();
+-
++ void slotCleanShutdown();
+ private:
+ // The main window might get deleted behind our back (W_DestructiveClose),
+ // so use a guarded pointer
+diff -Nur kdenetwork-3.4.0.orig/kopete/kopete/kopetewindow.cpp kdenetwork-3.4.0/kopete/kopete/kopetewindow.cpp
+--- kdenetwork-3.4.0.orig/kopete/kopete/kopetewindow.cpp 2005-02-25 11:52:29.000000000 +0100
++++ kdenetwork-3.4.0/kopete/kopete/kopetewindow.cpp 2005-04-04 00:12:30.000000000 +0200
+@@ -67,9 +67,32 @@
+ #include "kopeteuiglobal.h"
+ #include "systemtray.h"
+
++/* KMainWindow is very broken from our point of view - it deref()'s the app
++ * when the last visible KMainWindow is destroyed. But when our main window is
++ * hidden when it's in the tray,closing the last chatwindow would cause the app
++ * to quit. - Richard
++ *
++ * Fortunately KMainWindow checks queryExit before deref()ing the Kapplication.
++ * KopeteWindow reimplements queryExit() and only returns true if it is shutting down
++ * (either because the user quit Kopete, or the session manager did).
++ *
++ * KopeteWindow and ChatWindows are closed by session management.
++ * App shutdown is not performed by the KopeteWindow but by KopeteApplication:
++ * 1) user quit - KopeteWindow::slotQuit() was called, calls KopeteApplication::quitKopete(),
++ * which closes all chatwindows and the KopeteWindow. The last window to close
++ * shuts down the PluginManager in queryExit(). When the PluginManager has completed its
++ * shutdown, the app is finally deref()ed, and the contactlist and accountmanager
++ * are saved.
++ * and calling KApplication::quit()
++ * 2) session - KopeteWindow and all chatwindows are closed by KApplication session management.
++ * quit Then the shutdown proceeds as above.
++ *
++ * queryClose() is honoured so group chats and chats receiving recent messages can interrupt
++ * (session) quit.
++ */
+
+ KopeteWindow::KopeteWindow( QWidget *parent, const char *name )
+-: KMainWindow( parent, name )
++: KMainWindow( parent, name, WType_TopLevel )
+ {
+ // Applications should ensure that their StatusBar exists before calling createGUI()
+ // so that the StatusBar is always correctly positioned when KDE is configured to use
+@@ -446,42 +469,59 @@
+ Kopete::AccountManager::self()->setAwayAll( awayReason );
+ }
+
+-void KopeteWindow::closeEvent( QCloseEvent *e )
++
++bool KopeteWindow::queryClose()
+ {
+- // Note that KSystemTray closes all windows when you select quit()
+- // from it. This means that closeEvent will be called twice on exit.
+ KopeteApplication *app = static_cast<KopeteApplication *>( kapp );
++ if ( !app->sessionSaving() // if we are just closing but not shutting down
++ && !app->isShuttingDown()
++ && KopetePrefs::prefs()->showTray()
++ && isShown() )
++ // I would make this a KMessageBox::queuedMessageBox but there doesn't seem to be don'tShowAgain support for those
++ KMessageBox::information( this,
++ i18n( "<qt>Closing the main window will keep Kopete running in the "
++ "system tray. Use 'Quit' from the 'File' menu to quit the application.</qt>" ),
++ i18n( "Docking in System Tray" ), "hideOnCloseInfo" );
++// else // we are shutting down either user initiated or session management
++// Kopete::PluginManager::self()->shutdown();
++
++ return true;
++}
+
+- // also close if our tray icon is hidden!
+- if( app->isShuttingDown() || !KopetePrefs::prefs()->showTray() || !isShown() )
++bool KopeteWindow::queryExit()
++{
++ KopeteApplication *app = static_cast<KopeteApplication *>( kapp );
++ if ( app->sessionSaving()
++ || app->isShuttingDown() /* only set if KopeteApplication::quitKopete() or
++ KopeteApplication::commitData() called */
++ || !KopetePrefs::prefs()->showTray() /* also close if our tray icon is hidden! */
++ || !isShown() )
+ {
+- // DO NOT call base class's closeEvent - see comment in KopeteApplication constructor for reason
++ Kopete::PluginManager::self()->shutdown();
++ return true;
++ }
++ else
++ return false;
++}
++
++void KopeteWindow::closeEvent( QCloseEvent *e )
++{
++ // if there's a system tray applet and we are not shutting down then just do what needs to be done if a
++ // window is closed.
++ KopeteApplication *app = static_cast<KopeteApplication *>( kapp );
++ if ( KopetePrefs::prefs()->showTray() && !app->isShuttingDown() && !app->sessionSaving() ) {
++ // BEGIN of code borrowed from KMainWindow::closeEvent
+ // Save settings if auto-save is enabled, and settings have changed
+ if ( settingsDirty() && autoSaveSettings() )
+ saveAutoSaveSettings();
+-
+- e->accept();
+-
+- //If we're not showing the tray, and they close the window (via the 'X' in the titlebar),
+- //workaround the fact that accepting the close event doesn't cause kopete to shutdown
+- if ( !app->isShuttingDown() )
+- {
+- queryExit();
+- slotQuit();
++
++ if ( queryClose() ) {
++ e->accept();
+ }
+-
+- //may never get called
+- return;
++ // END of code borrowed from KMainWindow::closeEvent
+ }
+-
+- // FIXME: KDE 3.3: use queuedMessageBox
+- KMessageBox::information( this,
+- i18n( "<qt>Closing the main window will keep Kopete running in the "
+- "system tray. Use 'Quit' from the 'File' menu to quit the application.</qt>" ),
+- i18n( "Docking in System Tray" ), "hideOnCloseInfo" );
+-
+- hide();
+- e->ignore();
++ else
++ KMainWindow::closeEvent( e );
+ }
+
+ void KopeteWindow::slotQuit()
+diff -Nur kdenetwork-3.4.0.orig/kopete/kopete/kopetewindow.h kdenetwork-3.4.0/kopete/kopete/kopetewindow.h
+--- kdenetwork-3.4.0.orig/kopete/kopete/kopetewindow.h 2005-02-23 11:30:49.000000000 +0100
++++ kdenetwork-3.4.0/kopete/kopete/kopetewindow.h 2005-04-04 00:12:30.000000000 +0200
+@@ -190,6 +190,8 @@
+ void makeTrayToolTip();
+ void startAutoHideTimer();
+
++ virtual bool queryClose();
++ virtual bool queryExit();
+ private:
+ int docked;
+ bool hidden;
+diff -Nur kdenetwork-3.4.0.orig/kopete/kopete/systemtray.cpp kdenetwork-3.4.0/kopete/kopete/systemtray.cpp
+--- kdenetwork-3.4.0.orig/kopete/kopete/systemtray.cpp 2005-02-03 23:52:01.000000000 +0100
++++ kdenetwork-3.4.0/kopete/kopete/systemtray.cpp 2005-04-04 00:12:30.000000000 +0200
+@@ -25,6 +25,7 @@
+
+ #include <kwin.h>
+ #include <kaboutdata.h>
++#include <kactioncollection.h>
+ #include <kapplication.h>
+ #include <kdebug.h>
+ #include <kiconloader.h>
+@@ -36,7 +37,7 @@
+ #include "kopeteaccount.h"
+ #include "kopeteaccountmanager.h"
+ #include "kopetecontact.h"
+-
++#include "kopetewindow.h"
+
+ KopeteSystemTray* KopeteSystemTray::s_systemTray = 0L;
+
+@@ -70,6 +71,18 @@
+ const Kopete::OnlineStatus &, const Kopete::OnlineStatus &)),
+ this, SLOT(slotReevaluateAccountStates()));
+
++ // the slot called by default by the quit action, KSystemTray::maybeQuit(),
++ // just closes the parent window, which is hard to distinguish in that window's closeEvent()
++ // from a click on the window's close widget
++ // in the quit case, we want to quit the application
++ // in the close widget click case, we only want to hide the parent window
++ // so instead, we make it call our general purpose quit slot on the window, which causes a window close and everything else we need
++ // KDE4 - app will have to listen for quitSelected instead
++ KAction *quit = actionCollection()->action( "file_quit" );
++ quit->disconnect();
++ KopeteWindow *myParent = static_cast<KopeteWindow *>( parent );
++ connect( quit, SIGNAL( activated() ), myParent, SLOT( slotQuit() ) );
++
+ //setPixmap(mKopeteIcon);
+ slotReevaluateAccountStates();
+ slotConfigChanged();
+diff -Nur kdenetwork-3.4.0.orig/kopete/libkopete/kopeteaccount.cpp kdenetwork-3.4.0/kopete/libkopete/kopeteaccount.cpp
+--- kdenetwork-3.4.0.orig/kopete/libkopete/kopeteaccount.cpp 2005-03-04 10:53:38.000000000 +0100
++++ kdenetwork-3.4.0/kopete/libkopete/kopeteaccount.cpp 2005-04-04 00:12:30.000000000 +0200
+@@ -97,6 +97,7 @@
+ while ( !d->contacts.isEmpty() )
+ delete *QDictIterator<Contact>( d->contacts );
+
++ kdDebug( 14010 ) << k_funcinfo << " account '" << d->id << "' about to emit accountDestroyed " << endl;
+ emit accountDestroyed(this);
+
+ delete d->myself;
+diff -Nur kdenetwork-3.4.0.orig/kopete/libkopete/kopetepluginmanager.cpp kdenetwork-3.4.0/kopete/libkopete/kopetepluginmanager.cpp
+--- kdenetwork-3.4.0.orig/kopete/libkopete/kopetepluginmanager.cpp 2004-10-17 20:37:16.000000000 +0200
++++ kdenetwork-3.4.0/kopete/libkopete/kopetepluginmanager.cpp 2005-04-04 00:12:30.000000000 +0200
+@@ -101,7 +101,7 @@
+ PluginManager::~PluginManager()
+ {
+ if ( d->shutdownMode != Private::DoneShutdown )
+- kdWarning( 14010 ) << k_funcinfo << "Destructing plugin manager without going through the shutdown process!" << endl << kdBacktrace() << endl;
++ kdWarning( 14010 ) << k_funcinfo << "Destructing plugin manager without going through the shutdown process! Backtrace is: " << endl << kdBacktrace() << endl;
+
+ // Quick cleanup of the remaining plugins, hope it helps
+ // Note that deleting it.data() causes slotPluginDestroyed to be called, which
+@@ -160,7 +160,7 @@
+
+ void PluginManager::shutdown()
+ {
+- //kdDebug( 14010 ) << k_funcinfo << endl;
++ kdDebug( 14010 ) << k_funcinfo << kdBacktrace() << endl;
+
+ d->shutdownMode = Private::ShuttingDown;
+
+@@ -200,6 +200,7 @@
+ // FIXME: I don't buy the above argument. Add a Kopete::Plugin::emitReadyForUnload(void),
+ // and make readyForUnload be passed a plugin. - Richard
+ Plugin *plugin = dynamic_cast<Plugin *>( const_cast<QObject *>( sender() ) );
++ kdDebug( 14010 ) << k_funcinfo << plugin->pluginId() << "ready for unload" << endl;
+ if ( !plugin )
+ {
+ kdWarning( 14010 ) << k_funcinfo << "Calling object is not a plugin!" << endl;
+diff -Nur kdenetwork-3.4.0.orig/kopete/libkopete/kopetepluginmanager.h kdenetwork-3.4.0/kopete/libkopete/kopetepluginmanager.h
+--- kdenetwork-3.4.0.orig/kopete/libkopete/kopetepluginmanager.h 2004-11-18 23:12:09.000000000 +0100
++++ kdenetwork-3.4.0/kopete/libkopete/kopetepluginmanager.h 2005-04-04 00:12:30.000000000 +0200
+@@ -175,7 +175,6 @@
+ * is neglectable for the user.
+ */
+ void allPluginsLoaded();
+-
+ private slots:
+ /**
+ * @brief Cleans up some references if the plugin is destroyed
+diff -Nur kdenetwork-3.4.0.orig/kopete/libkopete/kopeteprotocol.cpp kdenetwork-3.4.0/kopete/libkopete/kopeteprotocol.cpp
+--- kdenetwork-3.4.0.orig/kopete/libkopete/kopeteprotocol.cpp 2004-12-04 15:39:03.000000000 +0100
++++ kdenetwork-3.4.0/kopete/libkopete/kopeteprotocol.cpp 2005-04-04 00:12:30.000000000 +0200
+@@ -96,6 +96,8 @@
+ {//slot connected in aboutToUnload
+ if ( !self || !self->account() || self->account()->isConnected())
+ return;
++ // some protocols change status several times during shutdown. We should only call deleteLater() once
++ disconnect( self, 0, this, 0 );
+
+ connect( self->account(), SIGNAL(accountDestroyed(const Kopete::Account* )),
+ this, SLOT( slotAccountDestroyed( ) ) );
+@@ -105,15 +107,23 @@
+
+ void Protocol::slotAccountDestroyed( )
+ {
++ kdDebug( 14010 ) << k_funcinfo << " an account was destroyed" << endl;
+ QDict<Account> dict = AccountManager::self()->accounts( this );
+ if ( dict.isEmpty() )
+ {
++ kdDebug( 14010 ) << "all gone, we are ready for unload" << endl;
+ // While at this point we are still in a stack trace from the destroyed
+ // account it's safe to emit readyForUnload already, because it uses a
+ // deleteLater rather than a delete for exactly this reason, to keep the
+ // API managable
+ emit( readyForUnload() );
+ }
++ else
++ {
++ kdDebug( 14010 ) << "protocol still has " << dict.count() << " accounts:" << endl;
++ for( QDictIterator<Account> di(dict); di.current(); ++di )
++ kdDebug( 14010 ) << " " << di.currentKey() << " : " << di.current()->accountId() << endl;
++ }
+ }
+
+ void Protocol::aboutToUnload()
+@@ -121,8 +131,6 @@
+
+ d->unloading = true;
+
+- bool allDisconnected = true;
+-
+ // Disconnect all accounts
+ QDict<Account> accounts = AccountManager::self()->accounts( this );
+
+@@ -139,8 +147,6 @@
+ SIGNAL( onlineStatusChanged( Kopete::Contact *, const Kopete::OnlineStatus &, const Kopete::OnlineStatus & ) ),
+ this, SLOT( slotAccountOnlineStatusChanged( Kopete::Contact * ) ) );
+ it.current()->disconnect();
+-
+- allDisconnected = false;
+ }
+ else
+ {
diff --git a/kde-base/kopete/files/kdenetwork-3.4.0-kopete-spaces.patch b/kde-base/kopete/files/kdenetwork-3.4.0-kopete-spaces.patch
new file mode 100644
index 000000000000..26c8382f3684
--- /dev/null
+++ b/kde-base/kopete/files/kdenetwork-3.4.0-kopete-spaces.patch
@@ -0,0 +1,225 @@
+diff -Nur kdenetwork-3.4.0.orig/kopete/protocols/oscar/aim/aimcontact.cpp kdenetwork-3.4.0/kopete/protocols/oscar/aim/aimcontact.cpp
+--- kdenetwork-3.4.0.orig/kopete/protocols/oscar/aim/aimcontact.cpp 2005-02-23 11:30:54.000000000 +0100
++++ kdenetwork-3.4.0/kopete/protocols/oscar/aim/aimcontact.cpp 2005-04-04 01:41:26.000000000 +0200
+@@ -145,7 +145,7 @@
+
+ void AIMContact::userInfoUpdated( const QString& contact, const UserDetails& details )
+ {
+- if ( contact.lower() != contactId().lower() )
++ if ( Oscar::normalize( contact ) != Oscar::normalize( contactId() ) )
+ return;
+
+ kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << contact << endl;
+@@ -179,7 +179,7 @@
+
+ void AIMContact::userOnline( const QString& userId )
+ {
+- if ( userId.lower() == contactId().lower() )
++ if ( Oscar::normalize( userId ) == Oscar::normalize( contactId() ) )
+ {
+ kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "Getting more contact info" << endl;
+ setOnlineStatus( mProtocol->statusOnline );
+@@ -197,7 +197,7 @@
+
+ void AIMContact::updateAwayMessage( const QString& contact, const QString& message )
+ {
+- if ( contact.lower() != contactId().lower() )
++ if ( Oscar::normalize( contact ) != Oscar::normalize( contactId() ) )
+ return;
+ else
+ {
+@@ -220,7 +220,7 @@
+
+ void AIMContact::updateProfile( const QString& contact, const QString& profile )
+ {
+- if ( contact.lower() != contactId().lower() )
++ if ( Oscar::normalize( contact ) != Oscar::normalize( contactId() ) )
+ return;
+
+ setProperty( mProtocol->clientProfile, profile );
+diff -Nur kdenetwork-3.4.0.orig/kopete/protocols/oscar/icq/icqcontact.cpp kdenetwork-3.4.0/kopete/protocols/oscar/icq/icqcontact.cpp
+--- kdenetwork-3.4.0.orig/kopete/protocols/oscar/icq/icqcontact.cpp 2005-02-03 23:52:07.000000000 +0100
++++ kdenetwork-3.4.0/kopete/protocols/oscar/icq/icqcontact.cpp 2005-04-04 01:41:26.000000000 +0200
+@@ -106,7 +106,7 @@
+
+ void ICQContact::userOnline( const QString& userId )
+ {
+- if ( userId != contactId() )
++ if ( Oscar::normalize( userId ) != Oscar::normalize( contactId() ) )
+ return;
+
+ kdDebug(OSCAR_ICQ_DEBUG) << "Setting " << userId << " online" << endl;
+@@ -116,7 +116,7 @@
+
+ void ICQContact::userOffline( const QString& userId )
+ {
+- if ( userId != contactId() )
++ if ( Oscar::normalize( userId ) != Oscar::normalize( contactId() ) )
+ return;
+
+ kdDebug(OSCAR_ICQ_DEBUG) << "Setting " << userId << " offline" << endl;
+@@ -130,7 +130,7 @@
+ setOnlineStatus( mProtocol->statusManager()->waitingForAuth() );
+
+ QString nickname = property( Kopete::Global::Properties::self()->nickName() ).value().toString();
+- if ( nickname.isEmpty() || nickname == contactId() )
++ if ( nickname.isEmpty() || Oscar::normalize( nickname ) == Oscar::normalize( contactId() ) )
+ {
+ int time = ( KApplication::random() % 25 ) * 1000;
+ kdDebug(OSCAR_ICQ_DEBUG) << k_funcinfo << "updating nickname in " << time/1000 << " seconds" << endl;
+@@ -164,7 +164,7 @@
+
+ void ICQContact::slotGotAuthReply( const QString& contact, const QString& reason, bool granted )
+ {
+- if ( contact != contactId() )
++ if ( Oscar::normalize( contact ) != Oscar::normalize( contactId() ) )
+ return;
+
+ kdDebug(OSCAR_ICQ_DEBUG) << k_funcinfo << endl;
+@@ -189,7 +189,7 @@
+
+ void ICQContact::slotGotAuthRequest( const QString& contact, const QString& reason )
+ {
+- if ( contact != contactId() )
++ if ( Oscar::normalize( contact ) != Oscar::normalize( contactId() ) )
+ return;
+
+ ICQAuthReplyDialog replyDialog;
+@@ -202,7 +202,7 @@
+
+ void ICQContact::receivedLongInfo( const QString& contact )
+ {
+- if ( contact.lower() != contactId().lower() )
++ if ( Oscar::normalize( contact ) != Oscar::normalize( contactId() ) )
+ {
+ if ( m_infoWidget )
+ m_infoWidget->delayedDestruct();
+@@ -224,7 +224,7 @@
+
+ void ICQContact::receivedShortInfo( const QString& contact )
+ {
+- if ( contact != contactId() )
++ if ( Oscar::normalize( contact ) != Oscar::normalize( contactId() ) )
+ return;
+
+ ICQShortInfo shortInfo = mAccount->engine()->getShortInfo( contact );
+diff -Nur kdenetwork-3.4.0.orig/kopete/protocols/oscar/liboscar/ssiauthtask.cpp kdenetwork-3.4.0/kopete/protocols/oscar/liboscar/ssiauthtask.cpp
+--- kdenetwork-3.4.0.orig/kopete/protocols/oscar/liboscar/ssiauthtask.cpp 2005-01-30 16:09:38.000000000 +0100
++++ kdenetwork-3.4.0/kopete/protocols/oscar/liboscar/ssiauthtask.cpp 2005-04-04 01:41:26.000000000 +0200
+@@ -21,6 +21,7 @@
+ #include "transfer.h"
+ #include "buffer.h"
+ #include "connection.h"
++#include "oscarutils.h"
+
+ #include <kdebug.h>
+
+@@ -135,7 +136,7 @@
+ {
+ Buffer* buf = transfer()->buffer();
+
+- QString uin = buf->getBUIN();
++ QString uin = Oscar::normalize( buf->getBUIN() );
+ QString reason = buf->getBSTR();
+
+ buf->getWord(); // 0x0000 - Unknown
+@@ -149,7 +150,7 @@
+ {
+ Buffer* buf = transfer()->buffer();
+
+- QString uin = buf->getBUIN();
++ QString uin = Oscar::normalize( buf->getBUIN() );
+ QString reason = buf->getBSTR();
+
+ buf->getWord(); // 0x0000 - Unknown
+@@ -164,7 +165,7 @@
+ {
+ Buffer* buf = transfer()->buffer();
+
+- QString uin = buf->getBUIN();
++ QString uin = Oscar::normalize( buf->getBUIN() );
+ bool accepted = buf->getByte();
+ QString reason = buf->getBSTR();
+
+@@ -186,7 +187,7 @@
+ {
+ Buffer* buf = transfer()->buffer();
+
+- QString uin = buf->getBUIN();
++ QString uin = Oscar::normalize( buf->getBUIN() );
+
+ kdDebug( OSCAR_RAW_DEBUG ) << k_funcinfo << "User " << uin << " added you to the contact list" << endl;
+ emit contactAddedYou( uin );
+diff -Nur kdenetwork-3.4.0.orig/kopete/protocols/oscar/liboscar/ssilisttask.cpp kdenetwork-3.4.0/kopete/protocols/oscar/liboscar/ssilisttask.cpp
+--- kdenetwork-3.4.0.orig/kopete/protocols/oscar/liboscar/ssilisttask.cpp 2005-01-25 16:10:19.000000000 +0100
++++ kdenetwork-3.4.0/kopete/protocols/oscar/liboscar/ssilisttask.cpp 2005-04-04 01:41:26.000000000 +0200
+@@ -110,6 +110,9 @@
+ tlvList.append( t );
+ }
+
++ if ( itemType == ROSTER_CONTACT )
++ itemName = Oscar::normalize( itemName );
++
+ Oscar::SSI s( itemName, groupId, itemId, itemType, tlvList );
+ s.setTLVListLength( tlvLength );
+
+diff -Nur kdenetwork-3.4.0.orig/kopete/protocols/oscar/liboscar/ssimodifytask.cpp kdenetwork-3.4.0/kopete/protocols/oscar/liboscar/ssimodifytask.cpp
+--- kdenetwork-3.4.0.orig/kopete/protocols/oscar/liboscar/ssimodifytask.cpp 2005-02-01 20:41:08.000000000 +0100
++++ kdenetwork-3.4.0/kopete/protocols/oscar/liboscar/ssimodifytask.cpp 2005-04-04 01:41:26.000000000 +0200
+@@ -41,7 +41,7 @@
+ {
+ }
+
+-void SSIModifyTask::onGo( )
++void SSIModifyTask::onGo()
+ {
+ sendSSIUpdate();
+ }
+@@ -62,7 +62,10 @@
+ {
+ m_opType = Add;
+ m_opSubject = Contact;
+- Oscar::SSI oldItem = m_ssiManager->findContact( contact );
++
++ QString newContact = Oscar::normalize( contact );
++
++ Oscar::SSI oldItem = m_ssiManager->findContact( newContact );
+ Oscar::SSI groupItem = m_ssiManager->findGroup( group );
+
+ if ( !groupItem )
+@@ -81,7 +84,7 @@
+ }
+
+ kdDebug( OSCAR_RAW_DEBUG ) << k_funcinfo << "creating new SSI item for " << contact << " in group " << group << endl;
+- Oscar::SSI newItem( contact, groupItem.gid(), m_ssiManager->nextContactId(), ROSTER_CONTACT, tlvList );
++ Oscar::SSI newItem( newContact, groupItem.gid(), m_ssiManager->nextContactId(), ROSTER_CONTACT, tlvList );
+ m_newItem = newItem;
+ return true;
+ }
+@@ -90,7 +93,7 @@
+ {
+ m_opType = Remove;
+ m_opSubject = Contact;
+- m_oldItem = m_ssiManager->findContact( contact );
++ m_oldItem = m_ssiManager->findContact( Oscar::normalize( contact ) );
+ kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "Scheduling" << m_oldItem.name() << " for removal" << endl;
+ return true;
+ }
+@@ -99,7 +102,7 @@
+ {
+ m_opType = Change;
+ m_opSubject = Group;
+- m_oldItem = m_ssiManager->findContact( contact );
++ m_oldItem = m_ssiManager->findContact( Oscar::normalize( contact ) );
+ Oscar::SSI oldGroupItem;
+ if ( m_oldItem.isValid() )
+ oldGroupItem = m_ssiManager->findGroup( newGroup );
+@@ -138,7 +141,7 @@
+ return true;
+ }
+
+-bool SSIModifyTask::removeGroup( const QString & groupName )
++bool SSIModifyTask::removeGroup( const QString& groupName )
+ {
+ m_opType = Remove;
+ m_opSubject = Group;
diff --git a/kde-base/kopete/kopete-3.4.0-r1.ebuild b/kde-base/kopete/kopete-3.4.0-r1.ebuild
new file mode 100644
index 000000000000..a75e78509ef8
--- /dev/null
+++ b/kde-base/kopete/kopete-3.4.0-r1.ebuild
@@ -0,0 +1,20 @@
+# Copyright 1999-2005 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/kde-base/kopete/kopete-3.4.0-r1.ebuild,v 1.1 2005/04/03 23:46:26 greg_g Exp $
+
+KMNAME=kdenetwork
+MAXKDEVER=$PV
+KM_DEPRANGE="$PV $MAXKDEVER"
+inherit kde-meta eutils
+
+DESCRIPTION="KDE multi-protocol IM client"
+KEYWORDS="~x86 ~amd64 ~ppc ~sparc"
+IUSE="ssl"
+
+RDEPEND="ssl? ( app-crypt/qca-tls )"
+
+# fix kde bug 91288. Applied for 3.4.1.
+PATCHES1="${FILESDIR}/kdenetwork-3.4.0-kopete-logout.patch"
+
+# fix kde bug 99671. Applied for 3.4.1.
+PATCHES1="${PATCHES1} ${FILESDIR}/kdenetwork-3.4.0-kopete-spaces.patch"