diff options
Diffstat (limited to 'src/FbTk/XLayer.cc')
-rw-r--r-- | src/FbTk/XLayer.cc | 84 |
1 files changed, 45 insertions, 39 deletions
diff --git a/src/FbTk/XLayer.cc b/src/FbTk/XLayer.cc index 8d1d80a..f7eda8c 100644 --- a/src/FbTk/XLayer.cc +++ b/src/FbTk/XLayer.cc | |||
@@ -27,9 +27,15 @@ | |||
27 | #include "App.hh" | 27 | #include "App.hh" |
28 | 28 | ||
29 | #include <iostream> | 29 | #include <iostream> |
30 | using namespace std; | 30 | |
31 | using std::find; | ||
31 | using namespace FbTk; | 32 | using namespace FbTk; |
32 | 33 | ||
34 | #ifdef DEBUG | ||
35 | using std::cerr; | ||
36 | using std::endl; | ||
37 | #endif // DEBUG | ||
38 | |||
33 | XLayer::XLayer(MultLayers &manager, int layernum): | 39 | XLayer::XLayer(MultLayers &manager, int layernum): |
34 | m_manager(manager), m_layernum(layernum) { | 40 | m_manager(manager), m_layernum(layernum) { |
35 | } | 41 | } |
@@ -51,7 +57,7 @@ void XLayer::restack() { | |||
51 | it_end = itemList().end(); | 57 | it_end = itemList().end(); |
52 | Window *winlist = new Window[num_windows]; | 58 | Window *winlist = new Window[num_windows]; |
53 | size_t j=0; | 59 | size_t j=0; |
54 | 60 | ||
55 | // add all the windows from each item | 61 | // add all the windows from each item |
56 | for (; it != it_end; ++it) { | 62 | for (; it != it_end; ++it) { |
57 | XLayerItem::Windows::const_iterator wit = (*it)->getWindows().begin(); | 63 | XLayerItem::Windows::const_iterator wit = (*it)->getWindows().begin(); |
@@ -87,13 +93,13 @@ void XLayer::stackBelowItem(XLayerItem *item, XLayerItem *above) { | |||
87 | Window *winlist; | 93 | Window *winlist; |
88 | size_t winnum, size, num = item->numWindows(); | 94 | size_t winnum, size, num = item->numWindows(); |
89 | 95 | ||
90 | // if there are no windows provided for above us, | 96 | // if there are no windows provided for above us, |
91 | // then we must have to go right to the top of the stack | 97 | // then we must have to go right to the top of the stack |
92 | if (!above) { // must need to go right to top | 98 | if (!above) { // must need to go right to top |
93 | if (item->getWindows().front()->window()) | 99 | if (item->getWindows().front()->window()) |
94 | XRaiseWindow(FbTk::App::instance()->display(), item->getWindows().front()->window()); | 100 | XRaiseWindow(FbTk::App::instance()->display(), item->getWindows().front()->window()); |
95 | 101 | ||
96 | // if this XLayerItem has more than one window, | 102 | // if this XLayerItem has more than one window, |
97 | // then we'll stack the rest in under the front one too | 103 | // then we'll stack the rest in under the front one too |
98 | // our size needs to be the number of windows in the group, since there isn't one above. | 104 | // our size needs to be the number of windows in the group, since there isn't one above. |
99 | if (num > 1) { | 105 | if (num > 1) { |
@@ -120,7 +126,7 @@ void XLayer::stackBelowItem(XLayerItem *item, XLayerItem *above) { | |||
120 | XLayerItem::Windows::iterator it = item->getWindows().begin(); | 126 | XLayerItem::Windows::iterator it = item->getWindows().begin(); |
121 | XLayerItem::Windows::iterator it_end = item->getWindows().end(); | 127 | XLayerItem::Windows::iterator it_end = item->getWindows().end(); |
122 | for (; it != it_end; ++it) { | 128 | for (; it != it_end; ++it) { |
123 | if ((*it)->window()) | 129 | if ((*it)->window()) |
124 | winlist[winnum++] = (*it)->window(); | 130 | winlist[winnum++] = (*it)->window(); |
125 | } | 131 | } |
126 | 132 | ||
@@ -128,7 +134,7 @@ void XLayer::stackBelowItem(XLayerItem *item, XLayerItem *above) { | |||
128 | XRestackWindows(FbTk::App::instance()->display(), winlist, winnum); | 134 | XRestackWindows(FbTk::App::instance()->display(), winlist, winnum); |
129 | 135 | ||
130 | delete [] winlist; | 136 | delete [] winlist; |
131 | 137 | ||
132 | } | 138 | } |
133 | 139 | ||
134 | // We can't just use Restack here, because it won't do anything if they're | 140 | // We can't just use Restack here, because it won't do anything if they're |
@@ -139,17 +145,17 @@ void XLayer::alignItem(XLayerItem &item) { | |||
139 | return; | 145 | return; |
140 | } | 146 | } |
141 | 147 | ||
142 | // Note: some other things effectively assume that the window list is | 148 | // Note: some other things effectively assume that the window list is |
143 | // sorted from highest to lowest | 149 | // sorted from highest to lowest |
144 | // get our item | 150 | // get our item |
145 | iterator myit = std::find(itemList().begin(), itemList().end(), &item); | 151 | iterator myit = find(itemList().begin(), itemList().end(), &item); |
146 | iterator it = myit; | 152 | iterator it = myit; |
147 | 153 | ||
148 | // go to the one above it in our layer (top is front, so we decrement) | 154 | // go to the one above it in our layer (top is front, so we decrement) |
149 | --it; | 155 | --it; |
150 | 156 | ||
151 | // keep going until we find one that is currently visible to the user | 157 | // keep going until we find one that is currently visible to the user |
152 | while (it != itemList().begin() && !(*it)->visible()) | 158 | while (it != itemList().begin() && !(*it)->visible()) |
153 | --it; | 159 | --it; |
154 | 160 | ||
155 | if (it == itemList().begin() && !(*it)->visible()) | 161 | if (it == itemList().begin() && !(*it)->visible()) |
@@ -166,7 +172,7 @@ XLayer::iterator XLayer::insert(XLayerItem &item, unsigned int pos) { | |||
166 | if (pos != 0) | 172 | if (pos != 0) |
167 | cerr<<__FILE__<<"("<<__LINE__<<"): Insert using non-zero position not valid in XLayer"<<endl; | 173 | cerr<<__FILE__<<"("<<__LINE__<<"): Insert using non-zero position not valid in XLayer"<<endl; |
168 | #endif // DEBUG | 174 | #endif // DEBUG |
169 | 175 | ||
170 | itemList().push_front(&item); | 176 | itemList().push_front(&item); |
171 | // restack below next window up | 177 | // restack below next window up |
172 | stackBelowItem(&item, m_manager.getLowestItemAboveLayer(m_layernum)); | 178 | stackBelowItem(&item, m_manager.getLowestItemAboveLayer(m_layernum)); |
@@ -188,9 +194,9 @@ void XLayer::cycleUp() { | |||
188 | // need to find highest visible window, and move it to bottom | 194 | // need to find highest visible window, and move it to bottom |
189 | iterator it = itemList().begin(); | 195 | iterator it = itemList().begin(); |
190 | iterator it_end = itemList().end(); | 196 | iterator it_end = itemList().end(); |
191 | while (it != it_end && !(*it)->visible()) | 197 | while (it != it_end && !(*it)->visible()) |
192 | ++it; | 198 | ++it; |
193 | 199 | ||
194 | // if there is something to do | 200 | // if there is something to do |
195 | if (it != it_end) | 201 | if (it != it_end) |
196 | lower(**it); | 202 | lower(**it); |
@@ -202,34 +208,34 @@ void XLayer::cycleDown() { | |||
202 | // so use a reverse iterator, and the same logic as cycleUp() | 208 | // so use a reverse iterator, and the same logic as cycleUp() |
203 | reverse_iterator it = itemList().rbegin(); | 209 | reverse_iterator it = itemList().rbegin(); |
204 | reverse_iterator it_end = itemList().rend(); | 210 | reverse_iterator it_end = itemList().rend(); |
205 | while (it != it_end && !(*it)->visible()) | 211 | while (it != it_end && !(*it)->visible()) |
206 | ++it; | 212 | ++it; |
207 | 213 | ||
208 | // if there is something to do | 214 | // if there is something to do |
209 | if (it != it_end) | 215 | if (it != it_end) |
210 | raise(**it); | 216 | raise(**it); |
211 | 217 | ||
212 | } | 218 | } |
213 | 219 | ||
214 | void XLayer::stepUp(XLayerItem &item) { | 220 | void XLayer::stepUp(XLayerItem &item) { |
215 | // need to find next visible window upwards, and put it above that | 221 | // need to find next visible window upwards, and put it above that |
216 | 222 | ||
217 | if (&item == itemList().front()) | 223 | if (&item == itemList().front()) |
218 | return; // nothing to do | 224 | return; // nothing to do |
219 | 225 | ||
220 | // TODO: is there a better way of doing this? | 226 | // TODO: is there a better way of doing this? |
221 | 227 | ||
222 | // get our item | 228 | // get our item |
223 | iterator myit = std::find(itemList().begin(), itemList().end(), &item); | 229 | iterator myit = find(itemList().begin(), itemList().end(), &item); |
224 | iterator it = myit; | 230 | iterator it = myit; |
225 | 231 | ||
226 | // go to the one above it in our layer (top is front, so we decrement) | 232 | // go to the one above it in our layer (top is front, so we decrement) |
227 | --it; | 233 | --it; |
228 | 234 | ||
229 | // keep going until we find one that is currently visible to the user | 235 | // keep going until we find one that is currently visible to the user |
230 | while (it != itemList().begin() && !(*it)->visible()) | 236 | while (it != itemList().begin() && !(*it)->visible()) |
231 | --it; | 237 | --it; |
232 | 238 | ||
233 | if (it == itemList().begin() && !(*it)->visible()) { | 239 | if (it == itemList().begin() && !(*it)->visible()) { |
234 | // reached front item, but it wasn't visible, therefore it was already raised | 240 | // reached front item, but it wasn't visible, therefore it was already raised |
235 | } else { | 241 | } else { |
@@ -243,7 +249,7 @@ void XLayer::stepUp(XLayerItem &item) { | |||
243 | if (it == itemList().begin()) { | 249 | if (it == itemList().begin()) { |
244 | stackBelowItem(&item, m_manager.getLowestItemAboveLayer(m_layernum)); | 250 | stackBelowItem(&item, m_manager.getLowestItemAboveLayer(m_layernum)); |
245 | } else { | 251 | } else { |
246 | // otherwise go up one in this layer (i.e. above the one we want to go above) | 252 | // otherwise go up one in this layer (i.e. above the one we want to go above) |
247 | --it; | 253 | --it; |
248 | // and stack below that. | 254 | // and stack below that. |
249 | stackBelowItem(&item, *it); | 255 | stackBelowItem(&item, *it); |
@@ -255,11 +261,11 @@ void XLayer::stepDown(XLayerItem &item) { | |||
255 | // need to find next visible window down, and put it below that | 261 | // need to find next visible window down, and put it below that |
256 | 262 | ||
257 | // if we're already the bottom of the layer | 263 | // if we're already the bottom of the layer |
258 | if (&item == itemList().back()) | 264 | if (&item == itemList().back()) |
259 | return; // nothing to do | 265 | return; // nothing to do |
260 | 266 | ||
261 | // get our position | 267 | // get our position |
262 | iterator myit = std::find(itemList().begin(), itemList().end(), &item); | 268 | iterator myit = find(itemList().begin(), itemList().end(), &item); |
263 | iterator it = myit; | 269 | iterator it = myit; |
264 | 270 | ||
265 | // go one below it (top is front, so we must increment) | 271 | // go one below it (top is front, so we must increment) |
@@ -267,7 +273,7 @@ void XLayer::stepDown(XLayerItem &item) { | |||
267 | iterator it_end = itemList().end(); | 273 | iterator it_end = itemList().end(); |
268 | 274 | ||
269 | // keep going down until we find a visible one | 275 | // keep going down until we find a visible one |
270 | while (it != it_end && !(*it)->visible()) | 276 | while (it != it_end && !(*it)->visible()) |
271 | it++; | 277 | it++; |
272 | 278 | ||
273 | // if we didn't reach the end, then stack below the | 279 | // if we didn't reach the end, then stack below the |
@@ -283,7 +289,7 @@ void XLayer::raise(XLayerItem &item) { | |||
283 | if (&item == itemList().front()) | 289 | if (&item == itemList().front()) |
284 | return; // nothing to do | 290 | return; // nothing to do |
285 | 291 | ||
286 | iterator it = std::find(itemList().begin(), itemList().end(), &item); | 292 | iterator it = find(itemList().begin(), itemList().end(), &item); |
287 | if (it != itemList().end()) | 293 | if (it != itemList().end()) |
288 | itemList().erase(it); | 294 | itemList().erase(it); |
289 | else { | 295 | else { |
@@ -295,7 +301,7 @@ void XLayer::raise(XLayerItem &item) { | |||
295 | 301 | ||
296 | itemList().push_front(&item); | 302 | itemList().push_front(&item); |
297 | stackBelowItem(&item, m_manager.getLowestItemAboveLayer(m_layernum)); | 303 | stackBelowItem(&item, m_manager.getLowestItemAboveLayer(m_layernum)); |
298 | 304 | ||
299 | } | 305 | } |
300 | 306 | ||
301 | void XLayer::tempRaise(XLayerItem &item) { | 307 | void XLayer::tempRaise(XLayerItem &item) { |
@@ -304,7 +310,7 @@ void XLayer::tempRaise(XLayerItem &item) { | |||
304 | if (&item == itemList().front()) | 310 | if (&item == itemList().front()) |
305 | return; // nothing to do | 311 | return; // nothing to do |
306 | 312 | ||
307 | iterator it = std::find(itemList().begin(), itemList().end(), &item); | 313 | iterator it = find(itemList().begin(), itemList().end(), &item); |
308 | if (it == itemList().end()) { | 314 | if (it == itemList().end()) { |
309 | #ifdef DEBUG | 315 | #ifdef DEBUG |
310 | cerr<<__FILE__<<"("<<__LINE__<<"): WARNING: raise on item not in layer["<<m_layernum<<"]"<<endl; | 316 | cerr<<__FILE__<<"("<<__LINE__<<"): WARNING: raise on item not in layer["<<m_layernum<<"]"<<endl; |
@@ -314,17 +320,17 @@ void XLayer::tempRaise(XLayerItem &item) { | |||
314 | 320 | ||
315 | // don't add it back to the top | 321 | // don't add it back to the top |
316 | stackBelowItem(&item, m_manager.getLowestItemAboveLayer(m_layernum)); | 322 | stackBelowItem(&item, m_manager.getLowestItemAboveLayer(m_layernum)); |
317 | 323 | ||
318 | } | 324 | } |
319 | 325 | ||
320 | void XLayer::lower(XLayerItem &item) { | 326 | void XLayer::lower(XLayerItem &item) { |
321 | // assume already in this layer | 327 | // assume already in this layer |
322 | 328 | ||
323 | // is it already the lowest? | 329 | // is it already the lowest? |
324 | if (&item == itemList().back()) | 330 | if (&item == itemList().back()) |
325 | return; // nothing to do | 331 | return; // nothing to do |
326 | 332 | ||
327 | iterator it = std::find(itemList().begin(), itemList().end(), &item); | 333 | iterator it = find(itemList().begin(), itemList().end(), &item); |
328 | if (it != itemList().end()) | 334 | if (it != itemList().end()) |
329 | // remove this item | 335 | // remove this item |
330 | itemList().erase(it); | 336 | itemList().erase(it); |
@@ -344,13 +350,13 @@ void XLayer::lower(XLayerItem &item) { | |||
344 | 350 | ||
345 | // go up one so we have an object (which must exist, since at least this item is in the layer) | 351 | // go up one so we have an object (which must exist, since at least this item is in the layer) |
346 | it--; | 352 | it--; |
347 | 353 | ||
348 | // go down another one | 354 | // go down another one |
349 | // must exist, otherwise our item must == itemList().back() | 355 | // must exist, otherwise our item must == itemList().back() |
350 | it--; | 356 | it--; |
351 | 357 | ||
352 | // and restack our window below that one. | 358 | // and restack our window below that one. |
353 | stackBelowItem(&item, *it); | 359 | stackBelowItem(&item, *it); |
354 | } | 360 | } |
355 | 361 | ||
356 | void XLayer::raiseLayer(XLayerItem &item) { | 362 | void XLayer::raiseLayer(XLayerItem &item) { |
@@ -367,15 +373,15 @@ void XLayer::moveToLayer(XLayerItem &item, int layernum) { | |||
367 | 373 | ||
368 | 374 | ||
369 | XLayerItem *XLayer::getLowestItem() { | 375 | XLayerItem *XLayer::getLowestItem() { |
370 | if (itemList().empty()) | 376 | if (itemList().empty()) |
371 | return 0; | 377 | return 0; |
372 | else | 378 | else |
373 | return itemList().back(); | 379 | return itemList().back(); |
374 | } | 380 | } |
375 | 381 | ||
376 | XLayerItem *XLayer::getItemBelow(XLayerItem &item) { | 382 | XLayerItem *XLayer::getItemBelow(XLayerItem &item) { |
377 | // get our iterator | 383 | // get our iterator |
378 | iterator it = std::find(itemList().begin(), itemList().end(), &item); | 384 | iterator it = find(itemList().begin(), itemList().end(), &item); |
379 | 385 | ||
380 | // go one lower | 386 | // go one lower |
381 | it++; | 387 | it++; |
@@ -389,12 +395,12 @@ XLayerItem *XLayer::getItemBelow(XLayerItem &item) { | |||
389 | 395 | ||
390 | XLayerItem *XLayer::getItemAbove(XLayerItem &item) { | 396 | XLayerItem *XLayer::getItemAbove(XLayerItem &item) { |
391 | // get our iterator | 397 | // get our iterator |
392 | iterator it = std::find(itemList().begin(), itemList().end(), &item); | 398 | iterator it = find(itemList().begin(), itemList().end(), &item); |
393 | 399 | ||
394 | // if this is the beginning (top-most item), do nothing, otherwise give the next one up | 400 | // if this is the beginning (top-most item), do nothing, otherwise give the next one up |
395 | // the list (which must be there since we aren't the beginning) | 401 | // the list (which must be there since we aren't the beginning) |
396 | if (it == itemList().begin()) | 402 | if (it == itemList().begin()) |
397 | return 0; | 403 | return 0; |
398 | else | 404 | else |
399 | return *(--it); | 405 | return *(--it); |
400 | } | 406 | } |