const wxIcon& wxIconBundle::GetIcon( const wxSize& size ) const
{
- size_t i, max = m_icons.GetCount();
+ // temp. variable needed to fix Borland C++ 5.5.1 problem
+ // with passing a return value through two functions
+ wxIcon *tmp;
+
+ size_t max = m_icons.GetCount();
+
+ // if we have one or no icon, we can return now without doing more work:
+ if ( max <= 1 )
+ {
+ if ( max == 1 ) // fix for broken BCC
+ tmp = &m_icons[0];
+ else // max == 0
+ tmp = &wxNullIcon;
+ return *tmp;
+ }
+
+ // there are more icons, find the best match:
wxCoord sysX = wxSystemSettings::GetMetric( wxSYS_ICON_X ),
sysY = wxSystemSettings::GetMetric( wxSYS_ICON_Y );
wxIcon *sysIcon = 0;
- // temp. variable needed to fix Borland C++ 5.5.1 problem
- // with passing a return value through two functions
- wxIcon *tmp;
- for( i = 0; i < max; i++ )
+ for( size_t i = 0; i < max; i++ )
{
if( !m_icons[i].Ok() )
continue;
// return the system-sized icon if we've got one
if( sysIcon ) return *sysIcon;
- // return the first icon, if we have one
- if( max > 0 ) // fix for broken BCC
- tmp = &m_icons[0];
- else
- tmp = &wxNullIcon;
+ // we certainly have at least one icon thanks to the <=1 check above
+ tmp = &m_icons[0];
return *tmp;
}