diff options
Diffstat (limited to 'src/util.cpp')
-rw-r--r-- | src/util.cpp | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/src/util.cpp b/src/util.cpp index 7474fa1..4975663 100644 --- a/src/util.cpp +++ b/src/util.cpp @@ -19,12 +19,66 @@ Improvements and feedback are welcome! *******************************************************************************/ +// TQt +#include <tqfileinfo.h> + // TDE +#include <kservice.h> #include <kdebug.h> // Portal #include "util.h" +WId parse_window_id(const TQString data) +{ + if (!data.startsWith("x11:")) + { + kdWarning() << "[FileChooser] Window Identifiers are currently only " + << "supported for X11. Created dialog will be parentless." + << endl; + return 0; + } + + bool ok; + WId wid = data.mid(4).toInt(&ok, 16); + return ok ? wid : 0; +} + +ApplicationInfo application_info_from_wid(WId wid) +{ + ApplicationInfo app; + if (wid) + { + // we need to get the pid but only deprecated KWin::Info has it + KWin::Info info = KWin::info(wid); + TQFileInfo fi(TQString("/proc/%1/exe").arg(info.pid)); + if (fi.exists() && fi.isSymLink()) { + fi = TQFileInfo(fi.readLink()); + + app.path = fi.filePath(); + + // try to find corresponding desktop file + KService::List all = KService::allServices(); + KService::List::ConstIterator svc; + for (svc = all.begin(); svc != all.end(); ++svc) { + TQString exec((*svc)->exec()); + if (exec.startsWith(fi.filePath()) || + exec.startsWith(fi.fileName())) + { + app.desktopFile = (*svc)->desktopEntryPath(); + app.name = (*svc)->name(); + break; + } + } + + // Last resort + if (app.name.isEmpty()) + app.name = fi.fileName(); + } + } + return app; +} + bool check_variant(TQT_DBusVariant variant, TQString signature) { return !variant.signature.isNull() && variant.signature == signature; |