]> cloud.milkyroute.net Git - dolphin.git/commitdiff
reactivate session management
authorPeter Penz <peter.penz19@gmail.com>
Thu, 27 Sep 2007 12:36:40 +0000 (12:36 +0000)
committerPeter Penz <peter.penz19@gmail.com>
Thu, 27 Sep 2007 12:36:40 +0000 (12:36 +0000)
svn path=/trunk/KDE/kdebase/apps/; revision=717737

src/main.cpp

index 12eac2211024c5784534cdbd03593c4a36c04539..225c48ed60ee81feba153fbb793776a322979953 100644 (file)
 
 #include "dolphinapplication.h"
 
 
 #include "dolphinapplication.h"
 
+#include "dolphinmainwindow.h"
+
 #include <kaboutdata.h>
 #include <kcmdlineargs.h>
 #include <klocale.h>
 #include <kaboutdata.h>
 #include <kcmdlineargs.h>
 #include <klocale.h>
+#include <kmainwindow.h>
 
 int main(int argc, char **argv)
 {
 
 int main(int argc, char **argv)
 {
@@ -72,17 +75,21 @@ int main(int argc, char **argv)
     DolphinApplication app;
     KGlobal::locale()->insertCatalog("libkonq"); // needed for applications using libkonq
 
     DolphinApplication app;
     KGlobal::locale()->insertCatalog("libkonq"); // needed for applications using libkonq
 
-#ifdef __GNUC__
-#warning TODO, SessionManagement
-#endif
-#if 0
-    if (false /* KDE4-TODO: app.isSessionRestored() */) {
+    if (app.isSessionRestored()) {
         int n = 1;
         while (KMainWindow::canBeRestored(n)) {
         int n = 1;
         while (KMainWindow::canBeRestored(n)) {
-            Dolphin::mainWin().restore(n);
+            const QString className = KXmlGuiWindow::classNameOfToplevel(n);
+            if (className == QLatin1String("DolphinMainWindow")) {
+                DolphinMainWindow* win = app.createMainWindow();
+                win->restore(n);
+            } else {
+                kWarning() << "Unknown class " << className << " in session saved data!";
+            }
             ++n;
         }
     } else {
             ++n;
         }
     } else {
-#endif
-        return app.exec();
+        app.exec();
     }
     }
+
+    return 0;
+}