1 ///////////////////////////////////////////////////////////////////////////// 
   2 // Name:        wx/propgeid/propgridiface.h 
   3 // Purpose:     wxPropertyGridInterface class 
   4 // Author:      Jaakko Salli 
   8 // Copyright:   (c) Jaakko Salli 
   9 // Licence:     wxWindows license 
  10 ///////////////////////////////////////////////////////////////////////////// 
  12 #ifndef __WX_PROPGRID_PROPGRIDIFACE_H__ 
  13 #define __WX_PROPGRID_PROPGRIDIFACE_H__ 
  17 #include "wx/propgrid/property.h" 
  18 #include "wx/propgrid/propgridpagestate.h" 
  20 // ----------------------------------------------------------------------- 
  24 /** @section wxPGPropArgCls 
  26     Most property grid functions have this type as their argument, as it can 
  27     convey a property by either a pointer or name. 
  29 class WXDLLIMPEXP_PROPGRID wxPGPropArgCls
 
  33     wxPGPropArgCls( const wxPGProperty
* property 
) 
  35         m_ptr
.property 
= (wxPGProperty
*) property
; 
  38     wxPGPropArgCls( const wxString
& str 
) 
  40         m_ptr
.stringName 
= &str
; 
  43     wxPGPropArgCls( const wxPGPropArgCls
& id 
) 
  48     // This is only needed for wxPython bindings 
  49     wxPGPropArgCls( wxString
* str
, bool WXUNUSED(deallocPtr
) ) 
  51         m_ptr
.stringName 
= str
; 
  52         m_flags 
= IsWxString 
| OwnsWxString
; 
  56         if ( m_flags 
& OwnsWxString 
) 
  57             delete m_ptr
.stringName
; 
  59     wxPGProperty
* GetPtr() const 
  61         wxCHECK( m_flags 
== IsProperty
, NULL 
); 
  62         return m_ptr
.property
; 
  64     wxPGPropArgCls( const char* str 
) 
  70     wxPGPropArgCls( const wchar_t* str 
) 
  72         m_ptr
.wcharName 
= str
; 
  76     /** This constructor is required for NULL. */ 
  79         m_ptr
.property 
= NULL
; 
  82     wxPGProperty
* GetPtr( wxPropertyGridInterface
* iface 
) const; 
  83     wxPGProperty
* GetPtr( const wxPropertyGridInterface
* iface 
) const 
  85         return GetPtr((wxPropertyGridInterface
*)iface
); 
  87     wxPGProperty
* GetPtr0() const { return m_ptr
.property
; } 
  88     bool HasName() const { return (m_flags 
!= IsProperty
); } 
  89     const wxString
& GetName() const { return *m_ptr
.stringName
; } 
 103         wxPGProperty
* property
; 
 104         const char* charName
; 
 106         const wchar_t* wcharName
; 
 108         const wxString
* stringName
; 
 110     unsigned char m_flags
; 
 115 typedef const wxPGPropArgCls
