[Kst] [Bug 87146] Kst sometimes does not save plots in new windows
Rick Chern
rchern at interchange.ubc.ca
Mon Aug 16 18:42:49 CEST 2004
------- You are receiving this mail because: -------
You are the assignee for the bug, or are watching the assignee.
http://bugs.kde.org/show_bug.cgi?id=87146
rchern interchange ubc ca changed:
What |Removed |Added
----------------------------------------------------------------------------
Status|NEW |RESOLVED
Resolution| |FIXED
------- Additional Comments From rchern interchange ubc ca 2004-08-16 18:42 -------
CVS commit by rchern:
Make sure checks for duplicate plot names are done for both new and edit plots.
CCMAIL: 87146-done bugs kde org
M +39 -24 kstplotdialog_i.cpp 1.76
M +1 -1 kstplotdialog_i.h 1.30
--- kdeextragear-2/kst/kst/kstplotdialog_i.cpp #1.75:1.76
@ -529,29 +529,8 @ void KstPlotDialogI::new_I() {
}
- KstApp *app = KstApp::inst();
- KMdiIterator<KMdiChildView*> *iter;
- QString name = Name->text();
- //check the name
- KstViewObjectPtr rc;
- iter = app->createIterator();
- while (iter->currentItem()) {
- KMdiChildView *childview = iter->currentItem();
- KstViewWindow *viewwindow = dynamic_cast<KstViewWindow*>(childview);
- if (viewwindow) {
- rc = viewwindow->view()->findChild(name);
- if (rc) {
- QString message = i18n("Could not create a new plot.\n"
- "%1: not a unique plot name.\n"
- "Change it to a unique name.").arg(Name->text());
-
- KMessageBox::sorry(this, message);
- Name->setFocus();
- app->deleteIterator(iter);
+ //check plot name
+ if (!checkPlotName()) {
return;
}
- }
- iter->next();
- }
- app->deleteIterator(iter);
Kst2DPlotPtr plot = static_cast<KstViewWindow*>(c)->view()->createPlot<Kst2DPlot>(Name->text());
@ -611,4 +590,11 @ void KstPlotDialogI::edit_I() {
}
+ //check the plot name
+ if (Name->text() != Select->currentText()) {
+ if (!checkPlotName()) {
+ return;
+ }
+ }
+
KMdiChildView *c = KstApp::inst()->findWindow(_window->currentText());
if (!c) {
@ -1199,4 +1185,33 @ void KstPlotDialogI::newWindow() {
}
+bool KstPlotDialogI::checkPlotName() {
+ KstApp *app = KstApp::inst();
+ KMdiIterator<KMdiChildView*> *iter;
+ QString name = Name->text();
+ //check the name
+ KstViewObjectPtr rc;
+ iter = app->createIterator();
+ while (iter->currentItem()) {
+ KMdiChildView *childview = iter->currentItem();
+ KstViewWindow *viewwindow = dynamic_cast<KstViewWindow*>(childview);
+ if (viewwindow) {
+ rc = viewwindow->view()->findChild(name);
+ if (rc) {
+ QString message = i18n("Could not create a new plot.\n"
+ "%1: not a unique plot name.\n"
+ "Change it to a unique name.").arg(Name->text());
+
+ KMessageBox::sorry(this, message);
+ Name->setFocus();
+ app->deleteIterator(iter);
+ return false;
+ }
+ }
+ iter->next();
+ }
+ app->deleteIterator(iter);
+ return true;
+}
+
#include "kstplotdialog_i.moc"
// vim: et ts=2 sw=2
--- kdeextragear-2/kst/kst/kstplotdialog_i.h #1.29:1.30
@ -103,5 +103,5 @ class KstPlotDialogI : public KstPlotDia
private:
void fill2DPlotList(Kst2DPlotList& plots);
-
+ bool checkPlotName();
KstDoc *doc;
KstLabel *SampleLabel;
More information about the Kst
mailing list