Browse Source

Implement open & select file in file manager [Windows only]

adaptive-webui-19844
Nick Tiskov 12 years ago
parent
commit
997b16a24a
  1. 15
      src/properties/propertieswidget.cpp

15
src/properties/propertieswidget.cpp

@ -449,14 +449,26 @@ void PropertiesWidget::openFolder(const QModelIndex &index, bool containing_fold @@ -449,14 +449,26 @@ void PropertiesWidget::openFolder(const QModelIndex &index, bool containing_fold
}
if (path_items.isEmpty())
return;
#ifndef Q_OS_WIN
if (containing_folder)
path_items.removeLast();
#endif
const QDir saveDir(h.save_path());
const QString filename = path_items.join("/");
const QString file_path = fsutils::expandPath(saveDir.absoluteFilePath(filename));
qDebug("Trying to open folder at %s", qPrintable(file_path));
// Flush data
h.flush_cache();
#ifdef Q_OS_WIN
if (containing_folder) {
// Syntax is: explorer /select, "C:\Folder1\Folder2\file_to_select"
// Dir separators MUST be win-style slashes
QProcess::startDetached("explorer.exe", QStringList() << "/select," << fsutils::toNativePath(file_path));
} else {
#endif
if (QFile::exists(file_path)) {
// Hack to access samba shares with QDesktopServices::openUrl
const QString p = file_path.startsWith("//") ? QString("file:") + file_path : file_path;
@ -464,6 +476,9 @@ void PropertiesWidget::openFolder(const QModelIndex &index, bool containing_fold @@ -464,6 +476,9 @@ void PropertiesWidget::openFolder(const QModelIndex &index, bool containing_fold
} else {
QMessageBox::warning(this, tr("I/O Error"), tr("This folder does not exist yet."));
}
#ifdef Q_OS_WIN
}
#endif
}
void PropertiesWidget::displayFilesListMenu(const QPoint&) {

Loading…
Cancel
Save