& wxPGPropArg
; 
 117 // ----------------------------------------------------------------------- 
 120 void wxPGTypeOperationFailed( const wxPGProperty
* p
, 
 121                               const wxString
& typestr
, 
 122                               const wxString
& op 
); 
 124 void wxPGGetFailed( const wxPGProperty
* p
, const wxString
& typestr 
); 
 126 // ----------------------------------------------------------------------- 
 128 // Helper macro that does necessary preparations when calling 
 129 // some wxPGProperty's member function. 
 130 #define wxPG_PROP_ARG_CALL_PROLOG_0(PROPERTY) \ 
 131     PROPERTY *p = (PROPERTY*)id.GetPtr(this); \ 
 134 #define wxPG_PROP_ARG_CALL_PROLOG_RETVAL_0(PROPERTY, RETVAL) \ 
 135     PROPERTY *p = (PROPERTY*)id.GetPtr(this); \ 
 136     if ( !p ) return RETVAL; 
 138 #define wxPG_PROP_ARG_CALL_PROLOG() \ 
 139     wxPG_PROP_ARG_CALL_PROLOG_0(wxPGProperty) 
 141 #define wxPG_PROP_ARG_CALL_PROLOG_RETVAL(RVAL) \ 
 142     wxPG_PROP_ARG_CALL_PROLOG_RETVAL_0(wxPGProperty, RVAL) 
 144 #define wxPG_PROP_ID_CONST_CALL_PROLOG() \ 
 145     wxPG_PROP_ARG_CALL_PROLOG_0(const wxPGProperty) 
 147 #define wxPG_PROP_ID_CONST_CALL_PROLOG_RETVAL(RVAL) \ 
 148     wxPG_PROP_ARG_CALL_PROLOG_RETVAL_0(const wxPGProperty, RVAL) 
 150 // ----------------------------------------------------------------------- 
 153 /** @class wxPropertyGridInterface 
 155     Most of the shared property manipulation interface shared by wxPropertyGrid, 
 156     wxPropertyGridPage, and wxPropertyGridManager is defined in this class. 
 159     - In separate wxPropertyGrid component this class was known as 
 160     wxPropertyContainerMethods. 
 165 class WXDLLIMPEXP_PROPGRID wxPropertyGridInterface
 
 170     virtual ~wxPropertyGridInterface() { } 
 173         Appends property to the list. 
 175         wxPropertyGrid assumes ownership of the object. 
 176         Becomes child of most recently added category. 
 178         - wxPropertyGrid takes the ownership of the property pointer. 
 179         - If appending a category with name identical to a category already in 
 180           the wxPropertyGrid, then newly created category is deleted, and most 
 181           recently added category (under which properties are appended) is set 
 182           to the one with same name. This allows easier adding of items to same 
 183           categories in multiple passes. 
 184         - Does not automatically redraw the control, so you may need to call 
 185           Refresh when calling this function after control has been shown for 
 188     wxPGProperty
* Append( wxPGProperty
* property 
); 
 190     wxPGProperty
* AppendIn( wxPGPropArg id
, wxPGProperty
* newproperty 
); 
 193         In order to add new items into a property with fixed children (for 
 194         instance, wxFlagsProperty), you need to call this method. After 
 195         populating has been finished, you need to call EndAddChildren. 
 197     void BeginAddChildren( wxPGPropArg id 
); 
 199     /** Deletes all properties. 
 201     virtual void Clear() = 0; 
 204         Clears current selection, if any. 
 207             If set to @false, deselecting the property will always work, 
 208             even if its editor had invalid value in it. 
 210         @return Returns @true if successful or if there was no selection. May 
 211                 fail if validation was enabled and active editor had invalid 
 214     bool ClearSelection( bool validation 
= false); 
 216     /** Resets modified status of all properties. 
 218     void ClearModifiedStatus(); 
 220     /** Collapses given category or property with children. 
 221         Returns true if actually collapses. 
 223     bool Collapse( wxPGPropArg id 
); 
 225     /** Collapses all items that can be collapsed. 
 228         Return false if failed (may fail if editor value cannot be validated). 
 230     bool CollapseAll() { return ExpandAll(false); } 
 233         Changes value of a property, as if from an editor. 
 234         Use this instead of SetPropertyValue() if you need the value to run 
 235         through validation process, and also send the property change event. 
 238         Returns true if value was successfully changed. 
 240     bool ChangePropertyValue( wxPGPropArg id
, wxVariant newValue 
); 
 243         Deletes a property by id. If category is deleted, all children are 
 244         automatically deleted as well. 
 246     void DeleteProperty( wxPGPropArg id 
); 
 249         Removes and returns a property. 
 252             Pointer or name of a property. 
 254         @remarks Removed property cannot have any children. 
 256     wxPGProperty
* RemoveProperty( wxPGPropArg id 
); 
 258     /** Disables property. */ 
 259     bool DisableProperty( wxPGPropArg id 
) { return EnableProperty(id
,false); } 
 262         Returns true if all property grid data changes have been committed. 
 264         Usually only returns false if value in active editor has been 
 265         invalidated by a wxValidator. 
 267     bool EditorValidate(); 
 270         Enables or disables property, depending on whether enable is true or 
 273     bool EnableProperty( wxPGPropArg id
, bool enable 
= true ); 
 275     /** Called after population of property with fixed children has finished. 
 277     void EndAddChildren( wxPGPropArg id 
); 
 279     /** Expands given category or property with children. 
 280         Returns true if actually expands. 
 282     bool Expand( wxPGPropArg id 
); 
 284     /** Expands all items that can be expanded. 
 286     bool ExpandAll( bool expand 
= true ); 
 288     /** Returns id of first child of given property. 
 290         Does not return sub-properties! 
 292     wxPGProperty
* GetFirstChild( wxPGPropArg id 
) 
 294         wxPG_PROP_ARG_CALL_PROLOG_RETVAL(wxNullProperty
) 
 296         if ( !p
->GetChildCount() || p
->HasFlag(wxPG_PROP_AGGREGATE
) ) 
 297             return wxNullProperty
; 
 303     /** Returns iterator class instance. 
 305         See @ref propgrid_iterator_flags. Value wxPG_ITERATE_DEFAULT causes 
 306         iteration over everything except private child properties. 
 308             Property to start iteration from. If NULL, then first child of root 
 311             Either wxTOP or wxBOTTOM. wxTOP will indicate that iterations start 
 312             from the first property from the top, and wxBOTTOM means that the 
 313             iteration will instead begin from bottommost valid item. 
 315     wxPropertyGridIterator 
GetIterator( int flags 
= wxPG_ITERATE_DEFAULT
, 
 316                                         wxPGProperty
* firstProp 
= NULL 
) 
 318         return wxPropertyGridIterator( m_pState
, flags
, firstProp 
); 
 321     wxPropertyGridConstIterator
 
 322     GetIterator( int flags 
= wxPG_ITERATE_DEFAULT
, 
 323                  wxPGProperty
* firstProp 
= NULL 
) const 
 325         return wxPropertyGridConstIterator( m_pState
, flags
, firstProp 
); 
 328     wxPropertyGridIterator 
GetIterator( int flags
, int startPos 
) 
 330         return wxPropertyGridIterator( m_pState
, flags
, startPos 
); 
 333     wxPropertyGridConstIterator 
GetIterator( int flags
, int startPos 
) const 
 335         return wxPropertyGridConstIterator( m_pState
, flags
, startPos 
); 
 339     /** Returns id of first item, whether it is a category or property. 
 341         @link iteratorflags List of iterator flags@endlink 
 343     wxPGProperty
* GetFirst( int flags 
= wxPG_ITERATE_ALL 
) 
 345         wxPropertyGridIterator 
it( m_pState
, flags
, wxNullProperty
, 1 ); 
 349     const wxPGProperty
* GetFirst( int flags 
= wxPG_ITERATE_ALL 
) const 
 351         return ((wxPropertyGridInterface
*)this)->GetFirst(flags
); 
 355         Returns pointer to a property with given name (case-sensitive). 
 356         If there is no property with such name, @NULL pointer is returned. 
 358         @remarks Properties which have non-category, non-root parent 
 359                  can not be accessed globally by their name. Instead, use 
 360                  "<property>.<subproperty>" instead of "<subproperty>". 
 362     wxPGProperty
* GetProperty( const wxString
& name 
) const 
 364         return GetPropertyByName(name
); 
 367     /** Returns map-like storage of property's attributes. 
 369         Note that if extra style wxPG_EX_WRITEONLY_BUILTIN_ATTRIBUTES is set, 
 370         then builtin-attributes are not included in the storage. 
 372     const wxPGAttributeStorage
& GetPropertyAttributes( wxPGPropArg id 
) const 
 374         // If 'id' refers to invalid property, then we will return dummy 
 375         // attributes (ie. root property's attributes, which contents should 
 376         // should always be empty and of no consequence). 
 377         wxPG_PROP_ARG_CALL_PROLOG_RETVAL(m_pState
->DoGetRoot()->GetAttributes()); 
 378         return p
->GetAttributes(); 
 381     /** Adds to 'targetArr' pointers to properties that have given 
 382         flags 'flags' set. However, if 'inverse' is set to true, then 
 383         only properties without given flags are stored. 
 385         Property flags to use. 
 387         Iterator flags to use. Default is everything expect private children. 
 389     void GetPropertiesWithFlag( wxArrayPGProperty
* targetArr
, 
 390                                 wxPGProperty::FlagType flags
, 
 391                                 bool inverse 
= false, 
 392                                 int iterFlags 
= wxPG_ITERATE_PROPERTIES 
| 
 393                                                 wxPG_ITERATE_HIDDEN 
| 
 394                                                 wxPG_ITERATE_CATEGORIES
) const; 
 396     /** Returns value of given attribute. If none found, returns NULL-variant. 
 398     wxVariant 
GetPropertyAttribute( wxPGPropArg id
, 
 399                                     const wxString
& attrName 
) const 
 401         wxPG_PROP_ARG_CALL_PROLOG_RETVAL(wxNullVariant
) 
 402         return p
->GetAttribute(attrName
); 
 405     /** Returns pointer of property's nearest parent category. If no category 
 408     wxPropertyCategory
* GetPropertyCategory( wxPGPropArg id 
) const 
 410         wxPG_PROP_ID_CONST_CALL_PROLOG_RETVAL(NULL
) 
 411         return m_pState
->GetPropertyCategory(p
); 
 415     /** Returns client data (void*) of a property. */ 
 416     void* GetPropertyClientData( wxPGPropArg id 
) const 
 418         wxPG_PROP_ARG_CALL_PROLOG_RETVAL(NULL
) 
 419         return p
