diff --git a/kcmkwin/kwinrules/ruleslist.cpp b/kcmkwin/kwinrules/ruleslist.cpp index 7a8130a56a..b83a7f561c 100644 --- a/kcmkwin/kwinrules/ruleslist.cpp +++ b/kcmkwin/kwinrules/ruleslist.cpp @@ -18,6 +18,7 @@ #include "ruleslist.h" +#include #include #include #include @@ -32,10 +33,10 @@ KCMRulesList::KCMRulesList( QWidget* parent) : KCMRulesListBase( parent) { // connect both current/selected, so that current==selected (stupid QListBox :( ) - connect( rules_listbox, SIGNAL( currentChanged( Q3ListBoxItem* )), - SLOT( activeChanged( Q3ListBoxItem*))); - connect( rules_listbox, SIGNAL( selectionChanged( Q3ListBoxItem* )), - SLOT( activeChanged( Q3ListBoxItem*))); + connect( rules_listbox, SIGNAL( currentChanged( QListWidgetItem* )), + SLOT( activeChanged( QListWidgetItem*))); + connect( rules_listbox, SIGNAL( selectionChanged( QListWidgetItem* )), + SLOT( activeChanged( QListWidgetItem*))); connect( new_button, SIGNAL( clicked()), SLOT( newClicked())); connect( modify_button, SIGNAL( clicked()), @@ -46,7 +47,7 @@ KCMRulesList::KCMRulesList( QWidget* parent) SLOT( moveupClicked())); connect( movedown_button, SIGNAL( clicked()), SLOT( movedownClicked())); - connect( rules_listbox, SIGNAL( doubleClicked ( Q3ListBoxItem * ) ), + connect( rules_listbox, SIGNAL( doubleClicked ( QListWidgetItem * ) ), SLOT( modifyClicked())); load(); } @@ -60,14 +61,16 @@ KCMRulesList::~KCMRulesList() rules.clear(); } -void KCMRulesList::activeChanged( Q3ListBoxItem* item ) +void KCMRulesList::activeChanged( QListWidgetItem* item ) { + int itemRow = rules_listbox->row(item); + if( item != NULL ) - rules_listbox->setSelected( item, true ); // make current==selected + item->setSelected( true ); // make current==selected modify_button->setEnabled( item != NULL ); delete_button->setEnabled( item != NULL ); - moveup_button->setEnabled( item != NULL && item->prev() != NULL ); - movedown_button->setEnabled( item != NULL && item->next() != NULL ); + moveup_button->setEnabled( item != NULL && itemRow > 0 ); + movedown_button->setEnabled( item != NULL && itemRow < (rules_listbox->count()-1) ); } void KCMRulesList::newClicked() @@ -76,16 +79,16 @@ void KCMRulesList::newClicked() Rules* rule = dlg.edit( NULL, 0, false ); if( rule == NULL ) return; - int pos = rules_listbox->currentItem() + 1; - rules_listbox->insertItem( rule->description, pos ); - rules_listbox->setSelected( pos, true ); + int pos = rules_listbox->currentRow() + 1; + rules_listbox->insertItem( pos , rule->description ); + rules_listbox->item(pos)->setSelected( true ); rules.insert( rules.begin() + pos, rule ); emit changed( true ); } void KCMRulesList::modifyClicked() { - int pos = rules_listbox->currentItem(); + int pos = rules_listbox->currentRow(); if ( pos == -1 ) return; RulesDialog dlg; @@ -94,29 +97,29 @@ void KCMRulesList::modifyClicked() return; delete rules[ pos ]; rules[ pos ] = rule; - rules_listbox->changeItem( rule->description, pos ); + rules_listbox->item(pos)->setText( rule->description ); emit changed( true ); } void KCMRulesList::deleteClicked() { - int pos = rules_listbox->currentItem(); + int pos = rules_listbox->currentRow(); assert( pos != -1 ); - rules_listbox->removeItem( pos ); + delete rules_listbox->takeItem( pos ); rules.erase( rules.begin() + pos ); emit changed( true ); } void KCMRulesList::moveupClicked() { - int pos = rules_listbox->currentItem(); + int pos = rules_listbox->currentRow(); assert( pos != -1 ); if( pos > 0 ) { - QString txt = rules_listbox->text( pos ); - rules_listbox->removeItem( pos ); - rules_listbox->insertItem( txt, pos - 1 ); - rules_listbox->setSelected( pos - 1, true ); + QString txt = rules_listbox->item(pos)->text(); + delete rules_listbox->takeItem( pos ); + rules_listbox->insertItem( pos - 1 , txt ); + rules_listbox->item(pos-1)->setSelected( true ); Rules* rule = rules[ pos ]; rules[ pos ] = rules[ pos - 1 ]; rules[ pos - 1 ] = rule; @@ -126,14 +129,14 @@ void KCMRulesList::moveupClicked() void KCMRulesList::movedownClicked() { - int pos = rules_listbox->currentItem(); + int pos = rules_listbox->currentRow(); assert( pos != -1 ); if( pos < int( rules_listbox->count()) - 1 ) { - QString txt = rules_listbox->text( pos ); - rules_listbox->removeItem( pos ); - rules_listbox->insertItem( txt, pos + 1 ); - rules_listbox->setSelected( pos + 1, true ); + QString txt = rules_listbox->item(pos)->text(); + delete rules_listbox->takeItem( pos ); + rules_listbox->insertItem( pos + 1 , txt); + rules_listbox->item(pos+1)->setSelected( true ); Rules* rule = rules[ pos ]; rules[ pos ] = rules[ pos + 1 ]; rules[ pos + 1 ] = rule; @@ -160,10 +163,10 @@ void KCMRulesList::load() cfg.changeGroup( QString::number( i )); Rules* rule = new Rules( cfg ); rules.append( rule ); - rules_listbox->insertItem( rule->description ); + rules_listbox->addItem( rule->description ); } if( rules.count() > 0 ) - rules_listbox->setSelected( 0, true ); + rules_listbox->item(0)->setSelected( true ); else activeChanged( NULL ); } diff --git a/kcmkwin/kwinrules/ruleslist.h b/kcmkwin/kwinrules/ruleslist.h index 4ab3a43530..49f40221c7 100644 --- a/kcmkwin/kwinrules/ruleslist.h +++ b/kcmkwin/kwinrules/ruleslist.h @@ -26,7 +26,7 @@ #include "../../rules.h" -class Q3ListBoxItem; +class QListWidgetItem; namespace KWin { @@ -58,7 +58,7 @@ class KCMRulesList void deleteClicked(); void moveupClicked(); void movedownClicked(); - void activeChanged( Q3ListBoxItem* ); + void activeChanged( QListWidgetItem* ); private: QVector< Rules* > rules; }; diff --git a/kcmkwin/kwinrules/ruleslistbase.ui b/kcmkwin/kwinrules/ruleslistbase.ui index 2bd4cd1dce..68727970e5 100644 --- a/kcmkwin/kwinrules/ruleslistbase.ui +++ b/kcmkwin/kwinrules/ruleslistbase.ui @@ -17,7 +17,7 @@ 0 - + @@ -80,9 +80,9 @@ qPixmapFromMimeSource - K3ListBox - Q3ListBox -
k3listbox.h
+ KListWidget + QListWidget +
klistwidget.h
diff --git a/kcmkwin/kwinrules/ruleswidget.cpp b/kcmkwin/kwinrules/ruleswidget.cpp index bfc26aa2e5..fe4bab6b3e 100644 --- a/kcmkwin/kwinrules/ruleswidget.cpp +++ b/kcmkwin/kwinrules/ruleswidget.cpp @@ -383,16 +383,16 @@ void RulesWidget::setRules( Rules* rules ) role->setText( rules->windowrole ); role_match->setCurrentIndex( rules->windowrolematch ); roleMatchChanged(); - types->setSelected( 0, rules->types & NET::NormalMask ); - types->setSelected( 1, rules->types & NET::DialogMask ); - types->setSelected( 2, rules->types & NET::UtilityMask ); - types->setSelected( 3, rules->types & NET::DockMask ); - types->setSelected( 4, rules->types & NET::ToolbarMask ); - types->setSelected( 5, rules->types & NET::MenuMask ); - types->setSelected( 6, rules->types & NET::SplashMask ); - types->setSelected( 7, rules->types & NET::DesktopMask ); - types->setSelected( 8, rules->types & NET::OverrideMask ); - types->setSelected( 9, rules->types & NET::TopMenuMask ); + types->item(0)->setSelected( rules->types & NET::NormalMask ); + types->item(1)->setSelected( rules->types & NET::DialogMask ); + types->item(2)->setSelected( rules->types & NET::UtilityMask ); + types->item(3)->setSelected( rules->types & NET::DockMask ); + types->item(4)->setSelected( rules->types & NET::ToolbarMask ); + types->item(5)->setSelected( rules->types & NET::MenuMask ); + types->item(6)->setSelected( rules->types & NET::SplashMask ); + types->item(7)->setSelected( rules->types & NET::DesktopMask ); + types->item(8)->setSelected( rules->types & NET::OverrideMask ); + types->item(9)->setSelected( rules->types & NET::TopMenuMask ); title->setText( rules->title ); title_match->setCurrentIndex( rules->titlematch ); titleMatchChanged(); @@ -466,25 +466,25 @@ Rules* RulesWidget::rules() const rules->windowrolematch = static_cast< Rules::StringMatch >( role_match->currentIndex()); rules->types = 0; bool all_types = true; - for( unsigned int i = 0; + for( int i = 0; i < types->count(); ++i ) - if( !types->isSelected( i )) + if( !types->item(i)->isSelected()) all_types = false; if( all_types ) // if all types are selected, use AllTypesMask (for future expansion) rules->types = NET::AllTypesMask; else { - rules->types |= types->isSelected( 0 ) ? NET::NormalMask : 0; - rules->types |= types->isSelected( 1 ) ? NET::DialogMask : 0; - rules->types |= types->isSelected( 2 ) ? NET::UtilityMask : 0; - rules->types |= types->isSelected( 3 ) ? NET::DockMask : 0; - rules->types |= types->isSelected( 4 ) ? NET::ToolbarMask : 0; - rules->types |= types->isSelected( 5 ) ? NET::MenuMask : 0; - rules->types |= types->isSelected( 6 ) ? NET::SplashMask : 0; - rules->types |= types->isSelected( 7 ) ? NET::DesktopMask : 0; - rules->types |= types->isSelected( 8 ) ? NET::OverrideMask : 0; - rules->types |= types->isSelected( 9 ) ? NET::TopMenuMask : 0; + rules->types |= types->item(0)->isSelected() ? NET::NormalMask : 0; + rules->types |= types->item(1)->isSelected() ? NET::DialogMask : 0; + rules->types |= types->item(2)->isSelected() ? NET::UtilityMask : 0; + rules->types |= types->item(3)->isSelected() ? NET::DockMask : 0; + rules->types |= types->item(4)->isSelected() ? NET::ToolbarMask : 0; + rules->types |= types->item(5)->isSelected() ? NET::MenuMask : 0; + rules->types |= types->item(6)->isSelected() ? NET::SplashMask : 0; + rules->types |= types->item(7)->isSelected() ? NET::DesktopMask : 0; + rules->types |= types->item(8)->isSelected() ? NET::OverrideMask : 0; + rules->types |= types->item(9)->isSelected() ? NET::TopMenuMask : 0; } rules->title = title->text(); rules->titlematch = static_cast< Rules::StringMatch >( title_match->currentIndex()); @@ -567,19 +567,19 @@ void RulesWidget::detected( bool ok ) roleMatchChanged(); if( detect_dlg->selectedWholeApp()) { - for( unsigned int i = 0; + for( int i = 0; i < types->count(); ++i ) - types->setSelected( i, true ); + types->item(i)->setSelected( true ); } else { NET::WindowType type = detect_dlg->selectedType(); - for( unsigned int i = 0; + for( int i = 0; i < types->count(); ++i ) - types->setSelected( i, false ); - types->setSelected( typeToCombo( type ), true ); + types->item(i)->setSelected( false ); + types->item( typeToCombo(type) )->setSelected( true ); } title->setText( detect_dlg->selectedTitle()); title_match->setCurrentIndex( detect_dlg->titleMatch()); @@ -653,10 +653,10 @@ bool RulesWidget::finalCheck() description->setText( i18n( "Unnamed entry" )); } bool all_types = true; - for( unsigned int i = 0; + for( int i = 0; i < types->count(); ++i ) - if( !types->isSelected( i )) + if( !types->item(i)->isSelected()) all_types = false; if( wmclass_match->currentIndex() == Rules::UnimportantMatch && all_types ) { diff --git a/kcmkwin/kwinrules/ruleswidgetbase.ui b/kcmkwin/kwinrules/ruleswidgetbase.ui index 97b6084754..63ddebb263 100644 --- a/kcmkwin/kwinrules/ruleswidgetbase.ui +++ b/kcmkwin/kwinrules/ruleswidgetbase.ui @@ -329,7 +329,7 @@ types
- + Normal Window