From 88fbf7e81a6ab317262bd97875a0296f59287586 Mon Sep 17 00:00:00 2001 From: Michele Calgaro Date: Thu, 26 Mar 2020 15:10:12 +0900 Subject: 1) Additional work on tq app -> tde app translation. 2) Make sure to exit app after restore if no app window can be grabbed 3) Save state only for known applications (app with empty name will not be saved and restored) Signed-off-by: Michele Calgaro --- src/customtraylabel.cpp | 24 ++++++++++++++++++------ 1 file changed, 18 insertions(+), 6 deletions(-) (limited to 'src/customtraylabel.cpp') diff --git a/src/customtraylabel.cpp b/src/customtraylabel.cpp index 87e50ac..5ad3459 100644 --- a/src/customtraylabel.cpp +++ b/src/customtraylabel.cpp @@ -44,11 +44,10 @@ CustomTrayLabel::CustomTrayLabel(Window w, TQWidget* p, const TQString& t) : TQTrayLabel(w, p, t), mUndockWhenDead(false) { - installMenu(); + installMenu(); } -CustomTrayLabel::CustomTrayLabel(const TQStringList& argv, pid_t pid, - TQWidget* parent) +CustomTrayLabel::CustomTrayLabel(const TQStringList& argv, pid_t pid, TQWidget* parent) : TQTrayLabel(argv, pid, parent), mUndockWhenDead(false) { installMenu(); @@ -124,6 +123,11 @@ void CustomTrayLabel::installMenu() setAcceptDrops(true); // and you thought this function only installs the menu } +void CustomTrayLabel::enableSessionManagement(bool sm) +{ + mSessionManagement->setOn(!appName().isEmpty() && sm); +} + // Session Management bool CustomTrayLabel::restoreState(TDEConfig *config) { @@ -132,13 +136,20 @@ bool CustomTrayLabel::restoreState(TDEConfig *config) return TQTrayLabel::restoreState(config); } -void CustomTrayLabel::saveState(TDEConfig *config) +bool CustomTrayLabel::saveState(TDEConfig *config) { - if (!mSessionManagement->isOn()) return; + if (!mSessionManagement->isOn()) + { + return false; + } - TQTrayLabel::saveState(config); + if (!TQTrayLabel::saveState(config)) + { + return false; + } config->writeEntry("DockWhenObscured", isDockWhenObscured()); TRACE("WM=%i DWO=%i", isDockWhenMinimized(), isDockWhenObscured()); + return true; } static bool which(const char *app) @@ -177,6 +188,7 @@ void CustomTrayLabel::setSkipTaskbar(bool skip) void CustomTrayLabel::setAppName(const TQString& name) { + //FIXME HACK relies on window and application name being the same. TQTrayLabel::setAppName(name.lower()); } -- cgit v1.2.1