->GetClientData(); 
 424         Returns first property which label matches given string. 
 426         NULL if none found. Note that this operation is extremely slow when 
 427         compared to GetPropertyByName(). 
 429     wxPGProperty
* GetPropertyByLabel( const wxString
& label 
) const; 
 431     /** Returns property with given name. NULL if none found. 
 433     wxPGProperty
* GetPropertyByName( const wxString
& name 
) const; 
 435     /** Returns child property 'subname' of property 'name'. Same as 
 436         calling GetPropertyByName("name.subname"), albeit slightly faster. 
 438     wxPGProperty
* GetPropertyByName( const wxString
& name
, 
 439                                      const wxString
& subname 
) const; 
 441     /** Returns property's editor. */ 
 442     const wxPGEditor
* GetPropertyEditor( wxPGPropArg id 
) const 
 444         wxPG_PROP_ARG_CALL_PROLOG_RETVAL(NULL
) 
 445         return p
->GetEditorClass(); 
 448     /** Returns help string associated with a property. */ 
 449     wxString 
GetPropertyHelpString( wxPGPropArg id 
) const 
 451         wxPG_PROP_ARG_CALL_PROLOG_RETVAL(m_emptyString
) 
 452         return p
->GetHelpString(); 
 455     /** Returns property's custom value image (NULL of none). */ 
 456     wxBitmap
* GetPropertyImage( wxPGPropArg id 
) const 
 458         wxPG_PROP_ARG_CALL_PROLOG_RETVAL(NULL
) 
 459         return p
->GetValueImage(); 
 462     /** Returns label of a property. */ 
 463     const wxString
& GetPropertyLabel( wxPGPropArg id 
) 
 465         wxPG_PROP_ARG_CALL_PROLOG_RETVAL(m_emptyString
) 
 466         return p
->GetLabel(); 
 469     /** Returns name of a property, by which it is globally accessible. */ 
 470     wxString 
GetPropertyName( wxPGProperty
* property 
) 
 472         return property
->GetName(); 
 475     /** Returns parent item of a property. */ 
 476     wxPGProperty
* GetPropertyParent( wxPGPropArg id 
) 
 478         wxPG_PROP_ARG_CALL_PROLOG_RETVAL(wxNullProperty
) 
 479         return p
->GetParent(); 
 483     /** Returns validator of a property as a reference, which you 
 484         can pass to any number of SetPropertyValidator. 
 486     wxValidator
* GetPropertyValidator( wxPGPropArg id 
) 
 488         wxPG_PROP_ARG_CALL_PROLOG_RETVAL(NULL
) 
 489         return p
->GetValidator(); 
 493     /** Returns value as wxVariant. To get wxObject pointer from it, 
 494         you will have to use WX_PG_VARIANT_TO_WXOBJECT(VARIANT,CLASSNAME) macro. 
 496         If property value is unspecified, Null variant is returned. 
 498     wxVariant 
GetPropertyValue( wxPGPropArg id 
) 
 500         wxPG_PROP_ARG_CALL_PROLOG_RETVAL(wxVariant()) 
 501         return p
->GetValue(); 
 504     wxString 
GetPropertyValueAsString( wxPGPropArg id 
) const; 
 505     long GetPropertyValueAsLong( wxPGPropArg id 
) const; 
 506     unsigned long GetPropertyValueAsULong( wxPGPropArg id 
) const 
 508         return (unsigned long) GetPropertyValueAsLong(id
); 
 511     int GetPropertyValueAsInt( wxPGPropArg id 
) const 
 512         { return (int)GetPropertyValueAsLong(id
); } 
 514     bool GetPropertyValueAsBool( wxPGPropArg id 
) const; 
 515     double GetPropertyValueAsDouble( wxPGPropArg id 
) const; 
 517 #define wxPG_PROP_ID_GETPROPVAL_CALL_PROLOG_RETVAL(TYPENAME, DEFVAL) \ 
 518     wxPG_PROP_ARG_CALL_PROLOG_RETVAL(DEFVAL) \ 
 519     wxString typeName(wxS(TYPENAME)); \ 
 520     wxVariant value = p->GetValue(); \ 
 521     if ( value.GetType() != typeName ) \ 
 523         wxPGGetFailed(p, typeName); \ 
 527 #define wxPG_PROP_ID_GETPROPVAL_CALL_PROLOG_RETVAL_WFALLBACK(TYPENAME, DEFVAL) \ 
 528     wxPG_PROP_ARG_CALL_PROLOG_RETVAL(DEFVAL) \ 
 529     wxVariant value = p->GetValue(); \ 
 530     if ( value.GetType() != wxS(TYPENAME) ) \ 
 533     wxArrayString GetPropertyValueAsArrayString( wxPGPropArg id ) const 
 535         wxPG_PROP_ID_GETPROPVAL_CALL_PROLOG_RETVAL("arrstring", 
 537         return value
.GetArrayString(); 
 540 #if wxUSE_LONGLONG_NATIVE 
 541     wxLongLong_t 
GetPropertyValueAsLongLong( wxPGPropArg id 
) const 
 543         wxPG_PROP_ID_GETPROPVAL_CALL_PROLOG_RETVAL_WFALLBACK("wxLongLong", 
 544                                              (long) GetPropertyValueAsLong(id
)) 
 547         return ll
.GetValue(); 
 550     wxULongLong_t 
GetPropertyValueAsULongLong( wxPGPropArg id 
) const 
 552         wxPG_PROP_ID_GETPROPVAL_CALL_PROLOG_RETVAL_WFALLBACK("wxULongLong", 
 553                                     (unsigned long) GetPropertyValueAsULong(id
)) 
 556         return ull
.GetValue(); 
 560     wxArrayInt 
GetPropertyValueAsArrayInt( wxPGPropArg id 
) const 
 562         wxPG_PROP_ID_GETPROPVAL_CALL_PROLOG_RETVAL("wxArrayInt", 
 570     wxDateTime 
GetPropertyValueAsDateTime( wxPGPropArg id 
) const 
 572         wxPG_PROP_ID_GETPROPVAL_CALL_PROLOG_RETVAL("datetime", 
 574         return value
.GetDateTime(); 
 579     /** Returns a wxVariant list containing wxVariant versions of all 
 580         property values. Order is not guaranteed. 
 582         Use wxPG_KEEP_STRUCTURE to retain category structure; each sub 
 583         category will be its own wxVariantList of wxVariant. 
 584         Use wxPG_INC_ATTRIBUTES to include property attributes as well. 
 585         Each attribute will be stored as list variant named 
 586         "@@<propname>@@attr." 
 589     wxVariant 
GetPropertyValues( const wxString
& listname 
= wxEmptyString
, 
 590         wxPGProperty
* baseparent 
= NULL
, long flags 
= 0 ) const 
 592         return m_pState
->DoGetPropertyValues(listname
, baseparent
, flags
); 
 596     /** Returns currently selected property. */ 
 597     wxPGProperty
