diff options
author | Clinton Stimpson <clinton@elemtech.com> | 2007-11-12 22:41:15 (GMT) |
---|---|---|
committer | Clinton Stimpson <clinton@elemtech.com> | 2007-11-12 22:41:15 (GMT) |
commit | fcc62c6d0dc4dd514a0588ff21339d39b7e641f2 (patch) | |
tree | 77e907941122b1172e6901b5a23e39e280e73eaa | |
parent | f97dddf0eecfd0b4a50166420ae8aabcb5571027 (diff) | |
download | CMake-fcc62c6d0dc4dd514a0588ff21339d39b7e641f2.zip CMake-fcc62c6d0dc4dd514a0588ff21339d39b7e641f2.tar.gz CMake-fcc62c6d0dc4dd514a0588ff21339d39b7e641f2.tar.bz2 |
BUG: Fix pause at shutdown.
ENH: Remove interrupt button and make configure/generate turn to stop during runs.
ENH: Add text to remove cache entry button.
-rw-r--r-- | Source/QtDialog/CMakeSetupDialog.cxx | 160 | ||||
-rw-r--r-- | Source/QtDialog/CMakeSetupDialog.h | 7 | ||||
-rw-r--r-- | Source/QtDialog/CMakeSetupDialog.ui | 142 |
3 files changed, 177 insertions, 132 deletions
diff --git a/Source/QtDialog/CMakeSetupDialog.cxx b/Source/QtDialog/CMakeSetupDialog.cxx index b3a093a..3eb3ef1 100644 --- a/Source/QtDialog/CMakeSetupDialog.cxx +++ b/Source/QtDialog/CMakeSetupDialog.cxx @@ -66,7 +66,7 @@ void QCMakeThread::run() } CMakeSetupDialog::CMakeSetupDialog() - : ExitAfterGenerate(true), CacheModified(false) + : ExitAfterGenerate(true), CacheModified(false), CurrentState(Interrupting) { // create the GUI QSettings settings; @@ -81,9 +81,6 @@ CMakeSetupDialog::CMakeSetupDialog() this->Splitter->setStretchFactor(1, 1); this->setCentralWidget(cont); this->ProgressBar->reset(); - this->InterruptButton->setIcon( - this->style()->standardPixmap(QStyle::SP_DialogCancelButton)); - this->InterruptButton->setEnabled(false); this->RemoveEntry->setEnabled(false); QMenu* FileMenu = this->menuBar()->addMenu(tr("&File")); @@ -104,15 +101,6 @@ CMakeSetupDialog::CMakeSetupDialog() this->GenerateAction = ToolsMenu->addAction(tr("&Generate")); QObject::connect(this->GenerateAction, SIGNAL(triggered(bool)), this, SLOT(doGenerate())); - /* - QMenu* OptionsMenu = this->menuBar()->addMenu(tr("&Options")); - QAction* a = OptionsMenu->addAction(tr("Exit after Generation")); - a->setCheckable(true); - this->ExitAfterGenerate = settings.value("ExitAfterGenerate", true).toBool(); - a->setChecked(this->ExitAfterGenerate); - QObject::connect(a, SIGNAL(triggered(bool)), - this, SLOT(setExitAfterGenerate(bool))); - */ QMenu* HelpMenu = this->menuBar()->addMenu(tr("&Help")); QAction* a = HelpMenu->addAction(tr("About")); @@ -122,8 +110,6 @@ CMakeSetupDialog::CMakeSetupDialog() QObject::connect(a, SIGNAL(triggered(bool)), this, SLOT(doHelp())); - this->setGenerateEnabled(false); - this->setAcceptDrops(true); // start the cmake worker thread @@ -131,6 +117,8 @@ CMakeSetupDialog::CMakeSetupDialog() QObject::connect(this->CMakeThread, SIGNAL(cmakeInitialized()), this, SLOT(initialize()), Qt::QueuedConnection); this->CMakeThread->start(); + + this->enterState(ReadyConfigure); } void CMakeSetupDialog::initialize() @@ -175,9 +163,6 @@ void CMakeSetupDialog::initialize() SIGNAL(errorMessage(QString)), this, SLOT(error(QString))); - QObject::connect(this->InterruptButton, SIGNAL(clicked(bool)), - this, SLOT(doInterrupt())); - QObject::connect(this->CMakeThread->cmakeInstance(), SIGNAL(outputMessage(QString)), this->Output, SLOT(append(QString))); @@ -234,6 +219,13 @@ CMakeSetupDialog::~CMakeSetupDialog() void CMakeSetupDialog::doConfigure() { + if(this->CurrentState == Configuring) + { + // stop configure + doInterrupt(); + return; + } + QString bindir = this->CMakeThread->cmakeInstance()->binaryDirectory(); QDir dir(bindir); if(!dir.exists()) @@ -262,9 +254,7 @@ void CMakeSetupDialog::doConfigure() // remember path this->addBinaryPath(dir.absolutePath()); - this->InterruptButton->setEnabled(true); - this->setEnabledState(false); - this->setGenerateEnabled(false); + this->enterState(Configuring); this->Output->clear(); QMetaObject::invokeMethod(this->CMakeThread->cmakeInstance(), @@ -277,47 +267,44 @@ void CMakeSetupDialog::doConfigure() void CMakeSetupDialog::finishConfigure(int err) { - this->InterruptButton->setEnabled(false); - this->setEnabledState(true); - this->ProgressBar->reset(); + if(0 == err && 0 == this->CacheValues->cacheModel()->newCount()) + { + this->enterState(ReadyGenerate); + } + else + { + this->enterState(ReadyConfigure); + this->CacheValues->scrollToTop(); + } + if(err != 0) { QMessageBox::critical(this, tr("Error"), tr("Error in configuration process, project files may be invalid"), QMessageBox::Ok); } - else if(0 == this->CacheValues->cacheModel()->newCount()) - { - this->setGenerateEnabled(true); - } } void CMakeSetupDialog::finishGenerate(int err) { - this->InterruptButton->setEnabled(false); - this->setEnabledState(true); - this->setGenerateEnabled(true); - this->ProgressBar->reset(); + this->enterState(ReadyGenerate); if(err != 0) { QMessageBox::critical(this, tr("Error"), tr("Error in generation process, project files may be invalid"), QMessageBox::Ok); } - /* - else if(this->ExitAfterGenerate) - { - QApplication::quit(); - } - */ } void CMakeSetupDialog::doGenerate() { - this->InterruptButton->setEnabled(true); - this->setEnabledState(false); - this->setGenerateEnabled(false); - this->Output->clear(); + if(this->CurrentState == Generating) + { + // stop generate + doInterrupt(); + return; + } + this->enterState(Generating); QMetaObject::invokeMethod(this->CMakeThread->cmakeInstance(), "generate", Qt::QueuedConnection); } @@ -325,7 +312,7 @@ void CMakeSetupDialog::doGenerate() void CMakeSetupDialog::closeEvent(QCloseEvent* e) { // don't close if we're busy - if(this->InterruptButton->isEnabled()) + if(this->CurrentState == Configuring || this->CurrentState == Generating) { e->ignore(); } @@ -382,7 +369,7 @@ void CMakeSetupDialog::doHelp() void CMakeSetupDialog::doInterrupt() { - this->InterruptButton->setEnabled(false); + this->enterState(Interrupting); QMetaObject::invokeMethod(this->CMakeThread->cmakeInstance(), "interrupt", Qt::QueuedConnection); } @@ -458,7 +445,6 @@ void CMakeSetupDialog::setEnabledState(bool enabled) this->BrowseSourceDirectoryButton->setEnabled(enabled); this->BinaryDirectory->setEnabled(enabled); this->BrowseBinaryDirectoryButton->setEnabled(enabled); - this->ConfigureButton->setEnabled(enabled); this->ReloadCacheAction->setEnabled(enabled); this->DeleteCacheAction->setEnabled(enabled); this->ExitAction->setEnabled(enabled); @@ -549,17 +535,6 @@ void CMakeSetupDialog::doAbout() void CMakeSetupDialog::setExitAfterGenerate(bool b) { this->ExitAfterGenerate = b; - /* - QSettings settings; - settings.beginGroup("Settings/StartPath"); - settings.setValue("ExitAfterGenerate", b); - */ -} - -void CMakeSetupDialog::setGenerateEnabled(bool b) -{ - this->GenerateButton->setEnabled(b); - this->GenerateAction->setEnabled(b); } void CMakeSetupDialog::addBinaryPath(const QString& path) @@ -586,7 +561,8 @@ void CMakeSetupDialog::addBinaryPath(const QString& path) void CMakeSetupDialog::dragEnterEvent(QDragEnterEvent* e) { - if(!this->ConfigureButton->isEnabled()) + if(this->CurrentState != ReadyConfigure || + this->CurrentState != ReadyGenerate) { e->ignore(); return; @@ -609,10 +585,12 @@ void CMakeSetupDialog::dragEnterEvent(QDragEnterEvent* e) void CMakeSetupDialog::dropEvent(QDropEvent* e) { - if(!this->ConfigureButton->isEnabled()) + if(this->CurrentState != ReadyConfigure || + this->CurrentState != ReadyGenerate) { return; } + const QMimeData* dat = e->mimeData(); QList<QUrl> urls = dat->urls(); QString file = urls.count() ? urls[0].toLocalFile() : QString(); @@ -672,7 +650,7 @@ void CMakeSetupDialog::saveBuildPaths(const QStringList& paths) void CMakeSetupDialog::setCacheModified() { this->CacheModified = true; - this->setGenerateEnabled(false); + this->enterState(ReadyConfigure); } void CMakeSetupDialog::removeSelectedCacheEntries() @@ -692,7 +670,9 @@ void CMakeSetupDialog::removeSelectedCacheEntries() void CMakeSetupDialog::selectionChanged() { QModelIndexList idxs = this->CacheValues->selectionModel()->selectedRows(); - if(idxs.count() && !this->InterruptButton->isEnabled()) + if(idxs.count() && + (this->CurrentState == ReadyConfigure || + this->CurrentState == ReadyGenerate) ) { this->RemoveEntry->setEnabled(true); } @@ -701,4 +681,64 @@ void CMakeSetupDialog::selectionChanged() this->RemoveEntry->setEnabled(false); } } + +void CMakeSetupDialog::enterState(CMakeSetupDialog::State s) +{ + if(s == this->CurrentState) + { + return; + } + + CMakeSetupDialog::State old = this->CurrentState; + this->CurrentState = s; + + if(s == Interrupting) + { + if(old == Configuring) + { + this->ConfigureButton->setEnabled(false); + } + if(old == Generating) + { + this->GenerateButton->setEnabled(false); + } + } + else if(s == Configuring) + { + this->Output->clear(); + this->setEnabledState(false); + this->GenerateButton->setEnabled(false); + this->GenerateAction->setEnabled(false); + this->ConfigureButton->setText(tr("Stop")); + } + else if(s == Generating) + { + this->Output->clear(); + this->setEnabledState(false); + this->ConfigureButton->setEnabled(false); + this->GenerateAction->setEnabled(false); + this->GenerateButton->setText(tr("Stop")); + } + else if(s == ReadyConfigure) + { + this->ProgressBar->reset(); + this->setEnabledState(true); + this->GenerateButton->setEnabled(false); + this->GenerateAction->setEnabled(false); + this->ConfigureButton->setEnabled(true); + this->ConfigureButton->setText(tr("Configure")); + this->GenerateButton->setText(tr("Generate")); + } + else if(s == ReadyGenerate) + { + this->ProgressBar->reset(); + this->setEnabledState(true); + this->GenerateButton->setEnabled(true); + this->GenerateAction->setEnabled(true); + this->ConfigureButton->setEnabled(true); + this->ConfigureButton->setText(tr("Configure")); + this->GenerateButton->setText(tr("Generate")); + } +} + diff --git a/Source/QtDialog/CMakeSetupDialog.h b/Source/QtDialog/CMakeSetupDialog.h index cf298f3..d8bea36 100644 --- a/Source/QtDialog/CMakeSetupDialog.h +++ b/Source/QtDialog/CMakeSetupDialog.h @@ -61,7 +61,6 @@ protected slots: void promptForGenerator(); void updateGeneratorLabel(const QString& gen); void setExitAfterGenerate(bool); - void setGenerateEnabled(bool); void addBinaryPath(const QString&); QStringList loadBuildPaths(); void saveBuildPaths(const QStringList&); @@ -72,6 +71,10 @@ protected slots: void selectionChanged(); protected: + + enum State { Interrupting, ReadyConfigure, ReadyGenerate, Configuring, Generating }; + void enterState(State s); + void closeEvent(QCloseEvent*); void dragEnterEvent(QDragEnterEvent*); void dropEvent(QDropEvent*); @@ -84,6 +87,8 @@ protected: QAction* ExitAction; QAction* ConfigureAction; QAction* GenerateAction; + State CurrentState; + }; // QCMake instance on a thread diff --git a/Source/QtDialog/CMakeSetupDialog.ui b/Source/QtDialog/CMakeSetupDialog.ui index b0288b3..d32b7a5 100644 --- a/Source/QtDialog/CMakeSetupDialog.ui +++ b/Source/QtDialog/CMakeSetupDialog.ui @@ -70,11 +70,11 @@ <property name="frameShadow" > <enum>QFrame::Raised</enum> </property> - <layout class="QGridLayout" > + <layout class="QVBoxLayout" > <property name="margin" > <number>0</number> </property> - <item row="0" column="0" colspan="6" > + <item> <layout class="QHBoxLayout" > <item> <widget class="QLabel" name="label_4" > @@ -128,16 +128,19 @@ <string>Remove Selected Entries</string> </property> <property name="text" > - <string/> + <string>Remove Entry</string> </property> <property name="icon" > <iconset resource="CMakeSetup.qrc" >:/Icons/Delete16.png</iconset> </property> + <property name="toolButtonStyle" > + <enum>Qt::ToolButtonTextBesideIcon</enum> + </property> </widget> </item> </layout> </item> - <item row="1" column="0" colspan="6" > + <item> <widget class="QCMakeCacheView" name="CacheValues" > <property name="alternatingRowColors" > <bool>true</bool> @@ -150,73 +153,7 @@ </property> </widget> </item> - <item row="3" column="0" > - <widget class="QPushButton" name="ConfigureButton" > - <property name="text" > - <string>Configure</string> - </property> - </widget> - </item> - <item row="3" column="1" > - <widget class="QPushButton" name="GenerateButton" > - <property name="text" > - <string>Generate</string> - </property> - </widget> - </item> - <item row="3" column="2" > - <widget class="QLabel" name="Generator" > - <property name="text" > - <string>Current Generator:</string> - </property> - </widget> - </item> - <item row="3" column="3" > - <spacer> - <property name="orientation" > - <enum>Qt::Horizontal</enum> - </property> - <property name="sizeType" > - <enum>QSizePolicy::Expanding</enum> - </property> - <property name="sizeHint" > - <size> - <width>121</width> - <height>27</height> - </size> - </property> - </spacer> - </item> - <item row="3" column="5" > - <widget class="QProgressBar" name="ProgressBar" > - <property name="minimum" > - <number>0</number> - </property> - <property name="maximum" > - <number>100</number> - </property> - <property name="value" > - <number>0</number> - </property> - <property name="textVisible" > - <bool>false</bool> - </property> - <property name="orientation" > - <enum>Qt::Horizontal</enum> - </property> - <property name="textDirection" > - <enum>QProgressBar::BottomToTop</enum> - </property> - </widget> - </item> - <item row="3" column="4" > - <widget class="QToolButton" name="InterruptButton" > - <property name="text" > - <string>...</string> - </property> - </widget> - </item> - <item row="2" column="0" colspan="6" > + <item> <widget class="QLabel" name="label_3" > <property name="text" > <string>Press Configure to update and display new values in red, then press Generate to generate selected build files.</string> @@ -229,6 +166,69 @@ </property> </widget> </item> + <item> + <layout class="QHBoxLayout" > + <item> + <widget class="QPushButton" name="ConfigureButton" > + <property name="text" > + <string>Configure</string> + </property> + </widget> + </item> + <item> + <widget class="QPushButton" name="GenerateButton" > + <property name="text" > + <string>Generate</string> + </property> + </widget> + </item> + <item> + <widget class="QLabel" name="Generator" > + <property name="text" > + <string>Current Generator:</string> + </property> + </widget> + </item> + <item> + <spacer> + <property name="orientation" > + <enum>Qt::Horizontal</enum> + </property> + <property name="sizeType" > + <enum>QSizePolicy::Expanding</enum> + </property> + <property name="sizeHint" > + <size> + <width>121</width> + <height>27</height> + </size> + </property> + </spacer> + </item> + <item> + <widget class="QProgressBar" name="ProgressBar" > + <property name="minimum" > + <number>0</number> + </property> + <property name="maximum" > + <number>100</number> + </property> + <property name="value" > + <number>0</number> + </property> + <property name="textVisible" > + <bool>false</bool> + </property> + <property name="orientation" > + <enum>Qt::Horizontal</enum> + </property> + <property name="textDirection" > + <enum>QProgressBar::BottomToTop</enum> + </property> + </widget> + </item> + </layout> + </item> </layout> </widget> <widget class="QTextEdit" name="Output" > |