diff options
author | Markus Mohrhard <markus.mohrhard@googlemail.com> | 2011-09-23 22:49:52 +0200 |
---|---|---|
committer | Markus Mohrhard <markus.mohrhard@googlemail.com> | 2011-09-24 03:52:33 +0200 |
commit | b7b14465204efe248cdf1e4657813e1a1192cca0 (patch) | |
tree | 63a61c320703e7b7e14f81f2d4712ad958621521 /sc | |
parent | 24f4f5bc7a68a3375f655ec3f4b9f3313c4609b2 (diff) |
fix crash, various button problems, memory leak
Diffstat (limited to 'sc')
-rw-r--r-- | sc/source/ui/namedlg/namedlg.cxx | 32 |
1 files changed, 30 insertions, 2 deletions
diff --git a/sc/source/ui/namedlg/namedlg.cxx b/sc/source/ui/namedlg/namedlg.cxx index 4bbb90b2d7bf..e2ab1332b973 100644 --- a/sc/source/ui/namedlg/namedlg.cxx +++ b/sc/source/ui/namedlg/namedlg.cxx @@ -297,6 +297,11 @@ ScNameDlg::~ScNameDlg() { delete mpRangeManagerTable; //need to delete undo stack here + while (!maUndoStack.empty()) + { + delete maUndoStack.top(); + maUndoStack.pop(); + } } void ScNameDlg::Init() @@ -404,6 +409,19 @@ void ScNameDlg::UpdateNames() aBtnBack.Enable(); else aBtnBack.Disable(); + + ScRangeNameLine aLine; + mpRangeManagerTable->GetCurrentLine(aLine); + if (aLine.aName.getLength()) + { + aBtnDelete.Enable(); + aBtnModify.Enable(); + } + else + { + aBtnDelete.Disable(); + aBtnModify.Disable(); + } } void ScNameDlg::CalcCurTableAssign( String& aAssign, ScRangeData* pRangeData ) @@ -469,7 +487,6 @@ bool ScNameDlg::AddPushed() { maEdName.SetText(EMPTY_STRING); aBtnAdd.Disable(); - aBtnDelete.Disable(); maUndoStack.push( new ScNameManagerUndoAdd( pRangeName, new ScRangeData(*pNewEntry) )); UpdateNames(); } @@ -536,8 +553,15 @@ void ScNameDlg::NameModified() aBtnAdd.Disable(); } else + { aBtnAdd.Enable(); - aBtnModify.Enable(); + } + ScRangeNameLine aLine; + mpRangeManagerTable->GetCurrentLine(aLine); + if (aLine.aName.getLength()) + aBtnModify.Enable(); + else + aBtnModify.Disable(); } } @@ -549,12 +573,14 @@ void ScNameDlg::SelectionChanged() maEdName.SetText(aLine.aName); maLbScope.SelectEntry(aLine.aScope); ShowOptions(aLine); + aBtnDelete.Enable(); } void ScNameDlg::BackPushed() { ScNameManagerUndo* aUndo = maUndoStack.top(); aUndo->Undo(); + delete aUndo; maUndoStack.pop(); if (maUndoStack.empty()) { @@ -591,6 +617,8 @@ void ScNameDlg::ModifiedPushed() ScRangeNameLine aLine; mpRangeManagerTable->GetCurrentLine(aLine); + if (!aLine.aName.getLength()) //no line selected + return; ScRangeName* pOldRangeName = GetRangeName(aLine.aScope, mpDoc); |