summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Meeks <michael.meeks@suse.com>2013-03-27 16:45:05 +0000
committerMichael Meeks <michael.meeks@suse.com>2013-03-27 16:46:46 +0000
commit23c22d3da5349ba1242edaeecfa0cba97a92ac71 (patch)
tree82ff989f6c348cc1d3a6414c60a7351d6d239811
parent129836c99d860c6ee4eac5167fce0326ba03f42f (diff)
fdo#62094 - fix infinite loop in radio button group iteration.
Simplify the code too - we copy the vector anyway, so reversing it should be cheap. Change-Id: Ie655ba3044c7e0dd5a15b0e839a3712a32a1e298
-rw-r--r--vcl/source/window/dlgctrl.cxx47
1 files changed, 11 insertions, 36 deletions
diff --git a/vcl/source/window/dlgctrl.cxx b/vcl/source/window/dlgctrl.cxx
index 19d68a08fe06..fe7b0803c2a6 100644
--- a/vcl/source/window/dlgctrl.cxx
+++ b/vcl/source/window/dlgctrl.cxx
@@ -544,39 +544,14 @@ namespace
return (pWindow && isVisibleInLayout(pWindow) && isEnabledInLayout(pWindow) && pWindow->IsInputEnabled());
}
- bool backInGroup(std::vector<RadioButton*>::reverse_iterator aRevStart, std::vector<RadioButton*> &rGroup)
+ bool focusNextInGroup(std::vector<RadioButton*>::iterator aStart, std::vector<RadioButton*> &rGroup)
{
- std::vector<RadioButton*>::reverse_iterator aI(aRevStart);
- while (aI != rGroup.rend())
- {
- Window *pWindow = *aI;
-
- if (isSuitableDestination(pWindow))
- {
- pWindow->ImplControlFocus( GETFOCUS_CURSOR | GETFOCUS_BACKWARD );
- return true;
- }
- }
-
- aI = rGroup.rbegin();
- while (aI != aRevStart)
- {
- Window *pWindow = *aI;
-
- if (isSuitableDestination(pWindow))
- {
- pWindow->ImplControlFocus( GETFOCUS_CURSOR | GETFOCUS_BACKWARD );
- return true;
- }
- }
+ std::vector<RadioButton*>::iterator aI(aStart);
- return false;
- }
+ if (aStart != rGroup.end())
+ ++aI;
- bool forwardInGroup(std::vector<RadioButton*>::iterator aStart, std::vector<RadioButton*> &rGroup)
- {
- std::vector<RadioButton*>::iterator aI(aStart);
- while (++aI != rGroup.end())
+ for (; aI != rGroup.end(); ++aI)
{
Window *pWindow = *aI;
@@ -587,8 +562,7 @@ namespace
}
}
- aI = rGroup.begin();
- while (aI != aStart)
+ for (aI = rGroup.begin(); aI != aStart; ++aI)
{
Window *pWindow = *aI;
@@ -597,6 +571,7 @@ namespace
pWindow->ImplControlFocus( GETFOCUS_CURSOR | GETFOCUS_FORWARD );
return true;
}
+ aI++;
}
return false;
@@ -609,14 +584,14 @@ namespace
if (aGroup.size() == 1) //only one button in group
return false;
+ if (bBackward)
+ std::reverse(aGroup.begin(), aGroup.end());
+
std::vector<RadioButton*>::iterator aStart(std::find(aGroup.begin(), aGroup.end(), pSourceWindow));
assert(aStart != aGroup.end());
- if (bBackward)
- return backInGroup(std::vector<RadioButton*>::reverse_iterator(aStart), aGroup);
- else
- return forwardInGroup(aStart, aGroup);
+ return focusNextInGroup(aStart, aGroup);
}
}