Changes the tabName function to return the name of a specific tab

Summary:
Changes the tabName function to return the name of the passed in
DolphinTabPage. Previously it would return the name of the active tab,
which causes in-active tabs to get the wrong name.

Test Plan:
Open Dolphin
Right click a folder and select 'Open in new tab'
Notice that the new tab has the wrong title

BUG: 397910

Reviewers: #dolphin, ngraham, elvisangelaccio

Reviewed By: #dolphin, ngraham, elvisangelaccio

Subscribers: kfm-devel

Tags: #dolphin

Differential Revision: https://phabricator.kde.org/D15112
This commit is contained in:
David Hallas 2018-08-28 09:00:13 +02:00
parent a23acffd5e
commit 5a9567730d
2 changed files with 9 additions and 8 deletions

View file

@ -116,7 +116,7 @@ void DolphinTabWidget::refreshViews()
{
const int tabCount = count();
for (int i = 0; i < tabCount; ++i) {
tabBar()->setTabText(i, tabName());
tabBar()->setTabText(i, tabName(tabPageAt(i)));
tabPageAt(i)->refreshViews();
}
}
@ -161,7 +161,7 @@ void DolphinTabWidget::openNewTab(const QUrl& primaryUrl, const QUrl& secondaryU
this, &DolphinTabWidget::activeViewChanged);
connect(tabPage, &DolphinTabPage::activeViewUrlChanged,
this, &DolphinTabWidget::tabUrlChanged);
addTab(tabPage, QIcon::fromTheme(KIO::iconNameForUrl(primaryUrl)), tabName());
addTab(tabPage, QIcon::fromTheme(KIO::iconNameForUrl(primaryUrl)), tabName(tabPage));
if (focusWidget) {
// The DolphinViewContainer grabbed the keyboard focus. As the tab is opened
@ -306,7 +306,7 @@ void DolphinTabWidget::tabUrlChanged(const QUrl& url)
{
const int index = indexOf(qobject_cast<QWidget*>(sender()));
if (index >= 0) {
tabBar()->setTabText(index, tabName());
tabBar()->setTabText(index, tabName(tabPageAt(index)));
tabBar()->setTabIcon(index, QIcon::fromTheme(KIO::iconNameForUrl(url)));
// Emit the currentUrlChanged signal if the url of the current tab has been changed.
@ -354,12 +354,12 @@ void DolphinTabWidget::tabRemoved(int index)
emit tabCountChanged(count());
}
QString DolphinTabWidget::tabName() const
QString DolphinTabWidget::tabName(DolphinTabPage* tabPage) const
{
if (currentTabPage() == nullptr) {
if (!tabPage) {
return QString();
}
QString name = currentTabPage()->activeViewContainer()->getCaption();
QString name = tabPage->activeViewContainer()->getCaption();
// Make sure that a '&' inside the directory name is displayed correctly
// and not misinterpreted as a keyboard shortcut in QTabBar::setTabText()
return name.replace('&', QLatin1String("&&"));

View file

@ -191,9 +191,10 @@ protected:
private:
/**
* Returns the name of the tab for the URL \a url.
* @param tabPage The tab page to get the name of
* @return The name of the tab page
*/
QString tabName() const;
QString tabName(DolphinTabPage* tabPage) const;
private:
/** Caches the (negated) places panel visibility */