summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorArnaud Versini <arnaud.versini@gmail.com>2018-04-29 20:15:02 +0200
committerNoel Grandin <noel.grandin@collabora.co.uk>2018-04-29 22:11:46 +0200
commit9f3e8cb4af359c387d575d34b9a3d59db7dbe3b0 (patch)
tree7ae396465360272a71bad60be080b1e8a662ad8f
parent5b77e676f57bab2de61dc430e8725c447b73354a (diff)
accessibility : remove useless guards and optimisze a litle
Change-Id: I1162f364d948b73b943fb973222103772fffddc3 Reviewed-on: https://gerrit.libreoffice.org/53629 Tested-by: Jenkins <ci@libreoffice.org> Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
-rw-r--r--accessibility/source/standard/vclxaccessibletoolbox.cxx28
1 files changed, 20 insertions, 8 deletions
diff --git a/accessibility/source/standard/vclxaccessibletoolbox.cxx b/accessibility/source/standard/vclxaccessibletoolbox.cxx
index 7f744038d505..c9258d402be8 100644
--- a/accessibility/source/standard/vclxaccessibletoolbox.cxx
+++ b/accessibility/source/standard/vclxaccessibletoolbox.cxx
@@ -839,14 +839,20 @@ sal_Int32 VCLXAccessibleToolBox::getSelectedAccessibleChildCount( )
OExternalLockGuard aGuard( this );
sal_Int32 nRet = 0;
- for ( sal_Int32 i = 0, nCount = implGetAccessibleChildCount(); i < nCount; i++ )
+ VclPtr< ToolBox > pToolBox = GetAs< ToolBox >();
+ if (pToolBox)
{
- if ( isAccessibleChildSelected( i ) )
+ sal_uInt16 nHighlightItemId = pToolBox->GetHighlightItemId();
+ for ( size_t i = 0, nCount = pToolBox->GetItemCount(); i < nCount; i++ )
{
- nRet = 1;
- break; // a toolbox can only have (n)one selected child
+ if ( nHighlightItemId == pToolBox->GetItemId( i ) )
+ {
+ nRet = 1;
+ break; // a toolbox can only have (n)one selected child
+ }
}
}
+
return nRet;
}
@@ -857,14 +863,20 @@ Reference< XAccessible > VCLXAccessibleToolBox::getSelectedAccessibleChild( sal_
throw IndexOutOfBoundsException();
Reference< XAccessible > xChild;
- for ( sal_Int32 i = 0, nCount = implGetAccessibleChildCount(); i < nCount; i++ )
+ VclPtr< ToolBox > pToolBox = GetAs< ToolBox >();
+ if (pToolBox)
{
- if ( isAccessibleChildSelected( i ) )
+ sal_uInt16 nHighlightItemId = pToolBox->GetHighlightItemId();
+ for ( sal_Int32 i = 0, nCount = pToolBox->GetItemCount(); i < nCount; i++ )
{
- xChild = getAccessibleChild( i );
- break;
+ if ( nHighlightItemId == pToolBox->GetItemId( i ) )
+ {
+ xChild = getAccessibleChild( i );
+ break;
+ }
}
}
+
if (!xChild)
throw IndexOutOfBoundsException();