Compare commits
128 Commits
ubuntu/cos
...
ubuntu/plu
Author | SHA1 | Date |
---|---|---|
Simon Quigley | ed9760f617 | 3 weeks ago |
Simon Quigley | e1aa429d8b | 3 weeks ago |
Simon Quigley | c3075b3182 | 2 months ago |
Simon Quigley | a90ab52cb3 | 3 months ago |
Simon Quigley | a7c55cca9d | 3 months ago |
Simon Quigley | 49541811db | 3 months ago |
Rik Mills | 017f7c8a4d | 3 months ago |
Aaron Rainbolt | b26925ea07 | 5 months ago |
Aaron Rainbolt | 802f5579bb | 5 months ago |
Aaron Rainbolt | 0f9f5df868 | 7 months ago |
Aaron Rainbolt | 1db48c93b7 | 7 months ago |
Aaron Rainbolt | 644c99327e | 7 months ago |
Aaron Rainbolt | ea95d92cfa | 7 months ago |
Aaron Rainbolt | 2c7d5a99f5 | 7 months ago |
Aaron Rainbolt | b2307df376 | 7 months ago |
Aaron Rainbolt | d327b18479 | 1 year ago |
Aaron Rainbolt | c5f0c347e1 | 1 year ago |
Aaron Rainbolt | fa8e6fa423 | 1 year ago |
Aaron Rainbolt | d5ecfb6681 | 1 year ago |
Aaron Rainbolt | 6dab1b3af8 | 1 year ago |
Aaron Rainbolt | b2487aad6c | 1 year ago |
Simon Quigley | a575de56f8 | 1 year ago |
Simon Quigley | c3f4fc8b10 | 2 years ago |
Simon Quigley | 40e11089cc | 2 years ago |
Simon Quigley | 98f5f397dc | 2 years ago |
Aaron Rainbolt | d0c06c5d6b | 2 years ago |
Aaron Rainbolt | 052a556bc0 | 2 years ago |
Aaron Rainbolt | 83c034bd6f | 2 years ago |
Aaron Rainbolt | 900d477f1d | 2 years ago |
Aaron Rainbolt | e251a6aa32 | 2 years ago |
Aaron Rainbolt | a273e1567d | 2 years ago |
Aaron Rainbolt | eb615c3512 | 2 years ago |
Aaron Rainbolt | 0672e46c73 | 2 years ago |
Aaron Rainbolt | cbe58deaea | 2 years ago |
Aaron Rainbolt | f0df77303e | 2 years ago |
Simon Quigley | d6371bc277 | 2 years ago |
Simon Quigley | 5fd9107a93 | 2 years ago |
Simon Quigley | f10ba18860 | 2 years ago |
Simon Quigley | 1e0ecbdf79 | 2 years ago |
Simon Quigley | c98bcd1948 | 2 years ago |
Simon Quigley | 1fa81fcbb4 | 2 years ago |
Simon Quigley | 2602979b29 | 2 years ago |
Simon Quigley | 0f65b41150 | 2 years ago |
Simon Quigley | be07f15a59 | 2 years ago |
Simon Quigley | 0a196e7e16 | 2 years ago |
Simon Quigley | 944ca043e5 | 2 years ago |
Simon Quigley | b6b785512d | 2 years ago |
Simon Quigley | 0db4d62f51 | 2 years ago |
Simon Quigley | 6a7fd542a9 | 3 years ago |
Simon Quigley | 1cb774dd2e | 3 years ago |
Simon Quigley | 9f419a4e10 | 3 years ago |
Simon Quigley | 84bf4caa68 | 3 years ago |
Simon Quigley | c5631d7a2d | 3 years ago |
Simon Quigley | 8654c7904b | 3 years ago |
Simon Quigley | ce2f4feab5 | 3 years ago |
Simon Quigley | 755cf858f6 | 3 years ago |
Simon Quigley | 32558ac832 | 3 years ago |
Simon Quigley | 817faa5457 | 3 years ago |
Simon Quigley | f4f7453d4f | 3 years ago |
Simon Quigley | dbe70dd76e | 3 years ago |
Simon Quigley | 1bb5e074ae | 3 years ago |
Simon Quigley | 1c098568f3 | 3 years ago |
Simon Quigley | 0888e2bed8 | 3 years ago |
Simon Quigley | fa135f8e2a | 3 years ago |
Simon Quigley | 5eca821f28 | 3 years ago |
Dmitry Shachnev | 748c733729 | 3 years ago |
Dmitry Shachnev | f1cccbe4e1 | 3 years ago |
apt-ghetto | 8e2977cd88 | 4 years ago |
Raman Sarda | 24b035552e | 4 years ago |
Raman Sarda | 1215d360d8 | 4 years ago |
Simon Quigley | c448ea0a2f | 5 years ago |
Gianfranco Costamagna | 19d5b222af | 5 years ago |
Simon Quigley | a56d40dc0a | 5 years ago |
Simon Quigley | 70bbac5c92 | 5 years ago |
Simon Quigley | 54b50f5152 | 5 years ago |
Simon Quigley | f742be6a17 | 5 years ago |
Simon Quigley | ac41f3a96b | 5 years ago |
Simon Quigley | a084e5bb86 | 5 years ago |
Simon Quigley | c1ffd9db39 | 5 years ago |
Simon Quigley | 251d898efc | 5 years ago |
Rik Mills | b671b41618 | 5 years ago |
Rik Mills | 6df0173c9b | 5 years ago |
Simon Quigley | 370ce0986a | 5 years ago |
Simon Quigley | ff3efabd56 | 5 years ago |
Simon Quigley | 897e1d1d5f | 5 years ago |
Simon Quigley | b3e9f2e54d | 5 years ago |
Simon Quigley | c4a6bb316b | 5 years ago |
Simon Quigley | ea2f48482a | 5 years ago |
Simon Quigley | d1c409451e | 5 years ago |
Rik Mills | b75411bb14 | 5 years ago |
apt-ghetto | bc3e4bc2b2 | 5 years ago |
apt-ghetto | 4d37efb21b | 5 years ago |
Rik Mills | e8e7d9bd5a | 5 years ago |
Walter Lapchynski | 4cfa12445f | 6 years ago |
Raman Sarda | 3663fb0ed1 | 6 years ago |
apt-ghetto | ba535b4af8 | 6 years ago |
apt-ghetto | 53e5a55691 | 6 years ago |
Rik Mills | faec7ee9c2 | 6 years ago |
apt-ghetto | 89d37d65c4 | 6 years ago |
apt-ghetto | 5e3b197f0d | 6 years ago |
apt-ghetto | bdd05e9657 | 6 years ago |
apt-ghetto | cd3ad840e2 | 6 years ago |
apt-ghetto | ac1face24d | 6 years ago |
Rik Mills | 9e81f0eb04 | 6 years ago |
Rik Mills | 973fb83019 | 6 years ago |
apt-ghetto | 5d2a1fd479 | 6 years ago |
Rik Mills | e727e901ee | 6 years ago |
Rik Mills | 73e2e10e1c | 6 years ago |
Simon Quigley | d71da0cea2 | 6 years ago |
Simon Quigley | f653c90d68 | 6 years ago |
Simon Quigley | 1635b116c7 | 6 years ago |
Simon Quigley | 18db7b2935 | 6 years ago |
Simon Quigley | cb42c7b187 | 6 years ago |
Dan Simmons | 3fa1ce108c | 6 years ago |
Simon Quigley | 532bd6d192 | 6 years ago |
Simon Quigley | 6efc7478dc | 6 years ago |
Simon Quigley | e0447781be | 6 years ago |
Simon Quigley | a95affe263 | 6 years ago |
Simon Quigley | 6ff37a972c | 6 years ago |
Simon Quigley | d02d893e30 | 6 years ago |
Simon Quigley | ff19c6a4b1 | 6 years ago |
Simon Quigley | 6a38fac102 | 6 years ago |
Simon Quigley | 27c0a43d79 | 6 years ago |
Simon Quigley | 88d19f7ee1 | 6 years ago |
Simon Quigley | 03320d44ae | 6 years ago |
Dmitry Shachnev | 50446e08c8 | 6 years ago |
Simon Quigley | 714eb972db | 6 years ago |
Dan Simmons | b6d30257ca | 6 years ago |
@ -1 +0,0 @@
|
||||
11
|
@ -0,0 +1,6 @@
|
||||
[DEFAULT]
|
||||
debian-branch = debian/sid
|
||||
upstream-branch = upstream/latest
|
||||
pristine-tar = True
|
||||
compression = xz
|
||||
|
@ -1,7 +0,0 @@
|
||||
usr/include/libfm-qt/*.h
|
||||
usr/include/libfm-qt/customactions/*.h
|
||||
usr/include/libfm-qt/core/*.h
|
||||
usr/lib/*/*.so
|
||||
usr/lib/*/pkgconfig/*
|
||||
|
||||
usr/share/cmake/fm-qt/*.cmake
|
@ -1,4 +0,0 @@
|
||||
usr/lib/*/*.so.*
|
||||
usr/share/libfm-qt/terminals.list
|
||||
usr/share/libfm-qt/archivers.list
|
||||
usr/share/mime/packages/libfm-qt-mimetypes.xml
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1 @@
|
||||
usr/lib/*/*.so.*
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,3 @@
|
||||
usr/share/libfm-qt6/archivers.list
|
||||
usr/share/libfm-qt6/terminals.list
|
||||
usr/share/mime/packages/libfm-qt6-mimetypes.xml
|
@ -0,0 +1,8 @@
|
||||
usr/include/libfm-qt6/*.h
|
||||
usr/include/libfm-qt6/core/*.h
|
||||
usr/include/libfm-qt6/core/legacy/*.h
|
||||
usr/include/libfm-qt6/core/vfs/*.h
|
||||
usr/include/libfm-qt6/customactions/*.h
|
||||
usr/lib/*/*.so
|
||||
usr/lib/*/pkgconfig/*
|
||||
usr/share/cmake/fm-qt6/*.cmake
|
@ -0,0 +1 @@
|
||||
usr/share/libfm-qt6/translations
|
@ -1,18 +0,0 @@
|
||||
Description: Add integration for LXQt Archiver
|
||||
Author: "Hong Jen Yee (PCMan)" <pcman.tw@gmail.com>
|
||||
Origin: upstream
|
||||
Applied-Upstream: commit:9a3bf23
|
||||
Last-Update: 2018-07-14
|
||||
--- a/data/archivers.list
|
||||
+++ b/data/archivers.list
|
||||
@@ -1,3 +1,10 @@
|
||||
+[lxqt-archiver]
|
||||
+create=lxqt-archiver --add %U
|
||||
+extract=lxqt-archiver --extract %U
|
||||
+extract_to=lxqt-archiver --extract-to %d %U
|
||||
+mime_types=application/x-7z-compressed;application/x-7z-compressed-tar;application/x-ace;application/x-alz;application/x-ar;application/x-arj;application/x-bzip;application/x-bzip-compressed-tar;application/x-bzip1;application/x-bzip1-compressed-tar;application/x-cabinet;application/x-cbr;application/x-cbz;application/x-cd-image;application/x-compress;application/x-compressed-tar;application/x-cpio;application/x-deb;application/x-ear;application/x-ms-dos-executable;application/x-gtar;application/x-gzip;application/x-gzpostscript;application/x-java-archive;application/x-lha;application/x-lhz;application/x-lzip;application/x-lzip-compressed-tar;application/x-lzma;application/x-lzma-compressed-tar;application/x-lzop;application/x-lzop-compressed-tar;application/x-rar;application/x-rar-compressed;application/vnd.rar;application/x-rpm;application/x-rzip;application/x-tar;application/x-tarz;application/x-stuffit;application/x-war;application/x-xz;application/x-xz-compressed-tar;application/x-zip;application/x-zip-compressed;application/x-zoo;application/zip;multipart/x-zip;
|
||||
+supports_uris=true
|
||||
+
|
||||
[file-roller]
|
||||
create=file-roller --add %U
|
||||
extract=file-roller --extract %U
|
@ -1,166 +0,0 @@
|
||||
Description: Support adding metadata for trusting executables.
|
||||
Author: Tsu Jan <tsujan2000@gmail.com>
|
||||
Applied-Upstream: https://github.com/lxqt/libfm-qt/pull/242/commits/9c2f00c2e22b8054bcaedad89ef74f0432b9f7fe
|
||||
Last-Update: 2018-10-15
|
||||
--- a/src/core/basicfilelauncher.cpp
|
||||
+++ b/src/core/basicfilelauncher.cpp
|
||||
@@ -176,7 +176,7 @@ bool BasicFileLauncher::launchDesktopEnt
|
||||
const char* desktopEntryName = nullptr;
|
||||
FilePathList shortcutTargetPaths;
|
||||
if(fileInfo->isExecutableType()) {
|
||||
- auto act = quickExec_ ? ExecAction::DIRECT_EXEC : askExecFile(fileInfo);
|
||||
+ auto act = (quickExec_ || fileInfo->isTrustable()) ? ExecAction::DIRECT_EXEC : askExecFile(fileInfo);
|
||||
switch(act) {
|
||||
case ExecAction::EXEC_IN_TERMINAL:
|
||||
case ExecAction::DIRECT_EXEC: {
|
||||
@@ -275,7 +275,7 @@ bool BasicFileLauncher::launchExecutable
|
||||
auto filename = fileInfo->path().localPath();
|
||||
/* FIXME: we need to use eaccess/euidaccess here. */
|
||||
if(g_file_test(filename.get(), G_FILE_TEST_IS_EXECUTABLE)) {
|
||||
- auto act = quickExec_ ? ExecAction::DIRECT_EXEC : askExecFile(fileInfo);
|
||||
+ auto act = (quickExec_ || fileInfo->isTrustable()) ? ExecAction::DIRECT_EXEC : askExecFile(fileInfo);
|
||||
int flags = G_APP_INFO_CREATE_NONE;
|
||||
switch(act) {
|
||||
case ExecAction::EXEC_IN_TERMINAL:
|
||||
--- a/src/core/fileinfo.cpp
|
||||
+++ b/src/core/fileinfo.cpp
|
||||
@@ -9,7 +9,8 @@ const char defaultGFileInfoQueryAttribs[
|
||||
"time::*,"
|
||||
"access::*,"
|
||||
"id::filesystem,"
|
||||
- "metadata::emblems";
|
||||
+ "metadata::emblems,"
|
||||
+ "metadata::trusted";
|
||||
|
||||
FileInfo::FileInfo() {
|
||||
// FIXME: initialize numeric data members
|
||||
@@ -23,6 +24,7 @@ FileInfo::~FileInfo() {
|
||||
}
|
||||
|
||||
void FileInfo::setFromGFileInfo(const GObjectPtr<GFileInfo>& inf, const FilePath& parentDirPath) {
|
||||
+ inf_ = inf;
|
||||
dirPath_ = parentDirPath;
|
||||
const char* tmp, *uri;
|
||||
GIcon* gicon;
|
||||
@@ -377,6 +379,37 @@ bool FileInfo::isExecutableType() const
|
||||
return mimeType_->canBeExecutable();
|
||||
}
|
||||
|
||||
+bool FileInfo::isTrustable() const {
|
||||
+ if(isExecutableType()) {
|
||||
+ /* to avoid GIO assertion warning: */
|
||||
+ if(g_file_info_get_attribute_type(inf_.get(), "metadata::trusted") == G_FILE_ATTRIBUTE_TYPE_STRING) {
|
||||
+ if(const auto data = g_file_info_get_attribute_string(inf_.get(), "metadata::trusted")) {
|
||||
+ return (strcmp(data, "true") == 0);
|
||||
+ }
|
||||
+ }
|
||||
+ }
|
||||
+ return false;
|
||||
+}
|
||||
+
|
||||
+void FileInfo::setTrustable(bool trust) const {
|
||||
+ if(!isExecutableType()) {
|
||||
+ return; // "metadata::trusted" is only for executables
|
||||
+ }
|
||||
+ GObjectPtr<GFileInfo> info {g_file_info_new()}; // used to set only this attribute
|
||||
+ if(trust) {
|
||||
+ g_file_info_set_attribute_string(info.get(), "metadata::trusted", "true");
|
||||
+ g_file_info_set_attribute_string(inf_.get(), "metadata::trusted", "true");
|
||||
+ }
|
||||
+ else {
|
||||
+ g_file_info_set_attribute(info.get(), "metadata::trusted", G_FILE_ATTRIBUTE_TYPE_INVALID, nullptr);
|
||||
+ g_file_info_set_attribute(inf_.get(), "metadata::trusted", G_FILE_ATTRIBUTE_TYPE_INVALID, nullptr);
|
||||
+ }
|
||||
+ g_file_set_attributes_from_info(path().gfile().get(),
|
||||
+ info.get(),
|
||||
+ G_FILE_QUERY_INFO_NONE,
|
||||
+ nullptr, nullptr);
|
||||
+}
|
||||
+
|
||||
|
||||
bool FileInfoList::isSameType() const {
|
||||
if(!empty()) {
|
||||
--- a/src/core/fileinfo.h
|
||||
+++ b/src/core/fileinfo.h
|
||||
@@ -214,7 +214,12 @@ public:
|
||||
return emblems_;
|
||||
}
|
||||
|
||||
+ bool isTrustable() const;
|
||||
+
|
||||
+ void setTrustable(bool trust) const;
|
||||
+
|
||||
private:
|
||||
+ GObjectPtr<GFileInfo> inf_;
|
||||
std::string name_;
|
||||
QString dispName_;
|
||||
|
||||
--- a/src/filemenu.cpp
|
||||
+++ b/src/filemenu.cpp
|
||||
@@ -245,6 +245,18 @@ FileMenu::FileMenu(Fm::FileInfoList file
|
||||
FileMenu::~FileMenu() {
|
||||
}
|
||||
|
||||
+void FileMenu::addTrustAction() {
|
||||
+ if(info_->isExecutableType() && (!fileLauncher_ || !fileLauncher_->quickExec())) {
|
||||
+ QAction* trustAction = new QAction(files_.size() > 1
|
||||
+ ? tr("Trust selected executables")
|
||||
+ : tr("Trust this executable"),
|
||||
+ this);
|
||||
+ trustAction->setCheckable(true);
|
||||
+ trustAction->setChecked(info_->isTrustable());
|
||||
+ connect(trustAction, &QAction::toggled, this, &FileMenu::onTrustToggled);
|
||||
+ insertAction(propertiesAction_, trustAction);
|
||||
+ }
|
||||
+}
|
||||
|
||||
void FileMenu::addCustomActionItem(QMenu* menu, std::shared_ptr<const FileActionItem> item) {
|
||||
if(!item) { // separator
|
||||
@@ -329,6 +341,12 @@ void FileMenu::onCustomActionTrigerred()
|
||||
}
|
||||
}
|
||||
|
||||
+void FileMenu::onTrustToggled(bool checked) {
|
||||
+ for(auto& file: files_) {
|
||||
+ file->setTrustable(checked);
|
||||
+ }
|
||||
+}
|
||||
+
|
||||
void FileMenu::onFilePropertiesTriggered() {
|
||||
FilePropsDialog::showForFiles(files_);
|
||||
}
|
||||
--- a/src/filemenu.h
|
||||
+++ b/src/filemenu.h
|
||||
@@ -41,6 +41,8 @@ public:
|
||||
explicit FileMenu(Fm::FileInfoList files, std::shared_ptr<const Fm::FileInfo> info, Fm::FilePath cwd, bool isWritableDir = true, const QString& title = QString(), QWidget* parent = nullptr);
|
||||
~FileMenu();
|
||||
|
||||
+ void addTrustAction();
|
||||
+
|
||||
bool useTrash() {
|
||||
return useTrash_;
|
||||
}
|
||||
@@ -162,6 +164,7 @@ protected:
|
||||
protected Q_SLOTS:
|
||||
void onOpenTriggered();
|
||||
void onOpenWithTriggered();
|
||||
+ void onTrustToggled(bool checked);
|
||||
void onFilePropertiesTriggered();
|
||||
void onApplicationTriggered();
|
||||
void onCustomActionTrigerred();
|
||||
--- a/src/folderview.cpp
|
||||
+++ b/src/folderview.cpp
|
||||
@@ -1318,11 +1318,11 @@ void FolderView::onFileClicked(int type,
|
||||
// show context menu
|
||||
auto files = selectedFiles();
|
||||
if(!files.empty()) {
|
||||
- QModelIndexList selIndexes = mode == DetailedListMode ? selectedRows() : selectedIndexes();
|
||||
- Fm::FileMenu* fileMenu = (view && selIndexes.size() == 1)
|
||||
+ Fm::FileMenu* fileMenu = (view && files.size() == 1)
|
||||
? new Fm::FileMenu(files, fileInfo, folderPath, isWritableDir, QString(), view)
|
||||
: new Fm::FileMenu(files, fileInfo, folderPath, isWritableDir);
|
||||
fileMenu->setFileLauncher(fileLauncher_);
|
||||
+ fileMenu->addTrustAction();
|
||||
prepareFileMenu(fileMenu);
|
||||
menu = fileMenu;
|
||||
}
|
@ -1,251 +0,0 @@
|
||||
Description: Fix failure to open smb:// caused by incorrect file info handling
|
||||
Author: "Hong Jen Yee (PCMan)" <pcman.tw@gmail.com>
|
||||
Origin: upstream
|
||||
Applied-Upstream: commit:1a6fa26
|
||||
Last-Update: 2018-07-14
|
||||
--- a/src/core/basicfilelauncher.cpp
|
||||
+++ b/src/core/basicfilelauncher.cpp
|
||||
@@ -27,11 +27,13 @@ bool BasicFileLauncher::launchFiles(cons
|
||||
FilePathList pathsToLaunch;
|
||||
// classify files according to different mimetypes
|
||||
for(auto& fileInfo : fileInfos) {
|
||||
- // qDebug("path: %s, target: %s", fileInfo->path().toString().get(), fileInfo->target().c_str());
|
||||
- if(fileInfo->isDir()) {
|
||||
- folderInfos.emplace_back(fileInfo);
|
||||
- }
|
||||
- else if(fileInfo->isMountable()) {
|
||||
+ /*
|
||||
+ qDebug("path: %s, type: %s, target: %s, isDir: %i, isDesktopEntry: %i",
|
||||
+ fileInfo->path().toString().get(), fileInfo->mimeType()->name(), fileInfo->target().c_str(),
|
||||
+ fileInfo->isDir(), fileInfo->isDesktopEntry());
|
||||
+ */
|
||||
+
|
||||
+ if(fileInfo->isMountable()) {
|
||||
if(fileInfo->target().empty()) {
|
||||
// the mountable is not yet mounted so we have no target URI.
|
||||
GErrorPtr err{G_IO_ERROR, G_IO_ERROR_NOT_MOUNTED,
|
||||
@@ -65,6 +67,9 @@ bool BasicFileLauncher::launchFiles(cons
|
||||
pathsToLaunch.emplace_back(path);
|
||||
}
|
||||
}
|
||||
+ else if(fileInfo->isDir()) {
|
||||
+ folderInfos.emplace_back(fileInfo);
|
||||
+ }
|
||||
else {
|
||||
auto& mimeType = fileInfo->mimeType();
|
||||
mimeTypeToFiles[mimeType->name()].emplace_back(fileInfo);
|
||||
@@ -101,16 +106,27 @@ bool BasicFileLauncher::launchFiles(cons
|
||||
bool BasicFileLauncher::launchPaths(FilePathList paths, GAppLaunchContext* ctx) {
|
||||
// FIXME: blocking with an event loop is not a good design :-(
|
||||
QEventLoop eventLoop;
|
||||
-
|
||||
auto job = new FileInfoJob{paths};
|
||||
job->setAutoDelete(false); // do not automatically delete the job since we want its results later.
|
||||
|
||||
GObjectPtr<GAppLaunchContext> ctxPtr{ctx};
|
||||
+
|
||||
+ // error handling (for example: handle path not mounted error)
|
||||
+ QObject::connect(job, &FileInfoJob::error,
|
||||
+ &eventLoop, [this, job, ctx](const GErrorPtr & err, Job::ErrorSeverity /* severity */ , Job::ErrorAction &act) {
|
||||
+ auto path = job->currentPath();
|
||||
+ if(showError(ctx, err, path, nullptr)) {
|
||||
+ // the user handled the error and ask for retry
|
||||
+ act = Job::ErrorAction::RETRY;
|
||||
+ }
|
||||
+ }, Qt::BlockingQueuedConnection); // BlockingQueuedConnection is required here to pause the job and wait for user response
|
||||
+
|
||||
QObject::connect(job, &FileInfoJob::finished,
|
||||
[&eventLoop]() {
|
||||
// exit the event loop when the job is done
|
||||
eventLoop.exit();
|
||||
});
|
||||
+
|
||||
// run the job in another thread to not block the UI
|
||||
job->runAsync();
|
||||
|
||||
@@ -143,7 +159,7 @@ BasicFileLauncher::ExecAction BasicFileL
|
||||
return ExecAction::DIRECT_EXEC;
|
||||
}
|
||||
|
||||
-bool BasicFileLauncher::showError(GAppLaunchContext* /* ctx */, GErrorPtr& /* err */, const FilePath& /* path */, const FileInfoPtr& /* info */) {
|
||||
+bool BasicFileLauncher::showError(GAppLaunchContext* /* ctx */, const GErrorPtr & /* err */, const FilePath& /* path */, const FileInfoPtr& /* info */) {
|
||||
return false;
|
||||
}
|
||||
|
||||
@@ -247,13 +263,21 @@ bool BasicFileLauncher::launchDesktopEnt
|
||||
|
||||
FilePath BasicFileLauncher::handleShortcut(const FileInfoPtr& fileInfo, GAppLaunchContext* ctx) {
|
||||
auto target = fileInfo->target();
|
||||
+
|
||||
+ // if we know the target is a dir, we are not going to open it using other apps
|
||||
+ // for example: `network:///smb-root' is a shortcut targeting `smb:///' and it's also a dir
|
||||
+ if(fileInfo->isDir()) {
|
||||
+ return FilePath::fromPathStr(target.c_str());
|
||||
+ }
|
||||
+
|
||||
auto scheme = CStrPtr{g_uri_parse_scheme(target.c_str())};
|
||||
if(scheme) {
|
||||
// collect the uri schemes we support
|
||||
if(strcmp(scheme.get(), "file") == 0
|
||||
|| strcmp(scheme.get(), "trash") == 0
|
||||
|| strcmp(scheme.get(), "network") == 0
|
||||
- || strcmp(scheme.get(), "computer") == 0) {
|
||||
+ || strcmp(scheme.get(), "computer") == 0
|
||||
+ || strcmp(scheme.get(), "menu") == 0) {
|
||||
return FilePath::fromUri(fileInfo->target().c_str());
|
||||
}
|
||||
else {
|
||||
--- a/src/core/basicfilelauncher.h
|
||||
+++ b/src/core/basicfilelauncher.h
|
||||
@@ -53,7 +53,7 @@ protected:
|
||||
|
||||
virtual bool openFolder(GAppLaunchContext* ctx, const FileInfoList& folderInfos, GErrorPtr& err);
|
||||
|
||||
- virtual bool showError(GAppLaunchContext* ctx, GErrorPtr& err, const FilePath& path = FilePath{}, const FileInfoPtr& info = FileInfoPtr{});
|
||||
+ virtual bool showError(GAppLaunchContext* ctx, const GErrorPtr& err, const FilePath& path = FilePath{}, const FileInfoPtr& info = FileInfoPtr{});
|
||||
|
||||
virtual ExecAction askExecFile(const FileInfoPtr& file);
|
||||
|
||||
--- a/src/core/fileinfo.cpp
|
||||
+++ b/src/core/fileinfo.cpp
|
||||
@@ -36,10 +36,9 @@ void FileInfo::setFromGFileInfo(const GO
|
||||
size_ = g_file_info_get_size(inf.get());
|
||||
|
||||
tmp = g_file_info_get_content_type(inf.get());
|
||||
- if(!tmp) {
|
||||
- tmp = "application/octet-stream";
|
||||
+ if(tmp) {
|
||||
+ mimeType_ = MimeType::fromName(tmp);
|
||||
}
|
||||
- mimeType_ = MimeType::fromName(tmp);
|
||||
|
||||
mode_ = g_file_info_get_attribute_uint32(inf.get(), G_FILE_ATTRIBUTE_UNIX_MODE);
|
||||
|
||||
@@ -196,6 +195,10 @@ _file_is_symlink:
|
||||
}
|
||||
}
|
||||
|
||||
+ if(!mimeType_) {
|
||||
+ mimeType_ = MimeType::fromName("application/octet-stream");
|
||||
+ }
|
||||
+
|
||||
/* if there is a custom folder icon, use it */
|
||||
if(isNative() && type == G_FILE_TYPE_DIRECTORY) {
|
||||
auto local_path = path().localPath();
|
||||
--- a/src/core/fileinfojob.cpp
|
||||
+++ b/src/core/fileinfojob.cpp
|
||||
@@ -13,31 +13,41 @@ FileInfoJob::FileInfoJob(FilePathList pa
|
||||
|
||||
void FileInfoJob::exec() {
|
||||
for(const auto& path: paths_) {
|
||||
- if(!isCancelled()) {
|
||||
+ if(isCancelled()) {
|
||||
+ break;
|
||||
+ }
|
||||
+ currentPath_ = path;
|
||||
+
|
||||
+ bool retry;
|
||||
+ do {
|
||||
+ retry = false;
|
||||
GErrorPtr err;
|
||||
GFileInfoPtr inf{
|
||||
g_file_query_info(path.gfile().get(), defaultGFileInfoQueryAttribs,
|
||||
G_FILE_QUERY_INFO_NONE, cancellable().get(), &err),
|
||||
false
|
||||
};
|
||||
- if(!inf) {
|
||||
- continue;
|
||||
- }
|
||||
-
|
||||
- // Reuse the same dirPath object when the path remains the same (optimize for files in the same dir)
|
||||
- auto dirPath = commonDirPath_.isValid() ? commonDirPath_ : path.parent();
|
||||
- FileInfo fileInfo(inf, dirPath);
|
||||
+ if(inf) {
|
||||
+ // Reuse the same dirPath object when the path remains the same (optimize for files in the same dir)
|
||||
+ auto dirPath = commonDirPath_.isValid() ? commonDirPath_ : path.parent();
|
||||
+ auto fileInfoPtr = std::make_shared<FileInfo>(inf, dirPath);
|
||||
+
|
||||
+ // FIXME: this is not elegant
|
||||
+ if(cutFilesHashSet_
|
||||
+ && cutFilesHashSet_->count(path.hash())) {
|
||||
+ fileInfoPtr->bindCutFiles(cutFilesHashSet_);
|
||||
+ }
|
||||
|
||||
- if(cutFilesHashSet_
|
||||
- && cutFilesHashSet_->count(fileInfo.path().hash())) {
|
||||
- fileInfo.bindCutFiles(cutFilesHashSet_);
|
||||
+ results_.push_back(fileInfoPtr);
|
||||
+ Q_EMIT gotInfo(path, results_.back());
|
||||
}
|
||||
-
|
||||
- auto fileInfoPtr = std::make_shared<const FileInfo>(fileInfo);
|
||||
-
|
||||
- results_.push_back(fileInfoPtr);
|
||||
- Q_EMIT gotInfo(path, fileInfoPtr);
|
||||
- }
|
||||
+ else {
|
||||
+ auto act = emitError(err);
|
||||
+ if(act == Job::ErrorAction::RETRY) {
|
||||
+ retry = true;
|
||||
+ }
|
||||
+ }
|
||||
+ } while(retry && !isCancelled());
|
||||
}
|
||||
}
|
||||
|
||||
--- a/src/core/fileinfojob.h
|
||||
+++ b/src/core/fileinfojob.h
|
||||
@@ -27,6 +27,10 @@ public:
|
||||
return results_;
|
||||
}
|
||||
|
||||
+ const FilePath& currentPath() const {
|
||||
+ return currentPath_;
|
||||
+ }
|
||||
+
|
||||
Q_SIGNALS:
|
||||
void gotInfo(const FilePath& path, std::shared_ptr<const FileInfo>& info);
|
||||
|
||||
@@ -39,6 +43,7 @@ private:
|
||||
FileInfoList results_;
|
||||
FilePath commonDirPath_;
|
||||
const std::shared_ptr<const HashSet> cutFilesHashSet_;
|
||||
+ FilePath currentPath_;
|
||||
};
|
||||
|
||||
} // namespace Fm
|
||||
--- a/src/core/gioptrs.h
|
||||
+++ b/src/core/gioptrs.h
|
||||
@@ -112,6 +112,10 @@ public:
|
||||
return err_;
|
||||
}
|
||||
|
||||
+ const GError* operator->() const {
|
||||
+ return err_;
|
||||
+ }
|
||||
+
|
||||
bool operator == (const GErrorPtr& other) const {
|
||||
return err_ == other.err_;
|
||||
}
|
||||
--- a/src/filelauncher.cpp
|
||||
+++ b/src/filelauncher.cpp
|
||||
@@ -76,7 +76,7 @@ bool FileLauncher::openFolder(GAppLaunch
|
||||
return BasicFileLauncher::openFolder(ctx, folderInfos, err);
|
||||
}
|
||||
|
||||
-bool FileLauncher::showError(GAppLaunchContext* /*ctx*/, GErrorPtr &err, const FilePath &path, const FileInfoPtr &info) {
|
||||
+bool FileLauncher::showError(GAppLaunchContext* /*ctx*/, const GErrorPtr &err, const FilePath &path, const FileInfoPtr &info) {
|
||||
/* ask for mount if trying to launch unmounted path */
|
||||
if(err->domain == G_IO_ERROR) {
|
||||
if(path && err->code == G_IO_ERROR_NOT_MOUNTED) {
|
||||
--- a/src/filelauncher.h
|
||||
+++ b/src/filelauncher.h
|
||||
@@ -43,7 +43,7 @@ protected:
|
||||
|
||||
bool openFolder(GAppLaunchContext* ctx, const FileInfoList& folderInfos, GErrorPtr& err) override;
|
||||
|
||||
- bool showError(GAppLaunchContext* ctx, GErrorPtr& err, const FilePath& path = FilePath{}, const FileInfoPtr& info = FileInfoPtr{}) override;
|
||||
+ bool showError(GAppLaunchContext* ctx, const GErrorPtr &err, const FilePath& path = FilePath{}, const FileInfoPtr& info = FileInfoPtr{}) override;
|
||||
|
||||
ExecAction askExecFile(const FileInfoPtr& file) override;
|
||||
|
@ -1,68 +0,0 @@
|
||||
Description: Correctly handle mountable types
|
||||
Author: "Hong Jen Yee (PCMan)" <pcman.tw@gmail.com>
|
||||
Origin: upstream
|
||||
Applied-Upstream: commit:dc7a575
|
||||
Last-Update: 2018-07-14
|
||||
--- a/src/core/basicfilelauncher.cpp
|
||||
+++ b/src/core/basicfilelauncher.cpp
|
||||
@@ -28,11 +28,10 @@ bool BasicFileLauncher::launchFiles(cons
|
||||
// classify files according to different mimetypes
|
||||
for(auto& fileInfo : fileInfos) {
|
||||
/*
|
||||
- qDebug("path: %s, type: %s, target: %s, isDir: %i, isDesktopEntry: %i",
|
||||
+ qDebug("path: %s, type: %s, target: %s, isDir: %i, isShortcut: %i, isMountable: %i, isDesktopEntry: %i",
|
||||
fileInfo->path().toString().get(), fileInfo->mimeType()->name(), fileInfo->target().c_str(),
|
||||
- fileInfo->isDir(), fileInfo->isDesktopEntry());
|
||||
+ fileInfo->isDir(), fileInfo->isShortcut(), fileInfo->isMountable(), fileInfo->isDesktopEntry());
|
||||
*/
|
||||
-
|
||||
if(fileInfo->isMountable()) {
|
||||
if(fileInfo->target().empty()) {
|
||||
// the mountable is not yet mounted so we have no target URI.
|
||||
@@ -267,6 +266,7 @@ FilePath BasicFileLauncher::handleShortc
|
||||
// if we know the target is a dir, we are not going to open it using other apps
|
||||
// for example: `network:///smb-root' is a shortcut targeting `smb:///' and it's also a dir
|
||||
if(fileInfo->isDir()) {
|
||||
+ qDebug("shortcut is dir: %s", target.c_str());
|
||||
return FilePath::fromPathStr(target.c_str());
|
||||
}
|
||||
|
||||
--- a/src/core/fileinfo.cpp
|
||||
+++ b/src/core/fileinfo.cpp
|
||||
@@ -118,7 +118,8 @@ void FileInfo::setFromGFileInfo(const GO
|
||||
isDeletable_ = true;
|
||||
}
|
||||
|
||||
- isShortcut_ = false;
|
||||
+ isShortcut_ = (type == G_FILE_TYPE_SHORTCUT);
|
||||
+ isMountable_ = (type == G_FILE_TYPE_MOUNTABLE);
|
||||
|
||||
/* special handling for symlinks */
|
||||
if(g_file_info_get_is_symlink(inf.get())) {
|
||||
@@ -129,7 +130,6 @@ void FileInfo::setFromGFileInfo(const GO
|
||||
|
||||
switch(type) {
|
||||
case G_FILE_TYPE_SHORTCUT:
|
||||
- isShortcut_ = true;
|
||||
/* Falls through. */
|
||||
case G_FILE_TYPE_MOUNTABLE:
|
||||
uri = g_file_info_get_attribute_string(inf.get(), G_FILE_ATTRIBUTE_STANDARD_TARGET_URI);
|
||||
--- a/src/core/fileinfo.h
|
||||
+++ b/src/core/fileinfo.h
|
||||
@@ -151,7 +151,7 @@ public:
|
||||
}
|
||||
|
||||
bool isMountable() const {
|
||||
- return mimeType_->isMountable();
|
||||
+ return isMountable_;
|
||||
}
|
||||
|
||||
bool isShortcut() const {
|
||||
@@ -239,6 +239,7 @@ private:
|
||||
std::string target_; /* target of shortcut or mountable. */
|
||||
|
||||
bool isShortcut_ : 1; /* TRUE if file is shortcut type */
|
||||
+ bool isMountable_ : 1; /* TRUE if file is mountable type */
|
||||
bool isAccessible_ : 1; /* TRUE if can be read by user */
|
||||
bool isWritable_ : 1; /* TRUE if can be written to by user */
|
||||
bool isDeletable_ : 1; /* TRUE if can be deleted by user */
|
@ -0,0 +1,16 @@
|
||||
Description: Fix metadata for trusting executables
|
||||
To conform with the Ubuntu standard use metadata::trusted instead of metadata::trust. This patch must be applied after any upstream version changes since they refuse to conform.
|
||||
Author: Dan Simmons <monetaryabyss@protonmail.com>
|
||||
Bug: https://bugs.launchpad.net/bugs/1813687
|
||||
Last-Update: 2019-01-29
|
||||
--- a/src/core/fileinfo.cpp
|
||||
+++ b/src/core/fileinfo.cpp
|
||||
@@ -2,7 +2,7 @@
|
||||
#include "fileinfo_p.h"
|
||||
#include <gio/gio.h>
|
||||
|
||||
-#define METADATA_TRUST "metadata::trust"
|
||||
+#define METADATA_TRUST "metadata::trusted"
|
||||
|
||||
namespace Fm {
|
||||
|
@ -1,52 +0,0 @@
|
||||
Description: Use window text color for places view
|
||||
Author: tsujan <tsujan2000@gmail.com>
|
||||
Origin: upstream
|
||||
Bug: https://github.com/lxqt/pcmanfm-qt/issues/696
|
||||
Applied-Upstream: commit:87df010
|
||||
Last-Update: 2018-07-14
|
||||
--- a/src/folderitemdelegate.cpp
|
||||
+++ b/src/folderitemdelegate.cpp
|
||||
@@ -361,7 +361,8 @@ QWidget* FolderItemDelegate::createEdito
|
||||
// ensure that its background isn't transparent (on the side-pane)
|
||||
QWidget* editor = QStyledItemDelegate::createEditor(parent, option, index);
|
||||
QPalette p = editor->palette();
|
||||
- p.setColor(QPalette::Base, QApplication::palette().color(QPalette::Base));
|
||||
+ p.setColor(QPalette::Text, qApp->palette().text().color());
|
||||
+ p.setColor(QPalette::Base, qApp->palette().color(QPalette::Base));
|
||||
editor->setPalette(p);
|
||||
return editor;
|
||||
}
|
||||
--- a/src/placesview.cpp
|
||||
+++ b/src/placesview.cpp
|
||||
@@ -131,13 +131,6 @@ PlacesView::PlacesView(QWidget* parent):
|
||||
setHeaderHidden(true);
|
||||
setIndentation(12);
|
||||
|
||||
- /* merge with the surroundings */
|
||||
- setFrameShape(QFrame::NoFrame);
|
||||
- QPalette p = palette();
|
||||
- p.setColor(QPalette::Base, QColor(Qt::transparent));
|
||||
- setPalette(p);
|
||||
- viewport()->setAutoFillBackground(false);
|
||||
-
|
||||
connect(this, &QTreeView::clicked, this, &PlacesView::onClicked);
|
||||
connect(this, &QTreeView::pressed, this, &PlacesView::onPressed);
|
||||
|
||||
--- a/src/sidepane.cpp
|
||||
+++ b/src/sidepane.cpp
|
||||
@@ -158,6 +158,15 @@ void SidePane::setMode(Mode mode) {
|
||||
switch(mode) {
|
||||
case ModePlaces: {
|
||||
PlacesView* placesView = new Fm::PlacesView(this);
|
||||
+
|
||||
+ // visually merge it with its surroundings
|
||||
+ placesView->setFrameShape(QFrame::NoFrame);
|
||||
+ QPalette p = placesView->palette();
|
||||
+ p.setColor(QPalette::Base, QColor(Qt::transparent));
|
||||
+ p.setColor(QPalette::Text, p.color(QPalette::WindowText));
|
||||
+ placesView->setPalette(p);
|
||||
+ placesView->viewport()->setAutoFillBackground(false);
|
||||
+
|
||||
view_ = placesView;
|
||||
placesView->restoreHiddenItems(restorableHiddenPlaces_);
|
||||
placesView->setIconSize(iconSize_);
|
@ -1,373 +0,0 @@
|
||||
Description: Move the Qt file dialog helper into libfm-qt.
|
||||
Author: Hong Jen Yee (PCMan) <pcman.tw@gmail.com>
|
||||
Origin: upstream
|
||||
Applied-Upstream: commit:cc63bc7
|
||||
Last-Update: 2018-07-30
|
||||
--- a/src/CMakeLists.txt
|
||||
+++ b/src/CMakeLists.txt
|
||||
@@ -83,6 +83,7 @@ set(libfm_SRCS
|
||||
filedialog.cpp
|
||||
fm-search.c # might be moved to libfm later
|
||||
xdndworkaround.cpp
|
||||
+ filedialoghelper.cpp
|
||||
)
|
||||
|
||||
set(libfm_UIS
|
||||
--- /dev/null
|
||||
+++ b/src/filedialoghelper.cpp
|
||||
@@ -0,0 +1,290 @@
|
||||
+#include "filedialoghelper.h"
|
||||
+
|
||||
+#include "libfmqt.h"
|
||||
+#include "filedialog.h"
|
||||
+
|
||||
+#include <QWindow>
|
||||
+#include <QDebug>
|
||||
+#include <QTimer>
|
||||
+#include <QSettings>
|
||||
+#include <QtGlobal>
|
||||
+
|
||||
+#include <memory>
|
||||
+
|
||||
+namespace Fm {
|
||||
+
|
||||
+inline static const QString viewModeToString(Fm::FolderView::ViewMode value);
|
||||
+inline static Fm::FolderView::ViewMode viewModeFromString(const QString& str);
|
||||
+
|
||||
+FileDialogHelper::FileDialogHelper() {
|
||||
+ // can only be used after libfm-qt initialization
|
||||
+ dlg_ = std::unique_ptr<Fm::FileDialog>(new Fm::FileDialog());
|
||||
+ connect(dlg_.get(), &Fm::FileDialog::accepted, [this]() {
|
||||
+ saveSettings();
|
||||
+ accept();
|
||||
+ });
|
||||
+ connect(dlg_.get(), &Fm::FileDialog::rejected, [this]() {
|
||||
+ saveSettings();
|
||||
+ reject();
|
||||
+ });
|
||||
+
|
||||
+ connect(dlg_.get(), &Fm::FileDialog::fileSelected, this, &FileDialogHelper::fileSelected);
|
||||
+ connect(dlg_.get(), &Fm::FileDialog::filesSelected, this, &FileDialogHelper::filesSelected);
|
||||
+ connect(dlg_.get(), &Fm::FileDialog::currentChanged, this, &FileDialogHelper::currentChanged);
|
||||
+ connect(dlg_.get(), &Fm::FileDialog::directoryEntered, this, &FileDialogHelper::directoryEntered);
|
||||
+ connect(dlg_.get(), &Fm::FileDialog::filterSelected, this, &FileDialogHelper::filterSelected);
|
||||
+}
|
||||
+
|
||||
+FileDialogHelper::~FileDialogHelper() {
|
||||
+}
|
||||
+
|
||||
+void FileDialogHelper::exec() {
|
||||
+ dlg_->exec();
|
||||
+}
|
||||
+
|
||||
+bool FileDialogHelper::show(Qt::WindowFlags windowFlags, Qt::WindowModality windowModality, QWindow* parent) {
|
||||
+ dlg_->setAttribute(Qt::WA_NativeWindow, true); // without this, sometimes windowHandle() will return nullptr
|
||||
+
|
||||
+ dlg_->setWindowFlags(windowFlags);
|
||||
+ dlg_->setWindowModality(windowModality);
|
||||
+
|
||||
+ // Reference: KDE implementation
|
||||
+ // https://github.com/KDE/plasma-integration/blob/master/src/platformtheme/kdeplatformfiledialoghelper.cpp
|
||||
+ dlg_->windowHandle()->setTransientParent(parent);
|
||||
+
|
||||
+ applyOptions();
|
||||
+
|
||||
+ loadSettings();
|
||||
+ // central positioning with respect to the parent window
|
||||
+ if(parent && parent->isVisible()) {
|
||||
+ dlg_->move(parent->x() + (parent->width() - dlg_->width()) / 2,
|
||||
+ parent->y() + (parent->height() - dlg_->height()) / 2);
|
||||
+ }
|
||||
+
|
||||
+ // NOTE: the timer here is required as a workaround borrowed from KDE. Without this, the dialog UI will be blocked.
|
||||
+ // QFileDialog calls our platform plugin to show our own native file dialog instead of showing its widget.
|
||||
+ // However, it still creates a hidden dialog internally, and then make it modal.
|
||||
+ // So user input from all other windows that are not the children of the QFileDialog widget will be blocked.
|
||||
+ // This includes our own dialog. After the return of this show() method, QFileDialog creates its own window and
|
||||
+ // then make it modal, which blocks our UI. The timer schedule a delayed popup of our file dialog, so we can
|
||||
+ // show again after QFileDialog and override the modal state. Then our UI can be unblocked.
|
||||
+ QTimer::singleShot(0, dlg_.get(), &QDialog::show);
|
||||
+ dlg_->setFocus();
|
||||
+ return true;
|
||||
+}
|
||||
+
|
||||
+void FileDialogHelper::hide() {
|
||||
+ dlg_->hide();
|
||||
+}
|
||||
+
|
||||
+bool FileDialogHelper::defaultNameFilterDisables() const {
|
||||
+ return false;
|
||||
+}
|
||||
+
|
||||
+void FileDialogHelper::setDirectory(const QUrl& directory) {
|
||||
+ dlg_->setDirectory(directory);
|
||||
+}
|
||||
+
|
||||
+QUrl FileDialogHelper::directory() const {
|
||||
+ return dlg_->directory();
|
||||
+}
|
||||
+
|
||||
+void FileDialogHelper::selectFile(const QUrl& filename) {
|
||||
+ dlg_->selectFile(filename);
|
||||
+}
|
||||
+
|
||||
+QList<QUrl> FileDialogHelper::selectedFiles() const {
|
||||
+ return dlg_->selectedFiles();
|
||||
+}
|
||||
+
|
||||
+void FileDialogHelper::setFilter() {
|
||||
+ // FIXME: what's this?
|
||||
+ // The gtk+ 3 file dialog helper in Qt5 update options in this method.
|
||||
+ applyOptions();
|
||||
+}
|
||||
+
|
||||
+void FileDialogHelper::selectNameFilter(const QString& filter) {
|
||||
+ dlg_->selectNameFilter(filter);
|
||||
+}
|
||||
+
|
||||
+#if QT_VERSION >= QT_VERSION_CHECK(5, 9, 0)
|
||||
+QString FileDialogHelper::selectedMimeTypeFilter() const {
|
||||
+ return dlg_->selectedMimeTypeFilter();
|
||||
+}
|
||||
+
|
||||
+void FileDialogHelper::selectMimeTypeFilter(const QString& filter) {
|
||||
+ dlg_->selectMimeTypeFilter(filter);
|
||||
+}
|
||||
+#endif
|
||||
+
|
||||
+QString FileDialogHelper::selectedNameFilter() const {
|
||||
+ return dlg_->selectedNameFilter();
|
||||
+}
|
||||
+
|
||||
+bool FileDialogHelper::isSupportedUrl(const QUrl& url) const {
|
||||
+ return dlg_->isSupportedUrl(url);
|
||||
+}
|
||||
+
|
||||
+void FileDialogHelper::applyOptions() {
|
||||
+ auto& opt = options();
|
||||
+
|
||||
+ // set title
|
||||
+ if(opt->windowTitle().isEmpty()) {
|
||||
+ dlg_->setWindowTitle(opt->acceptMode() == QFileDialogOptions::AcceptOpen ? tr("Open File")
|
||||
+ : tr("Save File"));
|
||||
+ }
|
||||
+ else {
|
||||
+ dlg_->setWindowTitle(opt->windowTitle());
|
||||
+ }
|
||||
+
|
||||
+ dlg_->setFilter(opt->filter());
|
||||
+ dlg_->setFileMode(QFileDialog::FileMode(opt->fileMode()));
|
||||
+ dlg_->setAcceptMode(QFileDialog::AcceptMode(opt->acceptMode())); // also sets a default label for accept button
|
||||
+ // bool useDefaultNameFilters() const;
|
||||
+ dlg_->setNameFilters(opt->nameFilters());
|
||||
+ if(!opt->mimeTypeFilters().empty()) {
|
||||
+ dlg_->setMimeTypeFilters(opt->mimeTypeFilters());
|
||||
+ }
|
||||
+
|
||||
+ dlg_->setDefaultSuffix(opt->defaultSuffix());
|
||||
+ // QStringList history() const;
|
||||
+
|
||||
+ // explicitly set labels
|
||||
+ for(int i = 0; i < QFileDialogOptions::DialogLabelCount; ++i) {
|
||||
+ auto label = static_cast<QFileDialogOptions::DialogLabel>(i);
|
||||
+ if(opt->isLabelExplicitlySet(label)) {
|
||||
+ dlg_->setLabelText(static_cast<QFileDialog::DialogLabel>(label), opt->labelText(label));
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ auto url = opt->initialDirectory();
|
||||
+ if(url.isValid()) {
|
||||
+ dlg_->setDirectory(url);
|
||||
+ }
|
||||
+
|
||||
+
|
||||
+#if QT_VERSION >= QT_VERSION_CHECK(5, 9, 0)
|
||||
+ auto filter = opt->initiallySelectedMimeTypeFilter();
|
||||
+ if(!filter.isEmpty()) {
|
||||
+ selectMimeTypeFilter(filter);
|
||||
+ }
|
||||
+ else {
|
||||
+ filter = opt->initiallySelectedNameFilter();
|
||||
+ if(!filter.isEmpty()) {
|
||||
+ selectNameFilter(opt->initiallySelectedNameFilter());
|
||||
+ }
|
||||
+ }
|
||||
+#else
|
||||
+ auto filter = opt->initiallySelectedNameFilter();
|
||||
+ if(!filter.isEmpty()) {
|
||||
+ selectNameFilter(filter);
|
||||
+ }
|
||||
+#endif
|
||||
+
|
||||
+ auto selectedFiles = opt->initiallySelectedFiles();
|
||||
+ for(const auto& selectedFile: selectedFiles) {
|
||||
+ selectFile(selectedFile);
|
||||
+ }
|
||||
+ // QStringList supportedSchemes() const;
|
||||
+}
|
||||
+
|
||||
+static const QString viewModeToString(Fm::FolderView::ViewMode value) {
|
||||
+ QString ret;
|
||||
+ switch(value) {
|
||||
+ case Fm::FolderView::DetailedListMode:
|
||||
+ default:
|
||||
+ ret = QLatin1String("Detailed");
|
||||
+ break;
|
||||
+ case Fm::FolderView::CompactMode:
|
||||
+ ret = QLatin1String("Compact");
|
||||
+ break;
|
||||
+ case Fm::FolderView::IconMode:
|
||||
+ ret = QLatin1String("Icon");
|
||||
+ break;
|
||||
+ case Fm::FolderView::ThumbnailMode:
|
||||
+ ret = QLatin1String("Thumbnail");
|
||||
+ break;
|
||||
+ }
|
||||
+ return ret;
|
||||
+}
|
||||
+
|
||||
+Fm::FolderView::ViewMode viewModeFromString(const QString& str) {
|
||||
+ Fm::FolderView::ViewMode ret;
|
||||
+ if(str == QLatin1String("Detailed")) {
|
||||
+ ret = Fm::FolderView::DetailedListMode;
|
||||
+ }
|
||||
+ else if(str == QLatin1String("Compact")) {
|
||||
+ ret = Fm::FolderView::CompactMode;
|
||||
+ }
|
||||
+ else if(str == QLatin1String("Icon")) {
|
||||
+ ret = Fm::FolderView::IconMode;
|
||||
+ }
|
||||
+ else if(str == QLatin1String("Thumbnail")) {
|
||||
+ ret = Fm::FolderView::ThumbnailMode;
|
||||
+ }
|
||||
+ else {
|
||||
+ ret = Fm::FolderView::DetailedListMode;
|
||||
+ }
|
||||
+ return ret;
|
||||
+}
|
||||
+
|
||||
+void FileDialogHelper::loadSettings() {
|
||||
+ QSettings settings(QSettings::UserScope, "lxqt", "filedialog");
|
||||
+ settings.beginGroup ("Sizes");
|
||||
+ dlg_->resize(settings.value("WindowSize", QSize(700, 500)).toSize());
|
||||
+ dlg_->setSplitterPos(settings.value("SplitterPos", 200).toInt());
|
||||
+ settings.endGroup();
|
||||
+
|
||||
+ settings.beginGroup ("View");
|
||||
+ dlg_->setViewMode(viewModeFromString(settings.value("Mode", "Detailed").toString()));
|
||||
+ settings.endGroup();
|
||||
+}
|
||||
+
|
||||
+void FileDialogHelper::saveSettings() {
|
||||
+ QSettings settings(QSettings::UserScope, "lxqt", "filedialog");
|
||||
+ settings.beginGroup ("Sizes");
|
||||
+ QSize windowSize = dlg_->size();
|
||||
+ if(settings.value("WindowSize") != windowSize) { // no redundant write
|
||||
+ settings.setValue("WindowSize", windowSize);
|
||||
+ }
|
||||
+ int splitterPos = dlg_->splitterPos();
|
||||
+ if(settings.value("SplitterPos") != splitterPos) {
|
||||
+ settings.setValue("SplitterPos", splitterPos);
|
||||
+ }
|
||||
+ settings.endGroup();
|
||||
+
|
||||
+ settings.beginGroup ("View");
|
||||
+ QString mode = viewModeToString(dlg_->viewMode());
|
||||
+ if(settings.value("Mode") != mode) {
|
||||
+ settings.setValue("Mode", mode);
|
||||
+ }
|
||||
+ settings.endGroup();
|
||||
+}
|
||||
+
|
||||
+/*
|
||||
+FileDialogPlugin::FileDialogPlugin() {
|
||||
+
|
||||
+}
|
||||
+
|
||||
+QPlatformFileDialogHelper *FileDialogPlugin::createHelper() {
|
||||
+ return new FileDialogHelper();
|
||||
+}
|
||||
+*/
|
||||
+
|
||||
+} // namespace Fm
|
||||
+
|
||||
+
|
||||
+QPlatformFileDialogHelper *createFileDialogHelper() {
|
||||
+ // When a process has this environment set, that means glib event loop integration is disabled.
|
||||
+ // In this case, libfm just won't work. So let's disable the file dialog helper and return nullptr.
|
||||
+ if(qgetenv("QT_NO_GLIB") == "1") {
|
||||
+ return nullptr;
|
||||
+ }
|
||||
+
|
||||
+ static std::unique_ptr<Fm::LibFmQt> libfmQtContext_;
|
||||
+ if(!libfmQtContext_) {
|
||||
+ // initialize libfm-qt only once
|
||||
+ libfmQtContext_ = std::unique_ptr<Fm::LibFmQt>{new Fm::LibFmQt()};
|
||||
+ }
|
||||
+ return new Fm::FileDialogHelper{};
|
||||
+}
|
||||
--- /dev/null
|
||||
+++ b/src/filedialoghelper.h
|
||||
@@ -0,0 +1,62 @@
|
||||
+#ifndef FILEDIALOGHELPER_H
|
||||
+#define FILEDIALOGHELPER_H
|
||||
+
|
||||
+#include "libfmqtglobals.h"
|
||||
+#include <qpa/qplatformdialoghelper.h> // this private header is subject to changes
|
||||
+#include <memory>
|
||||
+
|
||||
+namespace Fm {
|
||||
+
|
||||
+class FileDialog;
|
||||
+
|
||||
+class LIBFM_QT_API FileDialogHelper : public QPlatformFileDialogHelper {
|
||||
+ Q_OBJECT
|
||||
+
|
||||
+public:
|
||||
+ FileDialogHelper();
|
||||
+
|
||||
+ virtual ~FileDialogHelper();
|
||||
+
|
||||
+ // QPlatformDialogHelper
|
||||
+ void exec() override;
|
||||
+ bool show(Qt::WindowFlags windowFlags, Qt::WindowModality windowModality, QWindow *parent) override;
|
||||
+ void hide() override;
|
||||
+
|
||||
+ // QPlatformFileDialogHelper
|
||||
+ bool defaultNameFilterDisables() const override;
|
||||
+ void setDirectory(const QUrl &directory) override;
|
||||
+ QUrl directory() const override;
|
||||
+ void selectFile(const QUrl &filename) override;
|
||||
+ QList<QUrl> selectedFiles() const override;
|
||||
+ void setFilter() override;
|
||||
+ void selectNameFilter(const QString &filter) override;
|
||||
+#if QT_VERSION >= QT_VERSION_CHECK(5, 9, 0)
|
||||
+ QString selectedMimeTypeFilter() const override;
|
||||
+ void selectMimeTypeFilter(const QString &filter) override;
|
||||
+#endif
|
||||
+ QString selectedNameFilter() const override;
|
||||
+
|
||||
+ bool isSupportedUrl(const QUrl &url) const override;
|
||||
+
|
||||
+private:
|
||||
+ void applyOptions();
|
||||
+ void loadSettings();
|
||||
+ void saveSettings();
|
||||
+
|
||||
+private:
|
||||
+ std::unique_ptr<Fm::FileDialog> dlg_;
|
||||
+};
|
||||
+
|
||||
+} // namespace Fm
|
||||
+
|
||||
+// export a C API without C++ name mangling so others can dynamically load libfm-qt at runtime
|
||||
+// to call this API and get a new QPlatformFileDialogHelper object.
|
||||
+
|
||||
+extern "C" {
|
||||
+
|
||||
+// if the process calling this API fail to load libfm-qt, nullptr will be returned instead.
|
||||
+LIBFM_QT_API QPlatformFileDialogHelper* createFileDialogHelper();
|
||||
+
|
||||
+}
|
||||
+
|
||||
+#endif // FILEDIALOGHELPER_H
|
@ -1,6 +1 @@
|
||||
add-lxqt-archiver-integration.patch
|
||||
fix-incorrect-file-info-handling-1.patch
|
||||
fix-incorrect-file-info-handling-2.patch
|
||||
fix-places-font-color.patch
|
||||
move-in-file-dialog.patch
|
||||
add-metadata-for-trusting-executables.patch
|
||||
fix-metadata-for-trusting-executables.patch
|
||||
|
@ -0,0 +1,12 @@
|
||||
# For more information on what jobs are run see:
|
||||
# https://salsa.debian.org/salsa-ci-team/pipeline
|
||||
#
|
||||
# To enable the jobs, go to your repository (at salsa.debian.org)
|
||||
# and click over Settings > CI/CD > Expand (in General pipelines).
|
||||
# In "Custom CI config path" write debian/salsa-ci.yml and click
|
||||
# in "Save Changes". The CI tests will run after the next commit.
|
||||
---
|
||||
include:
|
||||
- https://salsa.debian.org/salsa-ci-team/pipeline/raw/master/salsa-ci.yml
|
||||
- https://salsa.debian.org/salsa-ci-team/pipeline/raw/master/pipeline-jobs.yml
|
||||
|
@ -0,0 +1,5 @@
|
||||
# This list will always be very long, it's okay
|
||||
libfm-qt source: very-long-line-length-in-source-file * > 512 [data/archivers.list:*]
|
||||
|
||||
# Long lines in the upstream changelog are okay
|
||||
libfm-qt source: very-long-line-length-in-source-file * > 512 [CHANGELOG:*]
|
@ -0,0 +1,5 @@
|
||||
Name: libfm-qt
|
||||
Bug-Database: https://github.com/lxqt/libfm-qt/issues
|
||||
Bug-Submit: https://github.com/lxqt/libfm-qt/issues/new
|
||||
Changelog: https://github.com/lxqt/libfm-qt/blob/master/CHANGELOG
|
||||
Repository: https://github.com/lxqt/libfm-qt
|
@ -1,50 +1,52 @@
|
||||
-----BEGIN PGP PUBLIC KEY BLOCK-----
|
||||
|
||||
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
|
||||
=h7ww
|
||||
-----BEGIN PGP PUBLIC KEY BLOCK-----
|
||||
|
||||
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
|
||||
sw==
|
||||
=gSIv
|
||||
-----END PGP PUBLIC KEY BLOCK-----
|
||||
|
@ -1,3 +1,5 @@
|
||||
version=4
|
||||
opts="pgpsigurlmangle=s/$/.asc/" \
|
||||
https://github.com/lxqt/libfm-qt/releases .*/libfm-qt-([\d\.]+).tar.xz
|
||||
opts="searchmode=plain, \
|
||||
pgpsigurlmangle=s/$/.asc/, \
|
||||
uversionmangle=s/(\d+\.\d+\.\d+).*/$1/" \
|
||||
https://api.github.com/repos/lxqt/@PACKAGE@/releases https:\/\/github.com\/lxqt\/@PACKAGE@\/releases\/download\/@ANY_VERSION@\/@PACKAGE@-@ANY_VERSION@.tar.xz
|
||||
|
Loading…
Reference in new issue