Репозиторий ALT Linux backports/2.4
Последнее обновление: 9 июля 2008 | Пакетов: 497 | Посещений: 1574063
 поиск   регистрация   авторизация 
 
Группа :: Графические оболочки/Icewm
Пакет: icewm

 Главная   Изменения   Спек   Патчи   Загрузить   Bugs and FR 

Патч: icewm-1.2.23-logouticon.patch


diff -u icewm-1.2.23/src-orig/objmenu.h icewm-1.2.23/src/objmenu.h
--- icewm-1.2.23/src-orig/objmenu.h	2005-10-07 12:17:07.000000000 +0200
+++ icewm-1.2.23/src/objmenu.h	2005-10-07 12:23:09.000000000 +0200
@@ -25,6 +25,7 @@
     virtual ~ObjectMenu();
 
     virtual void addObject(DObject *object);
+    virtual void addObject(DObject *object, const char *icons);
     virtual void addSeparator();
     virtual void addContainer(char *name, YIcon *icon, ObjectContainer *container);
 };
diff -u icewm-1.2.23/src-orig/wmapp.cc icewm-1.2.23/src/wmapp.cc
--- icewm-1.2.23/src-orig/wmapp.cc	2005-10-07 12:17:07.000000000 +0200
+++ icewm-1.2.23/src/wmapp.cc	2005-10-07 12:25:54.000000000 +0200
@@ -682,11 +682,11 @@
             YStringArray noargs;
 
             if (canLock())
-                logoutMenu->addItem(_("Lock _Workstation"), -2, "", actionLock);
+                logoutMenu->addItem(_("Lock _Workstation"), -2, "", actionLock, "lock");
             if (canShutdown(true))
-                logoutMenu->addItem(_("Re_boot"), -2, "", actionReboot);
+                logoutMenu->addItem(_("Re_boot"), -2, "", actionReboot, "reboot");
             if (canShutdown(false))
-                logoutMenu->addItem(_("Shut_down"), -2, "", actionShutdown);
+                logoutMenu->addItem(_("Shut_down"), -2, "", actionShutdown, "shutdown");
             logoutMenu->addSeparator();
 
             DProgram *restartIcewm =
diff -u icewm-1.2.23/src-orig/wmprog.cc icewm-1.2.23/src/wmprog.cc
--- icewm-1.2.23/src-orig/wmprog.cc	2005-10-07 12:17:07.000000000 +0200
+++ icewm-1.2.23/src/wmprog.cc	2005-10-07 12:23:09.000000000 +0200
@@ -76,6 +76,9 @@
 void ObjectMenu::addObject(DObject *fObject) {
     add(new DObjectMenuItem(fObject));
 }
+void ObjectMenu::addObject(DObject *fObject, const char *icons) {
+    add(new DObjectMenuItem(fObject), icons);
+}
 
 void ObjectMenu::addSeparator() {
     YMenu::addSeparator();
@@ -733,7 +736,7 @@
     if (showPrograms) {
         ObjectMenu *programs = new MenuFileMenu("programs", 0);
         ///    if (programs->itemCount() > 0)
-        addSubmenu(_("Programs"), 0, programs);
+        addSubmenu(_("Programs"), 0, programs, "programs");
     }
 #endif
 
@@ -772,7 +775,7 @@
 
     if (showRun) {
         if (runDlgCommand && runDlgCommand[0])
-            addItem(_("_Run..."), -2, "", actionRun);
+            addItem(_("_Run..."), -2, "", actionRun, "run");
     }
 
     addSeparator();
@@ -795,21 +798,21 @@
             DProgram::newProgram(_("_Help"), NULL, false, "browser.IceHelp",
                                  ICEHELPEXE, args);
 
-        if (help) addObject(help);
+        if (help) addObject(help, "help");
     }
 #endif
 
     if (showThemesMenu) {
         YMenu *themes = new ThemesMenu();
         if (themes)
-            addSubmenu(_("_Themes"), -2, themes);
+            addSubmenu(_("_Themes"), -2, themes, "themes");
     }
 
     if (logoutMenu) {
         if (showLogoutSubMenu)
-            addItem(_("_Logout..."), -2, actionLogout, logoutMenu);
+            addItem(_("_Logout..."), -2, actionLogout, logoutMenu, "logout");
         else
-            addItem(_("_Logout..."), -2, "", actionLogout);
+            addItem(_("_Logout..."), -2, "", actionLogout, "logout");
     }
 }
 #endif
diff -u icewm-1.2.23/src-orig/ymenu.cc icewm-1.2.23/src/ymenu.cc
--- icewm-1.2.23/src-orig/ymenu.cc	2005-10-07 12:17:07.000000000 +0200
+++ icewm-1.2.23/src/ymenu.cc	2005-10-07 12:23:09.000000000 +0200
@@ -19,6 +19,8 @@
 #include "ascii.h"
 #include "ypixbuf.h"
 
+#include "yicon.h"
+
 #include <string.h>
 
 YColor *menuBg = 0;
@@ -608,6 +610,18 @@
     beginAutoScroll(deltaX || deltaY, motion);
 }
 
+YMenuItem *YMenu::addItem(const char *name, int hotCharPos, const char *param, YAction *action, const char *icons) {
+    return add(new YMenuItem(name, hotCharPos, param, action, 0), icons);
+}
+
+YMenuItem *YMenu::addItem(const char *name, int hotCharPos, YAction *action, YMenu *submenu, const char *icons) {
+    return add(new YMenuItem(name, hotCharPos, 0, action, submenu), icons);
+}
+
+YMenuItem *YMenu::addSubmenu(const char *name, int hotCharPos, YMenu *submenu, const char *icons) {
+    return add(new YMenuItem(name, hotCharPos, 0, 0, submenu), icons);
+}
+
 YMenuItem *YMenu::addItem(const char *name, int hotCharPos, const char *param, YAction *action) {
     return add(new YMenuItem(name, hotCharPos, param, action, 0));
 }
@@ -638,6 +652,13 @@
     if (item) fItems.append(item);
     return item;
 }
+YMenuItem * YMenu::add(YMenuItem *item, const char *icons) {
+    YIcon *icon = 0;
+    icon = YIcon::getIcon(icons);
+    if (icon && item) item->setIcon(icon);
+    if (item) fItems.append(item);
+    return item;
+}
 
 YMenuItem * YMenu::addSorted(YMenuItem *item, bool duplicates) {
     for (int i = 0; i < itemCount(); i++) {
diff -u icewm-1.2.23/src-orig/ymenu.h icewm-1.2.23/src/ymenu.h
--- icewm-1.2.23/src-orig/ymenu.h	2005-10-07 12:17:07.000000000 +0200
+++ icewm-1.2.23/src/ymenu.h	2005-10-07 12:23:09.000000000 +0200
@@ -29,6 +29,11 @@
 
     void trackMotion(const int x_root, const int y_root, const unsigned state, bool submenu);
 
+    YMenuItem *add(YMenuItem *item, const char *icons);
+    YMenuItem *addItem(const char *name, int hotCharPos, const char *param, YAction *action, const char *icons);
+    YMenuItem *addItem(const char *name, int hotCharPos, YAction *action, YMenu *submenu, const char *icons);
+    YMenuItem *addSubmenu(const char *name, int hotCharPos, YMenu *submenu, const char *icons);
+    
     YMenuItem *add(YMenuItem *item);
     YMenuItem *addSorted(YMenuItem *item, bool duplicates);
     YMenuItem *addItem(const char *name, int hotCharPos, const char *param, YAction *action);
 
design & coding: Vladimir Lettiev aka crux © 2004-2005