]> cloud.milkyroute.net Git - dolphin.git/blobdiff - src/terminalsidebarpage.cpp
Adapt Dolphin Nepomuk support to namespace changes.
[dolphin.git] / src / terminalsidebarpage.cpp
index 8c8dcedeff7f7e85d73cfcdcd1bad508dcea5ee3..cfa55c0d84c80f6e06543f8b92a912214d62cbd4 100644 (file)
 #include <klibloader.h>
 #include <kde_terminal_interface.h>
 #include <kparts/part.h>
+#include <kshell.h>
 
-#include <QVBoxLayout>
+#include <QBoxLayout>
+#include <QShowEvent>
 
 TerminalSidebarPage::TerminalSidebarPage(QWidget* parent) :
     SidebarPage(parent),
@@ -40,20 +42,34 @@ TerminalSidebarPage::~TerminalSidebarPage()
 
 void TerminalSidebarPage::setUrl(const KUrl& url)
 {
-    SidebarPage::setUrl(url);
-    // TODO: synchronize terminal
+    if (!SidebarPage::url().equals(url, KUrl::CompareWithoutTrailingSlash)) {
+        SidebarPage::setUrl(url);
+        if ((m_terminal != 0) && isVisible()) {
+            m_terminal->sendInput("cd " + KShell::quoteArg(url.path()) + '\n');
+        }
+    }
 }
 
 void TerminalSidebarPage::showEvent(QShowEvent* event)
 {
+    if (event->spontaneous()) {
+        SidebarPage::showEvent(event);
+        return;
+    }
+
     if (m_terminal == 0) {
         KLibFactory* factory = KLibLoader::self()->factory("libkonsolepart");
-        KParts::Part* part = static_cast<KParts::Part*>(factory->create(this, "KParts::ReadOnlyPart"));
+        KParts::Part* part = factory ? static_cast<KParts::Part*>(factory->create(this, "KParts::ReadOnlyPart")) : 0;
         if (part != 0) {
-            m_terminal = part->widget();
-            m_layout->addWidget(m_terminal);
+            m_layout->addWidget(part->widget());
+            m_terminal = qobject_cast<TerminalInterface *>(part);
         }
     }
+    if (m_terminal != 0) {
+        m_terminal->showShellInDir(url().path());
+        m_terminal->sendInput("clear\n");
+    }
+
     SidebarPage::showEvent(event);
 }