diff options
Diffstat (limited to 'src/Slit.cc')
-rw-r--r-- | src/Slit.cc | 123 |
1 files changed, 49 insertions, 74 deletions
diff --git a/src/Slit.cc b/src/Slit.cc index 2dd9a78..a219fd8 100644 --- a/src/Slit.cc +++ b/src/Slit.cc | |||
@@ -22,7 +22,7 @@ | |||
22 | // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER | 22 | // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER |
23 | // DEALINGS IN THE SOFTWARE. | 23 | // DEALINGS IN THE SOFTWARE. |
24 | 24 | ||
25 | // $Id: Slit.cc,v 1.62 2003/06/20 01:27:28 fluxgen Exp $ | 25 | // $Id: Slit.cc,v 1.63 2003/06/22 12:31:37 fluxgen Exp $ |
26 | 26 | ||
27 | #include "Slit.hh" | 27 | #include "Slit.hh" |
28 | 28 | ||
@@ -54,6 +54,7 @@ | |||
54 | #include "Xinerama.hh" | 54 | #include "Xinerama.hh" |
55 | #include "SlitTheme.hh" | 55 | #include "SlitTheme.hh" |
56 | #include "SlitClient.hh" | 56 | #include "SlitClient.hh" |
57 | #include "Xutil.hh" | ||
57 | 58 | ||
58 | #include <algorithm> | 59 | #include <algorithm> |
59 | #include <iostream> | 60 | #include <iostream> |
@@ -69,53 +70,6 @@ | |||
69 | #include <iostream> | 70 | #include <iostream> |
70 | #include <algorithm> | 71 | #include <algorithm> |
71 | using namespace std; | 72 | using namespace std; |
72 | namespace { | ||
73 | |||
74 | void getWMName(BScreen *screen, Window window, std::string& name) { | ||
75 | name = ""; | ||
76 | |||
77 | if (screen == 0 || window == None) | ||
78 | return; | ||
79 | |||
80 | Display *display = FbTk::App::instance()->display(); | ||
81 | |||
82 | XTextProperty text_prop; | ||
83 | char **list; | ||
84 | int num; | ||
85 | I18n *i18n = I18n::instance(); | ||
86 | |||
87 | if (XGetWMName(display, window, &text_prop)) { | ||
88 | if (text_prop.value && text_prop.nitems > 0) { | ||
89 | if (text_prop.encoding != XA_STRING) { | ||
90 | |||
91 | text_prop.nitems = strlen((char *) text_prop.value); | ||
92 | |||
93 | if ((XmbTextPropertyToTextList(display, &text_prop, | ||
94 | &list, &num) == Success) && | ||
95 | (num > 0) && *list) { | ||
96 | name = static_cast<char *>(*list); | ||
97 | XFreeStringList(list); | ||
98 | } else | ||
99 | name = (char *)text_prop.value; | ||
100 | |||
101 | } else | ||
102 | name = (char *)text_prop.value; | ||
103 | } else { // default name | ||
104 | name = i18n->getMessage( | ||
105 | FBNLS::WindowSet, FBNLS::WindowUnnamed, | ||
106 | "Unnamed"); | ||
107 | } | ||
108 | } else { | ||
109 | // default name | ||
110 | name = i18n->getMessage( | ||
111 | FBNLS::WindowSet, FBNLS::WindowUnnamed, | ||
112 | "Unnamed"); | ||
113 | } | ||
114 | |||
115 | } | ||
116 | |||
117 | }; | ||
118 | |||
119 | 73 | ||
120 | namespace { | 74 | namespace { |
121 | 75 | ||
@@ -148,6 +102,7 @@ public: | |||
148 | m_label(label ? label : "") { | 102 | m_label(label ? label : "") { |
149 | setLabel(m_label.c_str()); // update label | 103 | setLabel(m_label.c_str()); // update label |
150 | } | 104 | } |
105 | |||
151 | void click(int button, int time) { | 106 | void click(int button, int time) { |
152 | // toggle direction | 107 | // toggle direction |
153 | if (m_slit.direction() == Slit::HORIZONTAL) | 108 | if (m_slit.direction() == Slit::HORIZONTAL) |
@@ -163,11 +118,9 @@ public: | |||
163 | m_label = (label ? label : ""); | 118 | m_label = (label ? label : ""); |
164 | std::string reallabel = m_label + " " + | 119 | std::string reallabel = m_label + " " + |
165 | ( m_slit.direction() == Slit::HORIZONTAL ? | 120 | ( m_slit.direction() == Slit::HORIZONTAL ? |
166 | i18n->getMessage( | 121 | i18n->getMessage(FBNLS::CommonSet, FBNLS::CommonDirectionHoriz, |
167 | FBNLS::CommonSet, FBNLS::CommonDirectionHoriz, | ||
168 | "Horizontal") : | 122 | "Horizontal") : |
169 | i18n->getMessage( | 123 | i18n->getMessage(FBNLS::CommonSet, FBNLS::CommonDirectionVert, |
170 | FBNLS::CommonSet, FBNLS::CommonDirectionVert, | ||
171 | "Vertical") ); | 124 | "Vertical") ); |
172 | FbTk::MenuItem::setLabel(reallabel.c_str()); | 125 | FbTk::MenuItem::setLabel(reallabel.c_str()); |
173 | } | 126 | } |
@@ -198,7 +151,8 @@ unsigned int Slit::s_eventmask = SubstructureRedirectMask | ButtonPressMask | | |||
198 | EnterWindowMask | LeaveWindowMask | ExposureMask; | 151 | EnterWindowMask | LeaveWindowMask | ExposureMask; |
199 | 152 | ||
200 | Slit::Slit(BScreen &scr, FbTk::XLayer &layer, const char *filename) | 153 | Slit::Slit(BScreen &scr, FbTk::XLayer &layer, const char *filename) |
201 | : m_screen(scr), m_timer(this), | 154 | : m_hidden(false), |
155 | m_screen(scr), m_timer(this), | ||
202 | m_slitmenu(*scr.menuTheme(), | 156 | m_slitmenu(*scr.menuTheme(), |
203 | scr.screenNumber(), | 157 | scr.screenNumber(), |
204 | scr.imageControl(), | 158 | scr.imageControl(), |
@@ -226,11 +180,14 @@ Slit::Slit(BScreen &scr, FbTk::XLayer &layer, const char *filename) | |||
226 | m_layeritem(0), | 180 | m_layeritem(0), |
227 | m_slit_theme(new SlitTheme(*this)), | 181 | m_slit_theme(new SlitTheme(*this)), |
228 | m_strut(0), | 182 | m_strut(0), |
183 | |||
184 | // resources | ||
185 | |||
229 | m_rc_auto_hide(scr.resourceManager(), false, | 186 | m_rc_auto_hide(scr.resourceManager(), false, |
230 | scr.name() + ".slit.autoHide", scr.altName() + ".Slit.AutoHide"), | 187 | scr.name() + ".slit.autoHide", scr.altName() + ".Slit.AutoHide"), |
231 | // TODO: this resource name must change | 188 | // TODO: this resource name must change |
232 | m_rc_maximize_over(scr.resourceManager(), false, | 189 | m_rc_maximize_over(scr.resourceManager(), false, |
233 | scr.name() + ".maxOverSlit", scr.altName() + ".MaxOverSlit"), | 190 | scr.name() + ".slit.maxOver", scr.altName() + ".Slit.MaxOver"), |
234 | m_rc_placement(scr.resourceManager(), BOTTOMRIGHT, | 191 | m_rc_placement(scr.resourceManager(), BOTTOMRIGHT, |
235 | scr.name() + ".slit.placement", scr.altName() + ".Slit.Placement"), | 192 | scr.name() + ".slit.placement", scr.altName() + ".Slit.Placement"), |
236 | m_rc_direction(scr.resourceManager(), VERTICAL, | 193 | m_rc_direction(scr.resourceManager(), VERTICAL, |
@@ -248,6 +205,8 @@ Slit::Slit(BScreen &scr, FbTk::XLayer &layer, const char *filename) | |||
248 | m_timer.setTimeout(200); // default timeout | 205 | m_timer.setTimeout(200); // default timeout |
249 | m_timer.fireOnce(true); | 206 | m_timer.fireOnce(true); |
250 | 207 | ||
208 | // create main window | ||
209 | |||
251 | XSetWindowAttributes attrib; | 210 | XSetWindowAttributes attrib; |
252 | unsigned long create_mask = CWBackPixmap | CWBackPixel | CWBorderPixel | | 211 | unsigned long create_mask = CWBackPixmap | CWBackPixel | CWBorderPixel | |
253 | CWColormap | CWOverrideRedirect | CWEventMask; | 212 | CWColormap | CWOverrideRedirect | CWEventMask; |
@@ -287,6 +246,8 @@ Slit::~Slit() { | |||
287 | clearStrut(); | 246 | clearStrut(); |
288 | if (frame.pixmap != 0) | 247 | if (frame.pixmap != 0) |
289 | screen().imageControl().removeImage(frame.pixmap); | 248 | screen().imageControl().removeImage(frame.pixmap); |
249 | |||
250 | shutdown(); | ||
290 | } | 251 | } |
291 | 252 | ||
292 | void Slit::clearStrut() { | 253 | void Slit::clearStrut() { |
@@ -355,7 +316,7 @@ void Slit::addClient(Window w) { | |||
355 | // Look for slot in client list by name | 316 | // Look for slot in client list by name |
356 | SlitClient *client = 0; | 317 | SlitClient *client = 0; |
357 | std::string match_name; | 318 | std::string match_name; |
358 | ::getWMName(&screen(), w, match_name); | 319 | match_name = Xutil::getWMName(w); |
359 | SlitClients::iterator it = m_client_list.begin(); | 320 | SlitClients::iterator it = m_client_list.begin(); |
360 | SlitClients::iterator it_end = m_client_list.end(); | 321 | SlitClients::iterator it_end = m_client_list.end(); |
361 | bool found_match = false; | 322 | bool found_match = false; |
@@ -422,9 +383,10 @@ void Slit::addClient(Window w) { | |||
422 | m_kwm2_dockwindow, 0l, 1l, False, | 383 | m_kwm2_dockwindow, 0l, 1l, False, |
423 | m_kwm2_dockwindow, | 384 | m_kwm2_dockwindow, |
424 | &ajunk, &ijunk, &uljunk, &uljunk, | 385 | &ajunk, &ijunk, &uljunk, &uljunk, |
425 | (unsigned char **) &data) == Success) { | 386 | (unsigned char **) &data) == Success && data) { |
426 | iskdedockapp = (data && data[0] != 0); | 387 | iskdedockapp = (data && data[0] != 0); |
427 | XFree((char *) data); | 388 | XFree((char *) data); |
389 | data = 0; | ||
428 | } | 390 | } |
429 | 391 | ||
430 | // Check if KDE v1.x dock applet | 392 | // Check if KDE v1.x dock applet |
@@ -433,9 +395,10 @@ void Slit::addClient(Window w) { | |||
433 | m_kwm1_dockwindow, 0l, 1l, False, | 395 | m_kwm1_dockwindow, 0l, 1l, False, |
434 | m_kwm1_dockwindow, | 396 | m_kwm1_dockwindow, |
435 | &ajunk, &ijunk, &uljunk, &uljunk, | 397 | &ajunk, &ijunk, &uljunk, &uljunk, |
436 | (unsigned char **) &data) == Success) { | 398 | (unsigned char **) &data) == Success && data) { |
437 | iskdedockapp = (data && data[0] != 0); | 399 | iskdedockapp = (data && data[0] != 0); |
438 | XFree((char *) data); | 400 | XFree((char *) data); |
401 | data = 0; | ||
439 | } | 402 | } |
440 | } | 403 | } |
441 | 404 | ||
@@ -496,10 +459,14 @@ void Slit::setPlacement(Placement place) { | |||
496 | } | 459 | } |
497 | 460 | ||
498 | void Slit::removeClient(SlitClient *client, bool remap, bool destroy) { | 461 | void Slit::removeClient(SlitClient *client, bool remap, bool destroy) { |
462 | if (client == 0) | ||
463 | return; | ||
464 | |||
499 | #ifdef DEBUG | 465 | #ifdef DEBUG |
500 | cerr<<"Slit::removeClient( client->client_window = 0x"<<hex<<client->clientWindow()<< | 466 | cerr<<"Slit::removeClient( client->client_window = 0x"<<hex<<client->clientWindow()<< |
501 | ", client->icon_window)"<<endl; | 467 | ", client->icon_window)"<<endl; |
502 | #endif // DEBUG | 468 | #endif // DEBUG |
469 | |||
503 | // remove from event manager | 470 | // remove from event manager |
504 | if (client->clientWindow() != 0) | 471 | if (client->clientWindow() != 0) |
505 | FbTk::EventManager::instance()->remove(client->clientWindow()); | 472 | FbTk::EventManager::instance()->remove(client->clientWindow()); |
@@ -677,6 +644,7 @@ void Slit::reconfigure() { | |||
677 | (*client_it)->enableEvents(); | 644 | (*client_it)->enableEvents(); |
678 | continue; | 645 | continue; |
679 | } | 646 | } |
647 | |||
680 | if (height_inc) | 648 | if (height_inc) |
681 | x = (frame.width - (*client_it)->width()) / 2; | 649 | x = (frame.width - (*client_it)->width()) / 2; |
682 | else | 650 | else |
@@ -717,6 +685,8 @@ void Slit::reconfigure() { | |||
717 | m_slitmenu.reconfigure(); | 685 | m_slitmenu.reconfigure(); |
718 | updateClientmenu(); | 686 | updateClientmenu(); |
719 | updateStrut(); | 687 | updateStrut(); |
688 | |||
689 | |||
720 | } | 690 | } |
721 | 691 | ||
722 | 692 | ||
@@ -839,6 +809,10 @@ void Slit::reposition() { | |||
839 | frame.window.moveResize(frame.x, frame.y, | 809 | frame.window.moveResize(frame.x, frame.y, |
840 | frame.width, frame.height); | 810 | frame.width, frame.height); |
841 | } | 811 | } |
812 | #ifdef DEBUG | ||
813 | cerr<<__FILE__<<"("<<__FUNCTION__<<"): frame("<<dec<<frame.x<<", "<<frame.y<<", "<<frame.width<<", "<<frame.height<<")"<<endl; | ||
814 | #endif // DEBUG | ||
815 | |||
842 | } | 816 | } |
843 | 817 | ||
844 | 818 | ||
@@ -896,7 +870,7 @@ void Slit::handleEvent(XEvent &event) { | |||
896 | if (data) | 870 | if (data) |
897 | iskdedockapp = True; | 871 | iskdedockapp = True; |
898 | XFree((char *) data); | 872 | XFree((char *) data); |
899 | 873 | data = 0; | |
900 | } | 874 | } |
901 | 875 | ||
902 | // Check if KDE v1.x dock applet | 876 | // Check if KDE v1.x dock applet |
@@ -904,9 +878,10 @@ void Slit::handleEvent(XEvent &event) { | |||
904 | if (XGetWindowProperty(disp, event.xmaprequest.window, | 878 | if (XGetWindowProperty(disp, event.xmaprequest.window, |
905 | m_kwm1_dockwindow, 0l, 1l, False, | 879 | m_kwm1_dockwindow, 0l, 1l, False, |
906 | m_kwm1_dockwindow, &ajunk, &ijunk, &uljunk, | 880 | m_kwm1_dockwindow, &ajunk, &ijunk, &uljunk, |
907 | &uljunk, (unsigned char **) &data) == Success) { | 881 | &uljunk, (unsigned char **) &data) == Success && data) { |
908 | iskdedockapp = (data && data[0] != 0); | 882 | iskdedockapp = (data && data[0] != 0); |
909 | XFree((char *) data); | 883 | XFree((char *) data); |
884 | data = 0; | ||
910 | } | 885 | } |
911 | } | 886 | } |
912 | 887 | ||
@@ -1142,8 +1117,7 @@ void Slit::setupMenu() { | |||
1142 | 1117 | ||
1143 | // setup base menu | 1118 | // setup base menu |
1144 | m_slitmenu.setLabel("Slit"); | 1119 | m_slitmenu.setLabel("Slit"); |
1145 | m_slitmenu.insert(i18n->getMessage( | 1120 | m_slitmenu.insert(i18n->getMessage(CommonSet, CommonPlacementTitle, |
1146 | CommonSet, CommonPlacementTitle, | ||
1147 | "Placement"), | 1121 | "Placement"), |
1148 | &m_placement_menu); | 1122 | &m_placement_menu); |
1149 | 1123 | ||
@@ -1152,29 +1126,31 @@ void Slit::setupMenu() { | |||
1152 | #ifdef XINERAMA | 1126 | #ifdef XINERAMA |
1153 | if (screen().hasXinerama()) { | 1127 | if (screen().hasXinerama()) { |
1154 | m_slitmenu.insert("On Head...", new XineramaHeadMenu<Slit>( | 1128 | m_slitmenu.insert("On Head...", new XineramaHeadMenu<Slit>( |
1155 | *screen().menuTheme(), | 1129 | *screen().menuTheme(), |
1156 | screen(), | 1130 | screen(), |
1157 | screen().imageControl(), | 1131 | screen().imageControl(), |
1158 | *screen().layerManager().getLayer(Fluxbox::instance()->getMenuLayer()), | 1132 | *screen().layerManager().getLayer(Fluxbox::instance()->getMenuLayer()), |
1159 | this | 1133 | this |
1160 | )); | 1134 | )); |
1161 | } | 1135 | } |
1162 | 1136 | ||
1163 | #endif //XINERAMA | 1137 | #endif //XINERAMA |
1164 | m_slitmenu.insert(new BoolMenuItem(i18n->getMessage( | 1138 | m_slitmenu.insert(new BoolMenuItem(i18n->getMessage(CommonSet, CommonAutoHide, |
1165 | CommonSet, CommonAutoHide, | ||
1166 | "Auto hide"), | 1139 | "Auto hide"), |
1167 | *m_rc_auto_hide, | 1140 | *m_rc_auto_hide, |
1168 | save_and_reconfigure_slit)); | 1141 | save_and_reconfigure_slit)); |
1169 | 1142 | ||
1143 | m_slitmenu.insert(new BoolMenuItem("Maximize Over", | ||
1144 | *m_rc_maximize_over, | ||
1145 | save_and_reconfigure_slit)); | ||
1146 | |||
1170 | FbTk::MenuItem *alpha_menuitem = new IntResMenuItem("Alpha", | 1147 | FbTk::MenuItem *alpha_menuitem = new IntResMenuItem("Alpha", |
1171 | m_rc_alpha, | 1148 | m_rc_alpha, |
1172 | 0, 255); | 1149 | 0, 255); |
1173 | alpha_menuitem->setCommand(save_and_reconfigure_slit); | 1150 | alpha_menuitem->setCommand(save_and_reconfigure_slit); |
1174 | m_slitmenu.insert(alpha_menuitem); | 1151 | m_slitmenu.insert(alpha_menuitem); |
1175 | 1152 | ||
1176 | m_slitmenu.insert(new SlitDirMenuItem(i18n->getMessage( | 1153 | m_slitmenu.insert(new SlitDirMenuItem(i18n->getMessage(SlitSet, SlitSlitDirection, |
1177 | SlitSet, SlitSlitDirection, | ||
1178 | "Slit Direction"), | 1154 | "Slit Direction"), |
1179 | *this, | 1155 | *this, |
1180 | save_and_reconfigure)); | 1156 | save_and_reconfigure)); |
@@ -1182,9 +1158,8 @@ void Slit::setupMenu() { | |||
1182 | m_slitmenu.update(); | 1158 | m_slitmenu.update(); |
1183 | 1159 | ||
1184 | // setup sub menu | 1160 | // setup sub menu |
1185 | m_placement_menu.setLabel(i18n->getMessage( | 1161 | m_placement_menu.setLabel(i18n->getMessage(SlitSet, SlitSlitPlacement, |
1186 | SlitSet, SlitSlitPlacement, | 1162 | "Slit Placement")); |
1187 | "Slit Placement")); | ||
1188 | m_placement_menu.setMinimumSublevels(3); | 1163 | m_placement_menu.setMinimumSublevels(3); |
1189 | m_layermenu->setInternalMenu(); | 1164 | m_layermenu->setInternalMenu(); |
1190 | m_clientlist_menu.setInternalMenu(); | 1165 | m_clientlist_menu.setInternalMenu(); |