* GetSelection() const 
 599         return m_pState
->GetSelection(); 
 603     wxPropertyGridPageState
* GetState() const { return m_pState
; } 
 606     /** Similar to GetIterator(), but instead returns wxPGVIterator instance, 
 607         which can be useful for forward-iterating through arbitrary property 
 611         See @ref propgrid_iterator_flags. 
 613     virtual wxPGVIterator 
GetVIterator( int flags 
) const; 
 615     /** Hides or reveals a property. 
 617             If true, hides property, otherwise reveals it. 
 619             By default changes are applied recursively. Set this paramter 
 620             wxPG_DONT_RECURSE to prevent this. 
 622     bool HideProperty( wxPGPropArg id
, 
 624                        int flags 
= wxPG_RECURSE 
); 
 626 #if wxPG_INCLUDE_ADVPROPS 
 627     /** Initializes *all* property types. Causes references to most object 
 628         files in the library, so calling this may cause significant increase 
 629         in executable size when linking with static library. 
 631     static void InitAllTypeHandlers(); 
 633     static void InitAllTypeHandlers() { } 
 637     /** Inserts property to the property container. 
 640         New property is inserted just prior to this. Available only 
 641         in the first variant. There are two versions of this function 
 642         to allow this parameter to be either an id or name to 
 646         Pointer to the inserted property. wxPropertyGrid will take 
 647         ownership of this object. 
 650         New property is inserted under this category. Available only 
 651         in the second variant. There are two versions of this function 
 652         to allow this parameter to be either an id or name to 
 656         Index under category. Available only in the second variant. 
 657         If index is < 0, property is appended in category. 
 660         Returns id for the property, 
 664         - wxPropertyGrid takes the ownership of the property pointer. 
 666         - While Append may be faster way to add items, make note that when 
 667           both types of data storage (categoric and 
 668           non-categoric) are active, Insert becomes even more slow. This is 
 669           especially true if current mode is non-categoric. 
 676             wxPGProperty* my_cat_id = propertygrid->Append( 
 677                 new wxPropertyCategory("My Category") ); 
 681             // insert into category - using second variant 
 682             wxPGProperty* my_item_id_1 = propertygrid->Insert( 
 683                 my_cat_id, 0, new wxStringProperty("My String 1") ); 
 685             // insert before to first item - using first variant 
 686             wxPGProperty* my_item_id_2 = propertygrid->Insert( 
 687                 my_item_id, new wxStringProperty("My String 2") ); 
 692     wxPGProperty
* Insert( wxPGPropArg priorThis
, wxPGProperty
* newproperty 
); 
 693     wxPGProperty
* Insert( wxPGPropArg parent
, 
 695                           wxPGProperty
* newproperty 
); 
 698     /** Returns true if property is a category. */ 
 699     bool IsPropertyCategory( wxPGPropArg id 
) const 
 701         wxPG_PROP_ARG_CALL_PROLOG_RETVAL(false) 
 702         return p
