diff options
| author | Andrea Diamantini <adjam7@gmail.com> | 2010-04-09 00:57:44 +0200 | 
|---|---|---|
| committer | Andrea Diamantini <adjam7@gmail.com> | 2010-04-09 00:57:44 +0200 | 
| commit | 2000e8acb0e5f851dfc4024b48c7f08610fc857e (patch) | |
| tree | 3af7636d22c3d56ac80ae69751a7bc0bf23d7e20 /src | |
| parent | This is a really big commit, implementing the new urlbar (diff) | |
| download | rekonq-2000e8acb0e5f851dfc4024b48c7f08610fc857e.tar.xz | |
Re-enabling all KDE url magics
Diffstat (limited to 'src')
| -rw-r--r-- | src/application.cpp | 82 | ||||
| -rw-r--r-- | src/application.h | 2 | 
2 files changed, 46 insertions, 38 deletions
| diff --git a/src/application.cpp b/src/application.cpp index 3405a1b2..48264440 100644 --- a/src/application.cpp +++ b/src/application.cpp @@ -289,53 +289,23 @@ void Application::loadUrl(const KUrl& url, const Rekonq::OpenType& type)      if (url.isEmpty())          return; -    // sanitization -    KUrl loadingUrl( url.toEncoded() ); - -    if ( !loadingUrl.isValid() ) +    if ( !url.isValid() )      { -        KMessageBox::error(0, i18n("Malformed URL:\n%1", loadingUrl.url(KUrl::RemoveTrailingSlash))); +        KMessageBox::error(0, i18n("Malformed URL:\n%1", url.url(KUrl::RemoveTrailingSlash)));          return;      } -    // first, create the webview(s) to not let hangs UI.. -    WebTab *tab = 0; -    MainWindow *w = 0; -    w = (type == Rekonq::NewWindow)  -        ? newMainWindow() -        : mainWindow(); -         -    switch(type) -    { -    case Rekonq::SettingOpenTab: -        tab = w->mainView()->newWebTab(!ReKonfig::openTabsBack(), ReKonfig::openTabsNearCurrent()); -        break; -    case Rekonq::NewCurrentTab: -        tab = w->mainView()->newWebTab(true); -        break; -    case Rekonq::NewBackTab: -        tab = w->mainView()->newWebTab(false, ReKonfig::openTabsNearCurrent()); -        break; -    case Rekonq::NewWindow: -    case Rekonq::CurrentTab: -        tab = w->mainView()->currentWebTab(); -        break; -    }; -     -    WebView *view = tab->view(); -     -    if (view) -    { -        FilterUrlJob *job = new FilterUrlJob(view, loadingUrl.pathOrUrl(), this); -        Weaver::instance()->enqueue(job); -    } +    prepareLoading(url.pathOrUrl(), type);  }  void Application::loadUrl(const QString& urlString,  const Rekonq::OpenType& type) -{     -    return loadUrl( QUrl::fromUserInput(urlString), type ); +{ +    if(urlString.isEmpty()) +        return; + +    prepareLoading(urlString, type);  } @@ -400,3 +370,39 @@ void Application::newWindow()      loadUrl( KUrl("about:home"), Rekonq::NewWindow );      mainWindow()->mainView()->urlBarWidget()->setFocus();  } + + +void Application::prepareLoading(const QString& urlString, const Rekonq::OpenType& type) +{ +    // first, create the webview(s) to not let hangs UI.. +    WebTab *tab = 0; +    MainWindow *w = 0; +    w = (type == Rekonq::NewWindow)  +        ? newMainWindow() +        : mainWindow(); +         +    switch(type) +    { +    case Rekonq::SettingOpenTab: +        tab = w->mainView()->newWebTab(!ReKonfig::openTabsBack(), ReKonfig::openTabsNearCurrent()); +        break; +    case Rekonq::NewCurrentTab: +        tab = w->mainView()->newWebTab(true); +        break; +    case Rekonq::NewBackTab: +        tab = w->mainView()->newWebTab(false, ReKonfig::openTabsNearCurrent()); +        break; +    case Rekonq::NewWindow: +    case Rekonq::CurrentTab: +        tab = w->mainView()->currentWebTab(); +        break; +    }; +     +    WebView *view = tab->view(); +     +    if (view) +    { +        FilterUrlJob *job = new FilterUrlJob(view, urlString, this); +        Weaver::instance()->enqueue(job); +    } +} diff --git a/src/application.h b/src/application.h index 4340b004..760f7943 100644 --- a/src/application.h +++ b/src/application.h @@ -141,6 +141,8 @@ private slots:      void loadResolvedUrl(ThreadWeaver::Job *);  private: +    void prepareLoading(const QString& urlString, const Rekonq::OpenType& type); +          static QWeakPointer<HistoryManager> s_historyManager;      static QWeakPointer<BookmarkProvider> s_bookmarkProvider;      static QWeakPointer<SessionManager> s_sessionManager; | 
