Property removal and deletion done from wxPropertyGrid event handler is now postponed to idle event

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@63534 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Jaakko Salli 2010-02-22 16:44:56 +00:00
parent e908dbcc92
commit f231df8aa8
5 changed files with 77 additions and 12 deletions

View File

@ -1808,6 +1808,10 @@ protected:
/** Appearance of a unspecified value cell. */
wxPGCell m_unspecifiedAppearance;
/** List of properties to be deleted/removed in idle event handler. */
wxArrayPGProperty m_deletedProperties;
wxArrayPGProperty m_removedProperties;
//
// Temporary values
//

View File

@ -240,18 +240,34 @@ public:
bool ChangePropertyValue( wxPGPropArg id, wxVariant newValue );
/**
Deletes a property by id. If category is deleted, all children are
automatically deleted as well.
*/
Removes and deletes a property and any children.
@param id
Pointer or name of a property.
@remarks If you delete a property in a wxPropertyGrid event
handler, the actual deletion is postponed until the next
idle event.
This functions deselects selected property, if any.
Validation failure option wxPG_VFB_STAY_IN_PROPERTY is not
respected, ie. selection is cleared even if editor had
invalid value.
*/
void DeleteProperty( wxPGPropArg id );
/**
Removes and returns a property.
Removes a property. Does not delete the property object, but
instead returns it.
@param id
Pointer or name of a property.
@remarks Removed property cannot have any children.
Also, if you remove property in a wxPropertyGrid event
handler, the actual removal is postponed until the next
idle event.
*/
wxPGProperty* RemoveProperty( wxPGPropArg id );

View File

@ -135,11 +135,19 @@ public:
bool ChangePropertyValue( wxPGPropArg id, wxVariant newValue );
/**
Deletes a property.
Removes and deletes a property and any children.
@remarks This functions deselects selected property, if any. Validation
failure option wxPG_VFB_STAY_IN_PROPERTY is not respected, ie.
selection is cleared even if editor had invalid value.
@param id
Pointer or name of a property.
@remarks If you delete a property in a wxPropertyGrid event
handler, the actual deletion is postponed until the next
idle event.
This functions deselects selected property, if any.
Validation failure option wxPG_VFB_STAY_IN_PROPERTY is not
respected, ie. selection is cleared even if editor had
invalid value.
*/
void DeleteProperty( wxPGPropArg id );
@ -589,12 +597,17 @@ public:
static void RegisterAdditionalEditors();
/**
Removes and returns a property.
Removes a property. Does not delete the property object, but
instead returns it.
@param id
Pointer or name of a property.
@remarks Removed property cannot have any children.
Also, if you remove property in a wxPropertyGrid event
handler, the actual removal is postponed until the next
idle event.
*/
wxPGProperty* RemoveProperty( wxPGPropArg id );

View File

@ -4535,9 +4535,10 @@ bool wxPropertyGrid::SendEvent( int eventType, wxPGProperty* p,
evt.SetCanVeto(true);
}
wxPropertyGridEvent* prevProcessedEvent = m_processedEvent;
m_processedEvent = &evt;
m_eventObject->HandleWindowEvent(evt);
m_processedEvent = NULL;
m_processedEvent = prevProcessedEvent;
return evt.WasVetoed();
}
@ -5639,6 +5640,27 @@ void wxPropertyGrid::OnIdle( wxIdleEvent& WXUNUSED(event) )
if ( tlp != m_tlp )
OnTLPChanging(tlp);
}
//
// Resolve pending property removals
if ( m_deletedProperties.size() > 0 )
{
wxArrayPGProperty& arr = m_deletedProperties;
for ( unsigned int i=0; i<arr.size(); i++ )
{
DeleteProperty(arr[i]);
}
arr.clear();
}
if ( m_removedProperties.size() > 0 )
{
wxArrayPGProperty& arr = m_removedProperties;
for ( unsigned int i=0; i<arr.size(); i++ )
{
RemoveProperty(arr[i]);
}
arr.clear();
}
}
bool wxPropertyGrid::IsEditorFocused() const

View File

@ -1857,6 +1857,18 @@ void wxPropertyGridPageState::DoDelete( wxPGProperty* item, bool doDelete )
wxCHECK_RET( item != &m_regularArray && item != m_abcArray,
wxT("wxPropertyGrid: Do not attempt to remove the root item.") );
wxPropertyGrid* pg = GetGrid();
// Must defer deletion? Yes, if handling a wxPG event.
if ( pg && pg->m_processedEvent )
{
if ( doDelete )
pg->m_deletedProperties.push_back(item);
else
pg->m_removedProperties.push_back(item);
return;
}
unsigned int indinparent = item->GetIndexInParent();
wxPGProperty* pwc = (wxPGProperty*)item;
@ -1867,8 +1879,6 @@ void wxPropertyGridPageState::DoDelete( wxPGProperty* item, bool doDelete )
wxASSERT( item->GetParentState() == this );
wxPropertyGrid* pg = GetGrid();
if ( DoIsPropertySelected(item) )
{
if ( pg && pg->GetState() == this )