X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/abf17941f7a052d25788d2f2f3c84e5aae935e29..c2d9d9becaf4267f03685e70233c1335f22d1c0d:/src/main.cpp diff --git a/src/main.cpp b/src/main.cpp index 9de7b609a..06dba88a2 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -19,82 +19,81 @@ ***************************************************************************/ #include "dolphinapplication.h" + #include "dolphinmainwindow.h" + #include #include +#include #include -#include -#include -#include - -static KCmdLineOptions options[] = -{ - { "+[Url]", I18N_NOOP( "Document to open" ), 0 }, - KCmdLineLastOption -}; - -void openWindow(DolphinApplication* app, const QString& url = QString()) -{ - if (app != 0) { - app->openWindow(url); - return; - } - - static QDBusInterface dbusIface("org.kde.dolphin", "/dolphin/Application", "", - QDBusConnection::connectToBus(QDBusConnection::SessionBus, "session_bus")); - QDBusReply reply = dbusIface.call("openWindow", url); -} +#include +#include int main(int argc, char **argv) { - KAboutData about("dolphin", - I18N_NOOP("Dolphin"), - "0.8.0", - I18N_NOOP("File Manager"), + KAboutData about("dolphin", 0, + ki18nc("@title", "Dolphin"), + "0.9.5", + ki18nc("@title", "File Manager"), KAboutData::License_GPL, - "(C) 2006 Peter Penz"); + ki18nc("@info:credit", "(C) 2006, 2007 Peter Penz")); about.setHomepage("http://enzosworld.gmxhome.de"); - about.setBugAddress("peter.penz@gmx.at"); - about.addAuthor("Peter Penz", I18N_NOOP("Maintainer and developer"), "peter.penz@gmx.at"); - about.addAuthor("Cvetoslav Ludmiloff", I18N_NOOP("Developer"), "ludmiloff@gmail.com"); - about.addAuthor("Stefan Monov", I18N_NOOP("Developer"), "logixoul@gmail.com"); - about.addAuthor("Michael Austin", I18N_NOOP("Documentation"), "tuxedup@users.sourceforge.net"); - about.addAuthor("Orville Bennett", I18N_NOOP("Documentation"), "obennett@hartford.edu"); - about.addCredit("Aaron J. Seigo", I18N_NOOP("... for the great support and the amazing patches")); - about.addCredit("Patrice Tremblay and Gregor Kalisnik", I18N_NOOP("... for their patches")); - about.addCredit("Ain, Itai, Ivan, Stephane, Patrice, Piotr and Stefano", - I18N_NOOP("... for their translations")); + about.addAuthor(ki18nc("@info:credit", "Peter Penz"), + ki18nc("@info:credit", "Maintainer and developer"), + "peter.penz@gmx.at"); + about.addAuthor(ki18nc("@info:credit", "David Faure"), + ki18nc("@info:credit", "Developer"), + "faure@kde.org"); + about.addAuthor(ki18nc("@info:credit", "Aaron J. Seigo"), + ki18nc("@info:credit", "Developer"), + "aseigo@kde.org"); + about.addAuthor(ki18nc("@info:credit", "Rafael Fernández López"), + ki18nc("@info:credit", "Developer"), + "ereslibre@kde.org"); + about.addAuthor(ki18nc("@info:credit", "Kevin Ottens"), + ki18nc("@info:credit", "Developer"), + "ervin@kde.org"); + about.addAuthor(ki18nc("@info:credit", "Holger Freyther"), + ki18nc("@info:credit", "Developer"), + "freyther@gmx.net"); + about.addAuthor(ki18nc("@info:credit", "Max Blazejak"), + ki18nc("@info:credit", "Developer"), + "m43ksrocks@gmail.com"); + about.addAuthor(ki18nc("@info:credit", "Michael Austin"), + ki18nc("@info:credit", "Documentation"), + "tuxedup@users.sourceforge.net"); KCmdLineArgs::init(argc, argv, &about); + + KCmdLineOptions options; + options.add("+[Url]", ki18nc("@info:shell", "Document to open")); KCmdLineArgs::addCmdLineOptions(options); - DolphinApplication *app = 0; - if (DolphinApplication::start()) { - app = new DolphinApplication(); + + if (!DolphinApplication::start()) { + return 0; } + DolphinApplication app; + // the .desktop file is not taken into account when launching manually, so + // set the icon precautionally: + QApplication::setWindowIcon(KIcon("system-file-manager")); + KGlobal::locale()->insertCatalog("libkonq"); // needed for applications using libkonq -#warning TODO, SessionManagement -#if 0 - if (false /* KDE4-TODO: app.isSessionRestored() */) { + if (app.isSessionRestored()) { int n = 1; - while (KMainWindow::canBeRestored(n)){ - Dolphin::mainWin().restore(n); + while (KMainWindow::canBeRestored(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 { -#endif - - KCmdLineArgs* args = KCmdLineArgs::parsedArgs(); - if (args->count() > 0) { - for (int i = 0; i < args->count(); ++i) { - openWindow(app, args->arg(i)); - } - } - else { - openWindow(app); - } - args->clear(); - if (app != 0) { - return app->exec(); + app.exec(); } + + return 0; }