->IsCategory(); 
 705     /** Returns true if property is enabled. */ 
 706     bool IsPropertyEnabled( wxPGPropArg id 
) const 
 708         wxPG_PROP_ARG_CALL_PROLOG_RETVAL(false) 
 709         return (!(p
->GetFlags() & wxPG_PROP_DISABLED
))?true:false; 
 713         Returns true if given property is expanded. 
 715         Naturally, always returns false for properties that cannot be expanded. 
 717     bool IsPropertyExpanded( wxPGPropArg id 
) const; 
 720         Returns true if property has been modified after value set or modify 
 721         flag clear by software. 
 723     bool IsPropertyModified( wxPGPropArg id 
) const 
 725         wxPG_PROP_ARG_CALL_PROLOG_RETVAL(false) 
 726         return ( (p
->GetFlags() & wxPG_PROP_MODIFIED
) ? true : false ); 
 730         Returns true if property is shown (ie hideproperty with true not 
 733     bool IsPropertyShown( wxPGPropArg id 
) const 
 735         wxPG_PROP_ARG_CALL_PROLOG_RETVAL(false) 
 736         return (!(p
->GetFlags() & wxPG_PROP_HIDDEN
))?true:false; 
 739     /** Returns true if property value is set to unspecified. 
 741     bool IsPropertyValueUnspecified( wxPGPropArg id 
) const 
 743         wxPG_PROP_ARG_CALL_PROLOG_RETVAL(false) 
 744         return p
->IsValueUnspecified(); 
 748         Disables (limit = true) or enables (limit = false) wxTextCtrl editor of 
 749         a property, if it is not the sole mean to edit the value. 
 751     void LimitPropertyEditing( wxPGPropArg id
, bool limit 
= true ); 
 753     /** If state is shown in it's grid, refresh it now. 
 755     virtual void RefreshGrid( wxPropertyGridPageState
* state 
= NULL 
); 
 757 #if wxPG_INCLUDE_ADVPROPS 
 759         Initializes additional property editors (SpinCtrl etc.). Causes 
 760         references to most object files in the library, so calling this may 
 761         cause significant increase in executable size when linking with static 
 764     static void RegisterAdditionalEditors(); 
 766     static void RegisterAdditionalEditors() { } 
 769     /** Replaces property with id with newly created property. For example, 
 770         this code replaces existing property named "Flags" with one that 
 771         will have different set of items: 
 773             pg->ReplaceProperty("Flags", 
 774                 wxFlagsProperty("Flags", wxPG_LABEL, newItems)) 
 776         For more info, see wxPropertyGrid::Insert. 
 778     wxPGProperty
* ReplaceProperty( wxPGPropArg id
, wxPGProperty
* property 
); 
 780     /** @anchor propgridinterface_editablestate_flags 
 782         Flags for wxPropertyGridInterface::SaveEditableState() and 
 783         wxPropertyGridInterface::RestoreEditableState(). 
 785     enum EditableStateFlags
 
 787         /** Include selected property. */ 
 788         SelectionState   
= 0x01, 
 789         /** Include expanded/collapsed property information. */ 
 790         ExpandedState    
= 0x02, 
 791         /** Include scrolled position. */ 
 792         ScrollPosState   
= 0x04, 
 793         /** Include selected page information. 
 794             Only applies to wxPropertyGridManager. */ 
 796         /** Include splitter position. Stored for each page. */ 
 797         SplitterPosState 
= 0x10, 
 798         /** Include description box size. 
 799             Only applies to wxPropertyGridManager. */ 
 803             Include all supported user editable state information. 
 804             This is usually the default value. */ 
 805         AllStates        
= SelectionState 
| 
 814         Restores user-editable state. 
 816         See also wxPropertyGridInterface::SaveEditableState(). 
 819             String generated by SaveEditableState. 
 822             Which parts to restore from source string. See @ref 
 823             propgridinterface_editablestate_flags "list of editable state 
 827             False if there was problem reading the string. 
 830         If some parts of state (such as scrolled or splitter position) fail to 
 831         restore correctly, please make sure that you call this function after 
 832         wxPropertyGrid size has been set (this may sometimes be tricky when 
 835     bool RestoreEditableState( const wxString
& src
, 
 836                                int restoreStates 
= AllStates 
); 
 839         Used to acquire user-editable state (selected property, expanded 
 840         properties, scrolled position, splitter positions). 
 842         @param includedStates 
 843         Which parts of state to include. See @ref 
 844         propgridinterface_editablestate_flags "list of editable state flags". 
 846     wxString 
SaveEditableState( int includedStates 
= AllStates 
) const; 
 849         Lets user to set the strings listed in the choice dropdown of a 
 850         wxBoolProperty. Defaults are "True" and "False", so changing them to, 
 851         say, "Yes" and "No" may be useful in some less technical applications. 
 853     static void SetBoolChoices( const wxString
& trueChoice
, 
 854                                 const wxString
& falseChoice 
); 
 856     /** Sets an attribute for this property. 
 858             Text identifier of attribute. See @ref propgrid_property_attributes. 
 862             Optional. Use wxPG_RECURSE to set the attribute to child properties 
 865     void SetPropertyAttribute( wxPGPropArg id
, 
 866                                const wxString
& attrName
, 
 870         DoSetPropertyAttribute(id
,attrName
,value
,argFlags
); 
 873     /** Sets property attribute for all applicapple properties. 
 874         Be sure to use this method only after all properties have been 
 877     void SetPropertyAttributeAll( const wxString
& attrName
, wxVariant value 
); 
 880         Sets background colour of a property. 
 883             Property name or pointer. 
 886             New background colour. 
 889             If True, child properties are affected recursively. Property 
 890             categories are skipped if this flag is used. 
 892     void SetPropertyBackgroundColour( wxPGPropArg id
, 
 893                                       const wxColour
& colour
, 
 894                                       bool recursively 
= true ); 
 896     /** Resets text and background colours of given property. 
 898     void SetPropertyColoursToDefault( wxPGPropArg id 
); 
 901         Sets text colour of a property. 
 904             Property name or pointer. 
 907             New background colour. 
 910             If True, child properties are affected recursively. Property 
 911             categories are skipped if this flag is used. 
 913     void SetPropertyTextColour( wxPGPropArg id
, 
 915                                 bool recursively 
= true ); 
 918         Returns background colour of first cell of a property. 
 920     wxColour 
GetPropertyBackgroundColour( wxPGPropArg id 
) const 
 922         wxPG_PROP_ARG_CALL_PROLOG_RETVAL(wxColour()) 
 923         return p
->GetCell(0).GetBgCol(); 
 927         Returns text colour of first cell of a property. 
 929     wxColour 
GetPropertyTextColour( wxPGPropArg id 
) const 
 931         wxPG_PROP_ARG_CALL_PROLOG_RETVAL(wxColour()) 
 932         return p
->GetCell(0).GetFgCol(); 
 935     /** Sets text, bitmap, and colours for given column's cell. 
 938         - You can set label cell by setting column to 0. 
 939         - You can use wxPG_LABEL as text to use default text for column. 
 941     void SetPropertyCell( wxPGPropArg id
, 
 943                           const wxString
& text 
= wxEmptyString
, 
 944                           const wxBitmap
& bitmap 
= wxNullBitmap
, 
 945                           const wxColour
& fgCol 
= wxNullColour
, 
 946                           const wxColour
& bgCol 
= wxNullColour 
); 
 949     /** Sets client data (void*) of a property. 
 951         This untyped client data has to be deleted manually. 
 953     void SetPropertyClientData( wxPGPropArg id
, void* clientData 
) 
 955         wxPG_PROP_ARG_CALL_PROLOG() 
 956         p
->SetClientData(clientData
); 
 959     /** Sets editor for a property. 
 962         For builtin editors, use wxPGEditor_X, where X is builtin editor's 
 963         name (TextCtrl, Choice, etc. see wxPGEditor documentation for full 
 966         For custom editors, use pointer you received from 
 967         wxPropertyGrid::RegisterEditorClass(). 
 969     void SetPropertyEditor( wxPGPropArg id
, const wxPGEditor
* editor 
) 
 971         wxPG_PROP_ARG_CALL_PROLOG() 
 972         wxCHECK_RET( editor
, wxT("unknown/NULL editor") ); 
 973         p
->SetEditor(editor
); 
 978     /** Sets editor control of a property. As editor argument, use 
 979         editor name string, such as "TextCtrl" or "Choice". 
 981     void SetPropertyEditor( wxPGPropArg id
, const wxString
& editorName 
) 
 983         SetPropertyEditor(id
,GetEditorByName(editorName
)); 
 986     /** Sets label of a property. 
 988     void SetPropertyLabel( wxPGPropArg id
, const wxString
& newproplabel 
); 
 991         Sets name of a property. 
 994             Name or pointer of property which name to change. 
 997             New name for property. 
 999     void SetPropertyName( wxPGPropArg id
, const wxString
& newName 
) 
1001         wxPG_PROP_ARG_CALL_PROLOG() 
1002         m_pState
->DoSetPropertyName( p
, newName 
); 
1006         Sets property (and, recursively, its children) to have read-only value. 
1007         In other words, user cannot change the value in the editor, but they 
1010         This is mainly for use with textctrl editor. Not all other editors fully 
1013         By default changes are applied recursively. Set this paramter 
1014         wxPG_DONT_RECURSE to prevent this. 
1016     void SetPropertyReadOnly( wxPGPropArg id
, 
1018                               int flags 
= wxPG_RECURSE 
) 
1020         wxPG_PROP_ARG_CALL_PROLOG() 
1021         if ( flags 
& wxPG_RECURSE 
) 
1022             p
->SetFlagRecursively(wxPG_PROP_READONLY
, set
); 
1024             p
->SetFlag(wxPG_PROP_READONLY
); 
1027     /** Sets property's value to unspecified. 
1028         If it has children (it may be category), then the same thing is done to 
1031     void SetPropertyValueUnspecified( wxPGPropArg id 
) 
1033         wxPG_PROP_ARG_CALL_PROLOG() 
1034         wxVariant nullVariant
; 
1035         SetPropVal(p
, nullVariant
); 
1039     /** Sets various property values from a list of wxVariants. If property with 
1040         name is missing from the grid, new property is created under given 
1041         default category (or root if omitted). 
1043     void SetPropertyValues( const wxVariantList
& list
, 
1044                             wxPGPropArg defaultCategory 
= wxNullProperty 
) 
1047         if ( defaultCategory
.HasName() ) p 
= defaultCategory
.GetPtr(this); 
1048         else p 
= defaultCategory
.GetPtr0(); 
1049         m_pState
->DoSetPropertyValues(list
, p
); 
1052     void SetPropertyValues( const wxVariant
& list
, 
1053                             wxPGPropArg defaultCategory 
= wxNullProperty 
) 
1055         SetPropertyValues(list
.GetList(),defaultCategory
); 
1059     /** Associates the help string with property. 
1061         By default, text is shown either in the manager's "description" 
1062         text box or in the status bar. If extra window style 
1063         wxPG_EX_HELP_AS_TOOLTIPS is used, then the text will appear as a 
1066     void SetPropertyHelpString( wxPGPropArg id
, const wxString
& helpString 
) 
1068         wxPG_PROP_ARG_CALL_PROLOG() 
1069         p
->SetHelpString(helpString
); 
1072     /** Set wxBitmap in front of the value. 
1074         - Bitmap will be scaled to a size returned by 
1075         wxPropertyGrid::GetImageSize(); 
1077     void SetPropertyImage( wxPGPropArg id
, wxBitmap
& bmp 
) 
1079         wxPG_PROP_ARG_CALL_PROLOG() 
1080         p
->SetValueImage(bmp
); 
1084     /** Sets max length of property's text. 
1086     bool SetPropertyMaxLength( wxPGPropArg id
, int maxLen 
); 
1088 #if wxUSE_VALIDATORS 
1089     /** Sets validator of a property. 
1091     void SetPropertyValidator( wxPGPropArg id
, const wxValidator
& validator 
) 
1093         wxPG_PROP_ARG_CALL_PROLOG() 
1094         p
->SetValidator(validator
); 
1099     /** Sets value (long integer) of a property. 
1101     void SetPropertyValue( wxPGPropArg id
, long value 
) 
1104         SetPropVal( id
, v 
); 
1107     /** Sets value (integer) of a property. 
1109     void SetPropertyValue( wxPGPropArg id
, int value 
) 
1111         wxVariant 
v((long)value
); 
1112         SetPropVal( id
, v 
); 
1114     /** Sets value (floating point) of a property. 
1116     void SetPropertyValue( wxPGPropArg id
, double value 
) 
1119         SetPropVal( id
, v 
); 
1121     /** Sets value (bool) of a property. 
1123     void SetPropertyValue( wxPGPropArg id
, bool value 
) 
1126         SetPropVal( id
, v 
); 
1129     void SetPropertyValue( wxPGPropArg id
, const wchar_t* value 
) 
1131         SetPropertyValueString( id
, wxString(value
) ); 
1134     void SetPropertyValue( wxPGPropArg id
, const char* value 
) 
1136         SetPropertyValueString( id
, wxString(value
) ); 
1138     void SetPropertyValue( wxPGPropArg id
, const wxString
& value 
) 
1140         SetPropertyValueString( id
, value 
); 
1143     /** Sets value (wxArrayString) of a property. 
1145     void SetPropertyValue( wxPGPropArg id
, const wxArrayString
& value 
) 
1148         SetPropVal( id
, v 
); 
1152     void SetPropertyValue( wxPGPropArg id
, const wxDateTime
& value 
) 
1155         SetPropVal( id
, v 
); 
1159     /** Sets value (wxObject*) of a property. 
1161     void SetPropertyValue( wxPGPropArg id
, wxObject
* value 
) 
1164         SetPropVal( id
, v 
); 
1167     void SetPropertyValue( wxPGPropArg id
, wxObject
& value 
) 
1169         wxVariant 
v(&value
); 
1170         SetPropVal( id
, v 
); 
1173 #if wxUSE_LONGLONG_NATIVE 
1174     /** Sets value (wxLongLong&) of a property. 
1176     void SetPropertyValue( wxPGPropArg id
, wxLongLong_t value 
) 
1178         wxVariant v 
= WXVARIANT(wxLongLong(value
)); 
1179         SetPropVal( id
, v 
); 
1181     /** Sets value (wxULongLong&) of a property. 
1183     void SetPropertyValue( wxPGPropArg id
, wxULongLong_t value 
) 
1185         wxVariant v 
= WXVARIANT(wxULongLong(value
)); 
1186         SetPropVal( id
, v 
); 
1190     /** Sets value (wxArrayInt&) of a property. 
1192     void SetPropertyValue( wxPGPropArg id
, const wxArrayInt
& value 
) 
1194         wxVariant v 
= WXVARIANT(value
); 
1195         SetPropVal( id
, v 
); 
1199     /** Sets value (wxString) of a property. 
1202         This method uses wxPGProperty::SetValueFromString, which all properties 
1203         should implement. This means that there should not be a type error, 
1204         and instead the string is converted to property's actual value type. 
1206     void SetPropertyValueString( wxPGPropArg id
, const wxString
& value 
); 
1208     /** Sets value (wxVariant&) of a property. 
1211         Use wxPropertyGrid::ChangePropertyValue() instead if you need to run 
1212         through validation process and send property change event. 
1214     void SetPropertyValue( wxPGPropArg id
, wxVariant value 
) 
1216         SetPropVal( id
, value 
); 
1220     /** Sets value (wxVariant&) of a property. Same as SetPropertyValue, but 
1221         accepts reference. */ 
1222     void SetPropVal( wxPGPropArg id
, wxVariant
& value 
); 
1225     /** Adjusts how wxPropertyGrid behaves when invalid value is entered 
1228         See @link vfbflags list of valid flags values@endlink 
1230     void SetValidationFailureBehavior( int vfbFlags 
); 
1233         Sorts all properties recursively. 
1236             This can contain any of the following options: 
1237               wxPG_SORT_TOP_LEVEL_ONLY: Only sort categories and their 
1238                 immediate children. Sorting done by wxPG_AUTO_SORT option 
1241         @see SortChildren, wxPropertyGrid::SetSortFunction 
1243     void Sort( int flags 
= 0 ); 
1246         Sorts children of a property. 
1249             Name or pointer to a property. 
1252             This can contain any of the following options: 
1253               wxPG_RECURSE: Sorts recursively. 
1255         @see Sort, wxPropertyGrid::SetSortFunction 
1257     void SortChildren( wxPGPropArg id
, int flags 
= 0 ) 
1259         wxPG_PROP_ARG_CALL_PROLOG() 
1260         m_pState
->DoSortChildren(p
, flags
); 
1265         def 
MapType(class_
,factory
): 
1266             "Registers Python type/class to property mapping.\n\nfactory: Property builder function/class." 
1267             global _type2property
 
1269                 mappings 
= _type2property
 
1271                 raise 
AssertionError("call only after a propertygrid or manager instance constructed") 
1273             mappings
[class_
] = factory
 
1276         def 
DoDefaultTypeMappings(self
): 
1277             "Map built-in properties." 
1278             global _type2property
 
1280                 mappings 
= _type2property
 
1285                 _type2property 
= mappings
 
1287             mappings
[str
] = StringProperty
 
1288             mappings
[unicode
] = StringProperty
 
1289             mappings
[int] = IntProperty
 
1290             mappings
[float] = FloatProperty
 
1291             mappings
[bool] = BoolProperty
 
1292             mappings
[list
] = ArrayStringProperty
 
1293             mappings
[tuple
] = ArrayStringProperty
 
1294             mappings
[wx
.Font
] = FontProperty
 
1295             mappings
[wx
.Colour
] = ColourProperty
 
1296             "mappings[wx.Size] = SizeProperty" 
1297             "mappings[wx.Point] = PointProperty" 
1298             "mappings[wx.FontData] = FontDataProperty" 
1300         def 
DoDefaultValueTypeMappings(self
): 
1301             "Map pg value type ids to getter methods." 
1304                 vt2getter 
= _vt2getter
 
1309                 _vt2getter 
= vt2getter
 
1311         def 
GetPropertyValues(self
,dict_
=None
, as_strings
=False
, inc_attributes
=False
): 
1312             "Returns values in the grid." 
1314             "dict_: if not given, then a new one is created. dict_ can be" 
1315             "  object as well, in which case it's __dict__ is used." 
1316             "as_strings: if True, then string representations of values" 
1317             "  are fetched instead of native types. Useful for config and such." 
1318             "inc_attributes: if True, then property attributes are added" 
1319             "  as @<propname>@<attr>." 
1321             "Return value: dictionary with values. It is always a dictionary," 
1322             "so if dict_ was object with __dict__ attribute, then that attribute" 
1327             elif 
hasattr(dict_
,'__dict__'): 
1328                 dict_ 
= dict_
.__dict__
 
1331                 getter 
= self
.GetPropertyValue
 
1333                 getter 
= self
.GetPropertyValueAsString
 
1335             it 
= self
.GetVIterator(PG_ITERATE_PROPERTIES
) 
1336             while not it
.AtEnd(): 
1337                 p 
= it
.GetProperty() 
1340                 dict_
[name
] = getter(p
) 
1343                     attrs 
= p
.GetAttributes() 
1344                     if attrs 
and len(attrs
): 
1345                         dict_
['@%s@attr'%name
] = attrs
 
1351         GetValues 
= GetPropertyValues
 
1354         def 
SetPropertyValues(self
,dict_
): 
1355             "Sets property values from dict_, which can be either\ndictionary or an object with __dict__ attribute." 
1357             "autofill: If true, keys with not relevant properties" 
1358             "  are auto-created. For more info, see AutoFill." 
1361             "  * Keys starting with underscore are ignored." 
1362             "  * Attributes can be set with entries named @<propname>@<attr>." 
1369             elif 
hasattr(dict_
,'__dict__'): 
1370                 dict_ 
= dict_
.__dict__
 
1374             def 
set_sub_obj(k0
,dict_
): 
1375                 for k
,v in dict_
.iteritems(): 
1377                         if k
.endswith('@attr'): 
1378                             attr_dicts
.append((k
[1:-5],v
)) 
1381                                 self
.SetPropertyValue(k
,v
) 
1385                                         self
._AutoFillOne(k0
,k
,v
) 
1388                                     if isinstance(v
,dict
): 
1390                                     elif 
hasattr(v
,'__dict__'): 
1391                                         set_sub_obj(k
,v
.__dict__
) 
1394             for k
,v in attr_dicts
: 
1395                 p 
= GetPropertyByName(k
) 
1397                     raise 
AssertionError("No such property: '%s'"%k
) 
1398                 for an
,av in v
.iteritems(): 
1399                     p
.SetAttribute(an
, av
) 
1403             is_manager 
= isinstance(self
,PropertyGridManager
) 
1406                 set_sub_obj(self
.GetGrid().GetRoot(),dict_
) 
1409                 traceback
.print_exc() 
1413         SetValues 
= SetPropertyValues
 
1415         def 
_AutoFillMany(self
,cat
,dict_
): 
1416             for k
,v in dict_
.iteritems(): 
1417                 self
._AutoFillOne(cat
,k
,v
) 
1420         def 
_AutoFillOne(self
,cat
,k
,v
): 
1421             global _type2property
 
1423             factory 
= _type2property
.get(v
.__class__
,None
) 
1426                 self
.AppendIn( cat
, factory(k
,k
,v
) ) 
1427             elif 
hasattr(v
,'__dict__'): 
1428                 cat2 
= self
.AppendIn( cat
, PropertyCategory(k
) ) 
1429                 self
._AutoFillMany(cat2
,v
.__dict__
) 
1430             elif 
isinstance(v
,dict
): 
1431                 cat2 
= self
.AppendIn( cat
, PropertyCategory(k
) ) 
1432                 self
._AutoFillMany(cat2
,v
) 
1433             elif 
not k
.startswith('_'): 
1434                 raise 
AssertionError("member '%s' is of unregisted type/class '%s'"%(k
,v
.__class__
)) 
1437         def 
AutoFill(self
,obj
,parent
=None
): 
1438             "Clears properties and re-fills to match members and\nvalues of given object or dictionary obj." 
1440             self
.edited_objects
[parent
] = obj
 
1443             is_manager 
= isinstance(self
,PropertyGridManager
) 
1447                     page 
= self
.GetCurrentPage() 
1449                     parent 
= page
.GetRoot() 
1452                     parent 
= self
.GetGrid().GetRoot() 
1454                 it 
= self
.GetIterator(PG_ITERATE_PROPERTIES
, parent
) 
1455                 it
.Next()  # Skip the parent 
1456                 while not it
.AtEnd(): 
1457                     p 
= it
.GetProperty() 
1458                     if not p
.IsSomeParent(parent
): 
1461                     self
.DeleteProperty(p
) 
1466             if not is_manager 
or page 
== self
.GetCurrentPage(): 
1471                 self
._AutoFillMany(parent
,obj
.__dict__
) 
1474                 traceback
.print_exc() 
1479         def 
RegisterEditor(self
, editor
, editorName
=None
): 
1480             "Transform class into instance, if necessary." 
1481             if not isinstance(editor
, PGEditor
): 
1484                 editorName 
= editor
.__class__
.__name__
 
1486                 self
._editor_instances
.append(editor
) 
1488                 self
._editor_instances 
= [editor
] 
1489             RegisterEditor(editor
, editorName
) 
1491         def 
GetPropertyClientData(self
, p
): 
1492             if isinstance(p
, basestring
): 
1493                 p 
= self
.GetPropertyByName(p
) 
1494             return p
.GetClientData() 
1496         def 
SetPropertyClientData(self
, p
, data
): 
1497             if isinstance(p
, basestring
): 
1498                 p 
= self
.GetPropertyByName(p
) 
1499             return p
.SetClientData(data
) 
1503     // GetPropertyByName With nice assertion error message. 
1504     wxPGProperty
* GetPropertyByNameA( const wxString
& name 
) const; 
1506     static wxPGEditor
* GetEditorByName( const wxString
& editorName 
); 
1508     virtual void RefreshProperty( wxPGProperty
* p 
) = 0; 
1513         In derived class, implement to set editable state component with 
1514         given name to given value. 
1516     virtual bool SetEditableStateItem( const wxString
& name
, wxVariant value 
) 
1524         In derived class, implement to return editable state component with 
1527     virtual wxVariant 
GetEditableStateItem( const wxString
& name 
) const 
1530         return wxNullVariant
; 
1533     // Returns page state data for given (sub) page (-1 means current page). 
1534     virtual wxPropertyGridPageState
* GetPageState( int pageIndex 
) const 
1536         if ( pageIndex 
<= 0 ) 
1541     virtual bool DoSelectPage( int WXUNUSED(index
) ) { return true; } 
1543     // Default call's m_pState's BaseGetPropertyByName 
1544     virtual wxPGProperty
* DoGetPropertyByName( const wxString
& name 
) const; 
1548     // Deriving classes must set this (it must be only or current page). 
1549     wxPropertyGridPageState
*         m_pState
; 
1551     // Intermediate version needed due to wxVariant copying inefficiency 
1552     void DoSetPropertyAttribute( wxPGPropArg id
, 
1553                                  const wxString
& name
, 
1554                                  wxVariant
& value
, long argFlags 
); 
1556     // Empty string object to return from member functions returning const 
1558     wxString                    m_emptyString
; 
1561     // Cannot be GetGrid() due to ambiguity issues. 
1562     wxPropertyGrid
* GetPropertyGrid() 
1564         return m_pState
->GetGrid(); 
1567     // Cannot be GetGrid() due to ambiguity issues. 
1568     const wxPropertyGrid
* GetPropertyGrid() const 
1570         return (const wxPropertyGrid
*) m_pState
->GetGrid(); 
1572 #endif // #ifndef SWIG 
1574     friend class wxPropertyGrid
; 
1575     friend class wxPropertyGridManager
; 
1578 #endif // wxUSE_PROPGRID 
1580 #endif // __WX_PROPGRID_PROPGRIDIFACE_H__