aboutsummaryrefslogtreecommitdiff
path: root/src/Tab.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/Tab.cc')
-rw-r--r--src/Tab.cc255
1 files changed, 153 insertions, 102 deletions
diff --git a/src/Tab.cc b/src/Tab.cc
index 94591fd..fb529d8 100644
--- a/src/Tab.cc
+++ b/src/Tab.cc
@@ -19,7 +19,7 @@
19// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER 19// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
20// DEALINGS IN THE SOFTWARE. 20// DEALINGS IN THE SOFTWARE.
21 21
22// $Id: Tab.cc,v 1.17 2002/01/26 11:16:25 fluxgen Exp $ 22// $Id: Tab.cc,v 1.18 2002/01/27 12:52:02 fluxgen Exp $
23 23
24#include "Tab.hh" 24#include "Tab.hh"
25 25
@@ -275,14 +275,11 @@ void Tab::withdraw() {
275// Set/reset the the sticky on all windows in the list 275// Set/reset the the sticky on all windows in the list
276//--------------------------------------- 276//---------------------------------------
277void Tab::stick() { 277void Tab::stick() {
278 Tab *tab;
278 279
279 //get first tab
280 Tab *first = 0;
281 first = getFirst(this);
282
283 //now do stick for all windows in the list 280 //now do stick for all windows in the list
284 for (; first!=0; first = first->m_next) { 281 for (tab = getFirst(this); tab != 0; tab = tab->m_next) {
285 FluxboxWindow *win = first->m_win; //just for convenient 282 FluxboxWindow *win = tab->m_win; //just for convenient
286 if (win->isStuck()) { 283 if (win->isStuck()) {
287 win->blackbox_attrib.flags ^= BaseDisplay::ATTRIB_OMNIPRESENT; 284 win->blackbox_attrib.flags ^= BaseDisplay::ATTRIB_OMNIPRESENT;
288 win->blackbox_attrib.attrib ^= BaseDisplay::ATTRIB_OMNIPRESENT; 285 win->blackbox_attrib.attrib ^= BaseDisplay::ATTRIB_OMNIPRESENT;
@@ -305,12 +302,12 @@ void Tab::stick() {
305// Resize the window's in the tablist 302// Resize the window's in the tablist
306//---------------------------------- 303//----------------------------------
307void Tab::resize() { 304void Tab::resize() {
308 Tab *first = getFirst(this); 305 Tab *tab;
309 306
310 //now move and resize the windows in the list 307 //now move and resize the windows in the list
311 for (; first != 0; first = first->m_next) { 308 for (tab = getFirst(this); tab != 0; tab = tab->m_next) {
312 if (first!=this) { 309 if (tab!=this) {
313 first->m_win->configure(m_win->getXFrame(), m_win->getYFrame(), 310 tab->m_win->configure(m_win->getXFrame(), m_win->getYFrame(),
314 m_win->getWidth(), m_win->getHeight()); 311 m_win->getWidth(), m_win->getHeight());
315 } 312 }
316 } 313 }
@@ -326,10 +323,12 @@ void Tab::resize() {
326// Shades the windows in the tablist 323// Shades the windows in the tablist
327//-------------------------------- 324//--------------------------------
328void Tab::shade() { 325void Tab::shade() {
329 for(Tab *first = getFirst(this); first != 0; first = first->m_next) { 326 Tab *tab;
330 if (first==this) 327
328 for(tab = getFirst(this); tab != 0; tab = tab->m_next) {
329 if (tab==this)
331 continue; 330 continue;
332 first->m_win->shade(); 331 tab->m_win->shade();
333 } 332 }
334 333
335 if (m_win->getScreen()->getTabPlacement() == PLEFT || 334 if (m_win->getScreen()->getTabPlacement() == PLEFT ||
@@ -390,6 +389,75 @@ void Tab::draw(bool pressed) {
390 } 389 }
391} 390}
392 391
392//-----------------------------------------------
393//Helper for the Tab::setPosition() call
394//returns the y position component correctly
395//according to shading in cases PBOTTOM and
396//isShaded()
397//-----------------------------------------------
398int Tab::setPositionShadingHelper(bool shaded) {
399 if (shaded) {
400 return m_win->getYFrame() + m_win->getTitleHeight() +
401 m_win->getScreen()->getBorderWidth2x();
402 } else {
403 return m_win->getYFrame() + m_win->getHeight() +
404 m_win->getScreen()->getBorderWidth2x();
405 }
406}
407
408//-----------------------------------------------
409//Helpers for correct alignment of tabs used
410//by the setPosition() call
411//return x/y positions correctly according to
412//alignment, the 1st for cases PTOP and PBOTTOM
413//the 2nd for cases PLEFT and PRIGHT
414//-----------------------------------------------
415int Tab::setPositionTBAlignHelper(Alignment align) {
416 switch(align) {
417
418 case ARELATIVE:
419 case ALEFT:
420 return m_win->getXFrame();
421 break;
422 case ACENTER:
423 return calcCenterXPos();
424 break;
425 case ARIGHT:
426 return m_win->getXFrame() + m_win->getWidth() +
427 m_win->getScreen()->getBorderWidth2x() - m_size_w;
428 default:
429#ifdef DEBUG
430 cerr << __FILE__ << ":" <<__LINE__ << ": " <<
431 "Unsupported Alignment" << endl;
432#endif //DEBUG
433 return 0;
434 break;
435 }
436}
437
438int Tab::setPositionLRAlignHelper(Alignment align) {
439 switch(align) {
440 case ALEFT:
441 return m_win->getYFrame() - m_size_h + m_win->getHeight() +
442 m_win->getScreen()->getBorderWidth2x();
443 break;
444 case ACENTER:
445 return calcCenterYPos();
446 break;
447 case ARELATIVE:
448 case ARIGHT:
449 return m_win->getYFrame();
450 break;
451 default:
452#ifdef DEBUG
453 cerr << __FILE__ << ":"<< __LINE__ << ": " <<
454 "Unsupported Alignment" << endl;
455#endif //DEBUG
456 return 0;
457 break;
458 }
459}
460
393//------------- setPosition ----------------- 461//------------- setPosition -----------------
394// Position tab ( follow the m_win pos ). 462// Position tab ( follow the m_win pos ).
395// (and resize) 463// (and resize)
@@ -400,85 +468,62 @@ void Tab::setPosition() {
400 if (m_stoptabs) 468 if (m_stoptabs)
401 return; 469 return;
402 470
403 Tab *first = 0; 471 Tab *tab;
404 int pos_x = 0, pos_y = 0; 472 int pos_x = 0, pos_y = 0;
405 473
406 m_stoptabs = true; //freeze tablist 474 m_stoptabs = true; //freeze tablist
407 475
408 //and check for max tabs 476 //and check for max tabs
409 //TODO: optimize! There is many ways to implement this...
410 //posible movement to a static member function
411
412 //Tab placement
413 if (m_win->getScreen()->getTabPlacement() == PTOP) {
414 pos_y = m_win->getYFrame() - m_size_h;
415 477
416 } else if (m_win->getScreen()->getTabPlacement() == PBOTTOM || 478 //Tab placement + alignment
417 m_win->isShaded()) { 479 switch (m_win->getScreen()->getTabPlacement()) {
418 if (m_win->isShaded()) 480 case PTOP:
419 pos_y = m_win->getYFrame() + m_win->getTitleHeight() + 481 pos_y = m_win->getYFrame() - m_size_h;
420 m_win->getScreen()->getBorderWidth2x(); 482 pos_x = setPositionTBAlignHelper(
421 483 m_win->getScreen()->getTabAlignment());
422 else 484 break;
423 pos_y = m_win->getYFrame() + m_win->getHeight() + 485 case PBOTTOM:
424 m_win->getScreen()->getBorderWidth2x(); 486 pos_y = setPositionShadingHelper(m_win->isShaded());
425 487 pos_x = setPositionTBAlignHelper(
426 } else if (m_win->getScreen()->getTabPlacement() == PLEFT) { 488 m_win->getScreen()->getTabAlignment());
489 break;
490 case PLEFT:
427 pos_x = m_win->getXFrame() - m_size_w; 491 pos_x = m_win->getXFrame() - m_size_w;
428 492 pos_y = setPositionLRAlignHelper(
429 } else if (m_win->getScreen()->getTabPlacement() == PRIGHT) { 493 m_win->getScreen()->getTabAlignment());
430 pos_x = m_win->getXFrame() + m_win->getWidth() + 494 break;
431 m_win->getScreen()->getBorderWidth2x(); 495 case PRIGHT:
432 } 496 pos_x = m_win->getXFrame() + m_win->getWidth() +
433 497 m_win->getScreen()->getBorderWidth2x();
434 //Tab alignment 498 pos_y = setPositionLRAlignHelper(
435 if (m_win->getScreen()->getTabPlacement() == PTOP || 499 m_win->getScreen()->getTabAlignment());
436 m_win->getScreen()->getTabPlacement() == PBOTTOM || 500 break;
437 m_win->isShaded()) { 501 default:
438 switch(m_win->getScreen()->getTabAlignment()) { 502 if(m_win->isShaded()) {
439 case ARELATIVE: 503 pos_y = setPositionShadingHelper(true);
440 case ALEFT: 504 pos_x = setPositionTBAlignHelper(
441 pos_x = m_win->getXFrame(); 505 m_win->getScreen()->getTabAlignment());
442 break; 506 } else {
443 case ACENTER: 507 setPositionShadingHelper(false);
444 pos_x = calcCenterXPos();
445 break;
446 case ARIGHT:
447 pos_x = m_win->getXFrame() + m_win->getWidth() +
448 m_win->getScreen()->getBorderWidth2x() - m_size_w;
449 break;
450 }
451 } else { //PLeft |�PRight
452 switch(m_win->getScreen()->getTabAlignment()) {
453 case ALEFT:
454 pos_y = m_win->getYFrame() - m_size_h + m_win->getHeight() +
455 m_win->getScreen()->getBorderWidth2x();
456 break;
457 case ACENTER:
458 pos_y = calcCenterYPos();
459 break;
460 case ARELATIVE:
461 case ARIGHT:
462 pos_y = m_win->getYFrame();
463 break;
464 } 508 }
509 break;
465 } 510 }
466 511
467 for (first = getFirst(this); 512 for (tab = getFirst(this);
468 first!=0; 513 tab!=0;
469 pos_x += first->m_inc_x, pos_y += first->m_inc_y, 514 pos_x += tab->m_inc_x, pos_y += tab->m_inc_y,
470 first = first->m_next){ 515 tab = tab->m_next){
471 516
472 XMoveWindow(m_display, first->m_tabwin, pos_x, pos_y); 517 XMoveWindow(m_display, tab->m_tabwin, pos_x, pos_y);
473 518
474 //dont move fluxboxwindow if the itterator = this 519 //dont move FluxboxWindow if the iterator = this
475 if (first!=this) { 520 if (tab!=this) {
476 first->m_win->configure(m_win->getXFrame(), m_win->getYFrame(), 521 tab->m_win->configure(m_win->getXFrame(), m_win->getYFrame(),
477 m_win->getWidth(), m_win->getHeight()); 522 m_win->getWidth(), m_win->getHeight());
478 } 523 }
479 } 524 }
480 525
481 m_stoptabs = false; 526 m_stoptabs = false;//thaw tablist
482} 527}
483 528
484//------------- calcIncrease ---------------- 529//------------- calcIncrease ----------------
@@ -490,7 +535,7 @@ void Tab::calcIncrease(void) {
490 cerr << "Calculating tab increase" << endl; 535 cerr << "Calculating tab increase" << endl;
491 #endif // DEBUG 536 #endif // DEBUG
492 537
493 Tab *first; 538 Tab *tab;
494 int inc_x = 0, inc_y = 0; 539 int inc_x = 0, inc_y = 0;
495 unsigned int tabs = 0, i = 0; 540 unsigned int tabs = 0, i = 0;
496 541
@@ -512,6 +557,8 @@ void Tab::calcIncrease(void) {
512 case ARELATIVE: 557 case ARELATIVE:
513 inc_x = calcRelativeWidth(); 558 inc_x = calcRelativeWidth();
514 break; 559 break;
560 default:
561 break;
515 } 562 }
516 } else if (m_win->getScreen()->getTabPlacement() == PLEFT || 563 } else if (m_win->getScreen()->getTabPlacement() == PLEFT ||
517 m_win->getScreen()->getTabPlacement() == PRIGHT) { 564 m_win->getScreen()->getTabPlacement() == PRIGHT) {
@@ -530,12 +577,14 @@ void Tab::calcIncrease(void) {
530 case ARELATIVE: 577 case ARELATIVE:
531 inc_y = calcRelativeHeight(); 578 inc_y = calcRelativeHeight();
532 break; 579 break;
580 default:
581 break;
533 } 582 }
534 } 583 }
535 584
536 for (first = getFirst(this); first!=0; first = first->m_next, tabs++); 585 for (tab = getFirst(this); tab!=0; tab = tab->m_next, tabs++);
537 586
538 for (first = getFirst(this); first!=0; first = first->m_next, i++){ 587 for (tab = getFirst(this); tab!=0; tab = tab->m_next, i++){
539 588
540 //TODO: move this out from here? 589 //TODO: move this out from here?
541 if ((m_win->getScreen()->getTabPlacement() == PTOP || 590 if ((m_win->getScreen()->getTabPlacement() == PTOP ||
@@ -546,30 +595,30 @@ void Tab::calcIncrease(void) {
546 m_win->getScreen()->getBorderWidth2x()) % tabs) || 595 m_win->getScreen()->getBorderWidth2x()) % tabs) ||
547 i >= ((m_win->getWidth() + 596 i >= ((m_win->getWidth() +
548 m_win->getScreen()->getBorderWidth2x()) % tabs)) { 597 m_win->getScreen()->getBorderWidth2x()) % tabs)) {
549 first->setTabWidth(inc_x); 598 tab->setTabWidth(inc_x);
550 first->m_inc_x = inc_x; 599 tab->m_inc_x = inc_x;
551 } else { // adding 1 extra pixel to get tabs like win width 600 } else { // adding 1 extra pixel to get tabs like win width
552 first->setTabWidth(inc_x + 1); 601 tab->setTabWidth(inc_x + 1);
553 first->m_inc_x = inc_x + 1; 602 tab->m_inc_x = inc_x + 1;
554 } 603 }
555 first->m_inc_y = inc_y; 604 tab->m_inc_y = inc_y;
556 } else if (m_win->getScreen()->getTabAlignment() == ARELATIVE) { 605 } else if (m_win->getScreen()->getTabAlignment() == ARELATIVE) {
557 if (!((m_win->getHeight() + 606 if (!((m_win->getHeight() +
558 m_win->getScreen()->getBorderWidth2x()) % tabs) || 607 m_win->getScreen()->getBorderWidth2x()) % tabs) ||
559 i >= ((m_win->getHeight() + 608 i >= ((m_win->getHeight() +
560 m_win->getScreen()->getBorderWidth2x()) % tabs)) { 609 m_win->getScreen()->getBorderWidth2x()) % tabs)) {
561 610
562 first->setTabHeight(inc_y); 611 tab->setTabHeight(inc_y);
563 first->m_inc_y = inc_y; 612 tab->m_inc_y = inc_y;
564 } else { 613 } else {
565 // adding 1 extra pixel to get tabs match window width 614 // adding 1 extra pixel to get tabs match window width
566 first->setTabHeight(inc_y + 1); 615 tab->setTabHeight(inc_y + 1);
567 first->m_inc_y = inc_y + 1; 616 tab->m_inc_y = inc_y + 1;
568 } 617 }
569 first->m_inc_x = inc_x; 618 tab->m_inc_x = inc_x;
570 } else { // non relative modes 619 } else { // non relative modes
571 first->m_inc_x = inc_x; 620 tab->m_inc_x = inc_x;
572 first->m_inc_y = inc_y; 621 tab->m_inc_y = inc_y;
573 } 622 }
574 } 623 }
575} 624}
@@ -617,13 +666,11 @@ void Tab::buttonReleaseEvent(XButtonEvent *be) {
617 m_win->getScreen()->getRootWindow(), 666 m_win->getScreen()->getRootWindow(),
618 be->x_root, be->y_root, &dest_x, &dest_y, &child)) { 667 be->x_root, be->y_root, &dest_x, &dest_y, &child)) {
619 668
620 Tab *tab = 0; 669 Tab *tab = Fluxbox::instance()->searchTab(child);
621 FluxboxWindow *win = 0; 670 FluxboxWindow *win = Fluxbox::instance()->searchWindow(child);
622 //search tablist for a tabwindow 671 //search tablist for a tabwindow
623 if (((tab = Fluxbox::instance()->searchTab(child))!=0) || 672 if ( (tab!=0) || (m_win->getScreen()->isSloppyWindowGrouping() &&
624 (m_win->getScreen()->isSloppyWindowGrouping() && 673 (win!=0) && (tab = win->getTab())!=0)) {
625 ((win = Fluxbox::instance()->searchWindow(child))!=0) &&
626 (tab = win->getTab())!=0)) {
627 674
628 if (tab == this) // inserting ourself to ourself causes a disconnect 675 if (tab == this) // inserting ourself to ourself causes a disconnect
629 return; 676 return;
@@ -639,7 +686,7 @@ void Tab::buttonReleaseEvent(XButtonEvent *be) {
639 } else { 686 } else {
640 disconnect(); 687 disconnect();
641 688
642 // convinience 689 // convenience
643 unsigned int placement = m_win->getScreen()->getTabPlacement(); 690 unsigned int placement = m_win->getScreen()->getTabPlacement();
644 691
645 // (ab)using dest_x and dest_y 692 // (ab)using dest_x and dest_y
@@ -661,6 +708,8 @@ void Tab::buttonReleaseEvent(XButtonEvent *be) {
661 case ARIGHT: 708 case ARIGHT:
662 dest_x -= m_win->getWidth() - m_size_w; 709 dest_x -= m_win->getWidth() - m_size_w;
663 break; 710 break;
711 default:
712 break;
664 } 713 }
665 714
666 } else { // PLEFT & PRIGHT 715 } else { // PLEFT & PRIGHT
@@ -674,6 +723,8 @@ void Tab::buttonReleaseEvent(XButtonEvent *be) {
674 case ALEFT: 723 case ALEFT:
675 dest_y -= m_win->getHeight() - m_size_h; 724 dest_y -= m_win->getHeight() - m_size_h;
676 break; 725 break;
726 default:
727 break;
677 } 728 }
678 } 729 }
679 //TODO: this causes an calculate increase event, even if we 730 //TODO: this causes an calculate increase event, even if we
@@ -979,7 +1030,7 @@ void Tab::setTabHeight(unsigned int h) {
979// --------------------------------------- 1030// ---------------------------------------
980void Tab::resizeGroup(void) { 1031void Tab::resizeGroup(void) {
981 #ifdef DEBUG 1032 #ifdef DEBUG
982 cerr << "Resising group" << endl; 1033 cerr <<__FILE__<<"("<<__LINE__<<"): Resizing group"<<endl;
983 #endif //DEBUG 1034 #endif //DEBUG
984 Tab *first; 1035 Tab *first;
985 for (first = getFirst(this); first != 0; first = first->m_next) { 1036 for (first = getFirst(this); first != 0; first = first->m_next) {