summaryrefslogtreecommitdiff
path: root/src/application.cpp
diff options
context:
space:
mode:
authorAndrea Diamantini <adjam7@gmail.com>2012-07-09 23:27:53 +0200
committerAndrea Diamantini <adjam7@gmail.com>2012-07-09 23:27:53 +0200
commit050659a86bc4419ae0d9f67ea013f8657fc23c71 (patch)
treec1aa5914aec9925a8163eae735601b5f1271712b /src/application.cpp
parentSVN_SILENT made messages (.desktop file) (diff)
downloadrekonq-050659a86bc4419ae0d9f67ea013f8657fc23c71.tar.xz
Fix session restore code
This let bookmark manager code properly load :) BUG: 296388 BUG: 298051
Diffstat (limited to 'src/application.cpp')
-rw-r--r--src/application.cpp167
1 files changed, 81 insertions, 86 deletions
diff --git a/src/application.cpp b/src/application.cpp
index efbfd60a..cbb083cb 100644
--- a/src/application.cpp
+++ b/src/application.cpp
@@ -194,122 +194,121 @@ int Application::newInstance()
kDebug() << "are there arguments? " << areThereArguments;
kDebug() << "is rekonq crashed? " << hasToBeRecovered;
- if (isFirstLoad && isSessionRestored())
- {
- isFirstLoad = false;
- }
- if (areThereArguments)
+ if (!isSessionRestored())
{
- // prepare URLS to load
- KUrl::List urlList;
- for (int i = 0; i < args->count(); ++i)
+ if (areThereArguments)
{
- const KUrl u = args->url(i);
+ // prepare URLS to load
+ KUrl::List urlList;
+ for (int i = 0; i < args->count(); ++i)
+ {
+ const KUrl u = args->url(i);
- if (u.isLocalFile() && QFile::exists(u.toLocalFile())) // "rekonq somefile.html" case
- urlList += u;
+ if (u.isLocalFile() && QFile::exists(u.toLocalFile())) // "rekonq somefile.html" case
+ urlList += u;
+ else
+ {
+ // "rekonq kde.org" || "rekonq kde:kdialog" case
+ UrlResolver res(args->arg(i));
+ UrlSearchList list = res.orderedSearchItems();
+ if (list.isEmpty())
+ {
+ urlList += u;
+ }
+ else
+ {
+ urlList += list.first().url;
+ }
+ }
+ }
+
+ if (isFirstLoad && (ReKonfig::startupBehaviour() == 2) && sessionManager()->restoreSessionFromScratch())
+ {
+ isFirstLoad = false;
+ }
+
+ // first argument: 99% of the time we have just that...
+ if (isFirstLoad)
+ {
+ // No windows in the current desktop? No windows at all?
+ // Create a new one and load there sites...
+ loadUrl(urlList.at(0), Rekonq::NewWindow);
+ }
else
{
- // "rekonq kde.org" || "rekonq kde:kdialog" case
- UrlResolver res(args->arg(i));
- UrlSearchList list = res.orderedSearchItems();
- if (list.isEmpty())
+ if (!ReKonfig::openExternalLinksInNewWindow())
{
- urlList += u;
+ loadUrl(urlList.at(0), Rekonq::NewFocusedTab);
}
else
{
- urlList += list.first().url;
+ loadUrl(urlList.at(0), Rekonq::NewWindow);
}
- }
- }
- if (isFirstLoad && (ReKonfig::startupBehaviour() == 2) && sessionManager()->restoreSessionFromScratch())
- {
- isFirstLoad = false;
- }
+ if (!mainWindow()->isActiveWindow())
+ KWindowSystem::demandAttention(mainWindow()->winId(), true);
+ }
- // first argument: 99% of the time we have just that...
- if (isFirstLoad)
- {
- // No windows in the current desktop? No windows at all?
- // Create a new one and load there sites...
- loadUrl(urlList.at(0), Rekonq::NewWindow);
- }
- else
- {
+ // following arguments: what's best behavior here?
+ // I'm pretty sure no one has real opinion about...
if (!ReKonfig::openExternalLinksInNewWindow())
{
- loadUrl(urlList.at(0), Rekonq::NewFocusedTab);
+ for (int i = 1; i < urlList.count(); ++i)
+ loadUrl(urlList.at(i), Rekonq::NewFocusedTab);
}
else
{
- loadUrl(urlList.at(0), Rekonq::NewWindow);
+ for (int i = 1; i < urlList.count(); ++i)
+ loadUrl(urlList.at(i), Rekonq::NewWindow);
}
-
- if (!mainWindow()->isActiveWindow())
- KWindowSystem::demandAttention(mainWindow()->winId(), true);
- }
-
- // following arguments: what's best behavior here?
- // I'm pretty sure no one has real opinion about...
- if (!ReKonfig::openExternalLinksInNewWindow())
- {
- for (int i = 1; i < urlList.count(); ++i)
- loadUrl(urlList.at(i), Rekonq::NewFocusedTab);
}
else
{
- for (int i = 1; i < urlList.count(); ++i)
- loadUrl(urlList.at(i), Rekonq::NewWindow);
- }
- }
- else
- {
- if (isFirstLoad)
- {
- if (hasToBeRecovered)
+ if (isFirstLoad)
{
- loadUrl(KUrl("about:closedTabs"), Rekonq::NewWindow);
+ if (hasToBeRecovered)
+ {
+ loadUrl(KUrl("about:closedTabs"), Rekonq::NewWindow);
+ }
+ else
+ {
+ switch (ReKonfig::startupBehaviour())
+ {
+ case 0: // open home page
+ newMainWindow()->homePage();
+ break;
+ case 1: // open new tab page
+ loadUrl(KUrl("about:home"), Rekonq::NewWindow);
+ break;
+ case 2: // restore session
+ if (sessionManager()->restoreSessionFromScratch())
+ {
+ break;
+ }
+ default:
+ newMainWindow()->homePage();
+ break;
+ }
+ }
}
else
{
- switch (ReKonfig::startupBehaviour())
+ switch (ReKonfig::newTabsBehaviour())
{
- case 0: // open home page
- newMainWindow()->homePage();
+ case 0: // new tab page
+ loadUrl(KUrl("about:home") , Rekonq::NewWindow);
break;
- case 1: // open new tab page
- loadUrl(KUrl("about:home"), Rekonq::NewWindow);
+ case 2: // homepage
+ loadUrl(KUrl(ReKonfig::homePage()) , Rekonq::NewWindow);
break;
- case 2: // restore session
- if (sessionManager()->restoreSessionFromScratch())
- {
- break;
- }
+ case 1: // blank page
default:
- newMainWindow()->homePage();
+ loadUrl(KUrl("about:blank") , Rekonq::NewWindow);
break;
}
}
}
- else
- {
- switch (ReKonfig::newTabsBehaviour())
- {
- case 0: // new tab page
- loadUrl(KUrl("about:home") , Rekonq::NewWindow);
- break;
- case 2: // homepage
- loadUrl(KUrl(ReKonfig::homePage()) , Rekonq::NewWindow);
- break;
- case 1: // blank page
- default:
- loadUrl(KUrl("about:blank") , Rekonq::NewWindow);
- break;
- }
- }
}
if (isFirstLoad)
@@ -333,10 +332,6 @@ int Application::newInstance()
historyManager();
- // bookmarks loading
- connect(bookmarkManager(), SIGNAL(openUrl(KUrl, Rekonq::OpenType)),
- instance(), SLOT(loadUrl(KUrl, Rekonq::OpenType)));
-
ReKonfig::setRecoverOnCrash(ReKonfig::recoverOnCrash() + 1);
saveConfiguration();
}