was missing in xti merge
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@66587 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -29,51 +29,61 @@
|
|||||||
#include "wx/tokenzr.h"
|
#include "wx/tokenzr.h"
|
||||||
#include "wx/txtstrm.h"
|
#include "wx/txtstrm.h"
|
||||||
|
|
||||||
|
// STL headers:
|
||||||
|
|
||||||
#include "wx/beforestd.h"
|
#include "wx/beforestd.h"
|
||||||
#include <map>
|
#include <map>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include "wx/afterstd.h"
|
#include "wx/afterstd.h"
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
struct wxWriter::wxWriterInternal
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxObjectWriter
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
struct wxObjectWriter::wxObjectWriterInternal
|
||||||
{
|
{
|
||||||
map< const wxObject*, int > m_writtenObjects;
|
map< const wxObject*, int > m_writtenObjects;
|
||||||
int m_nextId;
|
int m_nextId;
|
||||||
};
|
};
|
||||||
|
|
||||||
wxWriter::wxWriter()
|
wxObjectWriter::wxObjectWriter()
|
||||||
{
|
{
|
||||||
m_data = new wxWriterInternal ;
|
m_data = new wxObjectWriterInternal;
|
||||||
m_data->m_nextId = 0;
|
m_data->m_nextId = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
wxWriter::~wxWriter()
|
wxObjectWriter::~wxObjectWriter()
|
||||||
{
|
{
|
||||||
delete m_data;
|
delete m_data;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct wxWriter::wxWriterInternalPropertiesData
|
struct wxObjectWriter::wxObjectWriterInternalPropertiesData
|
||||||
{
|
{
|
||||||
char nothing;
|
char nothing;
|
||||||
};
|
};
|
||||||
|
|
||||||
void wxWriter::ClearObjectContext()
|
void wxObjectWriter::ClearObjectContext()
|
||||||
{
|
{
|
||||||
delete m_data;
|
delete m_data;
|
||||||
m_data = new wxWriterInternal() ;
|
m_data = new wxObjectWriterInternal();
|
||||||
m_data->m_nextId = 0;
|
m_data->m_nextId = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWriter::WriteObject(const wxObject *object, const wxClassInfo *classInfo , wxPersister *persister , const wxString &name , wxxVariantArray &metadata )
|
void wxObjectWriter::WriteObject(const wxObject *object, const wxClassInfo *classInfo,
|
||||||
|
wxObjectReaderCallback *persister, const wxString &name,
|
||||||
|
wxVariantBaseArray &metadata )
|
||||||
{
|
{
|
||||||
DoBeginWriteTopLevelEntry( name );
|
DoBeginWriteTopLevelEntry( name );
|
||||||
WriteObject( object, classInfo, persister, false, metadata);
|
WriteObject( object, classInfo, persister, false, metadata);
|
||||||
DoEndWriteTopLevelEntry( name );
|
DoEndWriteTopLevelEntry( name );
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWriter::WriteObject(const wxObject *object, const wxClassInfo *classInfo , wxPersister *persister , bool isEmbedded, wxxVariantArray &metadata )
|
void wxObjectWriter::WriteObject(const wxObject *object, const wxClassInfo *classInfo,
|
||||||
|
wxObjectReaderCallback *persister, bool isEmbedded,
|
||||||
|
wxVariantBaseArray &metadata )
|
||||||
{
|
{
|
||||||
if ( !classInfo->BeforeWriteObject( object, this, persister, metadata) )
|
if ( !classInfo->BeforeWriteObject( object, this, persister, metadata) )
|
||||||
return;
|
return;
|
||||||
@@ -92,12 +102,12 @@ void wxWriter::WriteObject(const wxObject *object, const wxClassInfo *classInfo
|
|||||||
|
|
||||||
// in case this object is a wxDynamicObject we also have to insert is superclass
|
// in case this object is a wxDynamicObject we also have to insert is superclass
|
||||||
// instance with the same id, so that object relations are streamed out correctly
|
// instance with the same id, so that object relations are streamed out correctly
|
||||||
const wxDynamicObject* dynobj = dynamic_cast<const wxDynamicObject *>( object ) ;
|
const wxDynamicObject* dynobj = wx_dynamic_cast(const wxDynamicObject*, object);
|
||||||
if ( !isEmbedded && dynobj )
|
if ( !isEmbedded && dynobj )
|
||||||
m_data->m_writtenObjects[dynobj->GetSuperClassInstance()] = oid;
|
m_data->m_writtenObjects[dynobj->GetSuperClassInstance()] = oid;
|
||||||
|
|
||||||
DoBeginWriteObject( object, classInfo, oid, metadata );
|
DoBeginWriteObject( object, classInfo, oid, metadata );
|
||||||
wxWriterInternalPropertiesData data ;
|
wxObjectWriterInternalPropertiesData data;
|
||||||
WriteAllProperties( object, classInfo, persister, &data );
|
WriteAllProperties( object, classInfo, persister, &data );
|
||||||
DoEndWriteObject( object, classInfo, oid );
|
DoEndWriteObject( object, classInfo, oid );
|
||||||
}
|
}
|
||||||
@@ -105,7 +115,10 @@ void wxWriter::WriteObject(const wxObject *object, const wxClassInfo *classInfo
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWriter::FindConnectEntry(const wxEvtHandler * evSource,const wxDelegateTypeInfo* dti, const wxObject* &sink , const wxHandlerInfo *&handler)
|
void wxObjectWriter::FindConnectEntry(const wxEvtHandler * evSource,
|
||||||
|
const wxEventSourceTypeInfo* dti,
|
||||||
|
const wxObject* &sink,
|
||||||
|
const wxHandlerInfo *&handler)
|
||||||
{
|
{
|
||||||
wxList *dynamicEvents = evSource->GetDynamicEventTable();
|
wxList *dynamicEvents = evSource->GetDynamicEventTable();
|
||||||
|
|
||||||
@@ -140,21 +153,24 @@ void wxWriter::FindConnectEntry(const wxEvtHandler * evSource,const wxDelegateTy
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
void wxWriter::WriteAllProperties( const wxObject * obj , const wxClassInfo* ci , wxPersister *persister, wxWriterInternalPropertiesData * data )
|
void wxObjectWriter::WriteAllProperties( const wxObject * obj, const wxClassInfo* ci,
|
||||||
|
wxObjectReaderCallback *persister,
|
||||||
|
wxObjectWriterInternalPropertiesData * data )
|
||||||
{
|
{
|
||||||
wxPropertyInfoMap map;
|
wxPropertyInfoMap map;
|
||||||
ci->GetProperties( map );
|
ci->GetProperties( map );
|
||||||
for ( int i = 0; i < ci->GetCreateParamCount(); ++i )
|
for ( int i = 0; i < ci->GetCreateParamCount(); ++i )
|
||||||
{
|
{
|
||||||
wxString name = ci->GetCreateParamName(i);
|
wxString name = ci->GetCreateParamName(i);
|
||||||
const wxPropertyInfo* prop = map.find(name)->second ;
|
wxPropertyInfoMap::const_iterator iter = map.find(name);
|
||||||
|
const wxPropertyInfo* prop = iter == map.end() ? NULL : iter->second;
|
||||||
if ( prop )
|
if ( prop )
|
||||||
{
|
{
|
||||||
WriteOneProperty( obj, prop->GetDeclaringClass(), prop, persister, data );
|
WriteOneProperty( obj, prop->GetDeclaringClass(), prop, persister, data );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
wxLogError( _("Create Parameter not found in declared RTTI Parameters") ) ;
|
wxLogError( _("Create Parameter %s not found in declared RTTI Parameters"), name.c_str() );
|
||||||
}
|
}
|
||||||
map.erase( name );
|
map.erase( name );
|
||||||
}
|
}
|
||||||
@@ -180,37 +196,42 @@ void wxWriter::WriteAllProperties( const wxObject * obj , const wxClassInfo* ci
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWriter::WriteOneProperty( const wxObject *obj , const wxClassInfo* ci , const wxPropertyInfo* pi , wxPersister *persister , wxWriterInternalPropertiesData *WXUNUSED(data) )
|
void wxObjectWriter::WriteOneProperty( const wxObject *obj, const wxClassInfo* ci,
|
||||||
|
const wxPropertyInfo* pi, wxObjectReaderCallback *persister,
|
||||||
|
wxObjectWriterInternalPropertiesData *WXUNUSED(data) )
|
||||||
{
|
{
|
||||||
if ( pi->GetFlags() & wxPROP_DONT_STREAM )
|
if ( pi->GetFlags() & wxPROP_DONT_STREAM )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// make sure that we are picking the correct object for accessing the property
|
// make sure that we are picking the correct object for accessing the property
|
||||||
const wxDynamicObject* dynobj = dynamic_cast< const wxDynamicObject* > (obj ) ;
|
const wxDynamicObject* dynobj = wx_dynamic_cast(const wxDynamicObject*, obj );
|
||||||
if ( dynobj && (dynamic_cast<const wxDynamicClassInfo*>(ci) == NULL) )
|
if ( dynobj && (wx_dynamic_cast(const wxDynamicClassInfo*, ci) == NULL) )
|
||||||
obj = dynobj->GetSuperClassInstance();
|
obj = dynobj->GetSuperClassInstance();
|
||||||
|
|
||||||
if ( pi->GetTypeInfo()->GetKind() == wxT_COLLECTION )
|
if ( pi->GetTypeInfo()->GetKind() == wxT_COLLECTION )
|
||||||
{
|
{
|
||||||
wxxVariantArray data ;
|
wxVariantBaseArray data;
|
||||||
pi->GetAccessor()->GetPropertyCollection(obj, data);
|
pi->GetAccessor()->GetPropertyCollection(obj, data);
|
||||||
const wxTypeInfo * elementType = dynamic_cast< const wxCollectionTypeInfo* >( pi->GetTypeInfo() )->GetElementType() ;
|
const wxTypeInfo * elementType =
|
||||||
|
wx_dynamic_cast( const wxCollectionTypeInfo*, pi->GetTypeInfo() )->GetElementType();
|
||||||
for ( size_t i = 0; i < data.GetCount(); ++i )
|
for ( size_t i = 0; i < data.GetCount(); ++i )
|
||||||
{
|
{
|
||||||
if ( i == 0 )
|
if ( i == 0 )
|
||||||
DoBeginWriteProperty( pi );
|
DoBeginWriteProperty( pi );
|
||||||
|
|
||||||
DoBeginWriteElement();
|
DoBeginWriteElement();
|
||||||
wxxVariant value = data[i] ;
|
wxVariantBase value = data[i];
|
||||||
if ( persister->BeforeWriteProperty( this, obj, pi, value ) )
|
if ( persister->BeforeWriteProperty( this, obj, pi, value ) )
|
||||||
{
|
{
|
||||||
const wxClassTypeInfo* cti = dynamic_cast< const wxClassTypeInfo* > ( elementType ) ;
|
const wxClassTypeInfo* cti =
|
||||||
|
wx_dynamic_cast( const wxClassTypeInfo*, elementType );
|
||||||
if ( cti )
|
if ( cti )
|
||||||
{
|
{
|
||||||
const wxClassInfo* pci = cti->GetClassInfo();
|
const wxClassInfo* pci = cti->GetClassInfo();
|
||||||
wxObject *vobj = pci->VariantToInstance( value );
|
wxObject *vobj = pci->VariantToInstance( value );
|
||||||
wxxVariantArray md ;
|
wxVariantBaseArray md;
|
||||||
WriteObject( vobj , (vobj ? vobj->GetClassInfo() : pci ) , persister , cti->GetKind()== wxT_OBJECT , md ) ;
|
WriteObject( vobj, (vobj ? vobj->GetClassInfo() : pci ),
|
||||||
|
persister, cti->GetKind()== wxT_OBJECT, md );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -224,13 +245,14 @@ void wxWriter::WriteOneProperty( const wxObject *obj , const wxClassInfo* ci , c
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const wxDelegateTypeInfo* dti = dynamic_cast< const wxDelegateTypeInfo* > ( pi->GetTypeInfo() ) ;
|
const wxEventSourceTypeInfo* dti =
|
||||||
|
wx_dynamic_cast( const wxEventSourceTypeInfo* , pi->GetTypeInfo() );
|
||||||
if ( dti )
|
if ( dti )
|
||||||
{
|
{
|
||||||
const wxObject* sink = NULL;
|
const wxObject* sink = NULL;
|
||||||
const wxHandlerInfo *handler = NULL;
|
const wxHandlerInfo *handler = NULL;
|
||||||
|
|
||||||
const wxEvtHandler * evSource = dynamic_cast<const wxEvtHandler *>(obj) ;
|
const wxEvtHandler * evSource = wx_dynamic_cast(const wxEvtHandler *, obj);
|
||||||
if ( evSource )
|
if ( evSource )
|
||||||
{
|
{
|
||||||
FindConnectEntry( evSource, dti, sink, handler );
|
FindConnectEntry( evSource, dti, sink, handler );
|
||||||
@@ -241,12 +263,14 @@ void wxWriter::WriteOneProperty( const wxObject *obj , const wxClassInfo* ci , c
|
|||||||
DoBeginWriteProperty( pi );
|
DoBeginWriteProperty( pi );
|
||||||
if ( IsObjectKnown( sink ) )
|
if ( IsObjectKnown( sink ) )
|
||||||
{
|
{
|
||||||
DoWriteDelegate( obj , ci , pi , sink , GetObjectID( sink ) , sink->GetClassInfo() , handler ) ;
|
DoWriteDelegate( obj, ci, pi, sink, GetObjectID( sink ),
|
||||||
|
sink->GetClassInfo(), handler );
|
||||||
DoEndWriteProperty( pi );
|
DoEndWriteProperty( pi );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
wxLogError( _("Streaming delegates for not already streamed objects not yet supported") ) ;
|
wxLogError( _T("Streaming delegates for not already ")
|
||||||
|
_T("streamed objects not yet supported") );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -258,7 +282,7 @@ void wxWriter::WriteOneProperty( const wxObject *obj , const wxClassInfo* ci , c
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
wxxVariant value ;
|
wxVariantBase value;
|
||||||
pi->GetAccessor()->GetProperty(obj, value);
|
pi->GetAccessor()->GetProperty(obj, value);
|
||||||
|
|
||||||
// avoid streaming out void objects
|
// avoid streaming out void objects
|
||||||
@@ -267,7 +291,8 @@ void wxWriter::WriteOneProperty( const wxObject *obj , const wxClassInfo* ci , c
|
|||||||
|
|
||||||
if ( pi->GetFlags() & wxPROP_ENUM_STORE_LONG )
|
if ( pi->GetFlags() & wxPROP_ENUM_STORE_LONG )
|
||||||
{
|
{
|
||||||
const wxEnumTypeInfo *eti = dynamic_cast<const wxEnumTypeInfo*>( pi->GetTypeInfo() ) ;
|
const wxEnumTypeInfo *eti =
|
||||||
|
wx_dynamic_cast(const wxEnumTypeInfo*, pi->GetTypeInfo() );
|
||||||
if ( eti )
|
if ( eti )
|
||||||
{
|
{
|
||||||
eti->ConvertFromLong( value.wxTEMPLATED_MEMBER_CALL(Get, long), value );
|
eti->ConvertFromLong( value.wxTEMPLATED_MEMBER_CALL(Get, long), value );
|
||||||
@@ -279,14 +304,16 @@ void wxWriter::WriteOneProperty( const wxObject *obj , const wxClassInfo* ci , c
|
|||||||
}
|
}
|
||||||
|
|
||||||
// avoid streaming out default values
|
// avoid streaming out default values
|
||||||
if ( pi->GetTypeInfo()->HasStringConverters() && !pi->GetDefaultValue().IsEmpty() )
|
if ( pi->GetTypeInfo()->HasStringConverters() &&
|
||||||
|
!pi->GetDefaultValue().IsEmpty() )
|
||||||
{
|
{
|
||||||
if ( value.GetAsString() == pi->GetDefaultValue().GetAsString() )
|
if ( value.GetAsString() == pi->GetDefaultValue().GetAsString() )
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// avoid streaming out null objects
|
// avoid streaming out null objects
|
||||||
const wxClassTypeInfo* cti = dynamic_cast< const wxClassTypeInfo* > ( pi->GetTypeInfo() ) ;
|
const wxClassTypeInfo* cti =
|
||||||
|
wx_dynamic_cast( const wxClassTypeInfo* , pi->GetTypeInfo() );
|
||||||
|
|
||||||
if ( cti && value.GetAsObject() == NULL )
|
if ( cti && value.GetAsObject() == NULL )
|
||||||
return;
|
return;
|
||||||
@@ -302,13 +329,14 @@ void wxWriter::WriteOneProperty( const wxObject *obj , const wxClassInfo* ci , c
|
|||||||
{
|
{
|
||||||
wxString stringValue;
|
wxString stringValue;
|
||||||
cti->ConvertToString( value, stringValue );
|
cti->ConvertToString( value, stringValue );
|
||||||
wxxVariant convertedValue(stringValue) ;
|
wxVariantBase convertedValue(stringValue);
|
||||||
DoWriteSimpleType( convertedValue );
|
DoWriteSimpleType( convertedValue );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
wxxVariantArray md ;
|
wxVariantBaseArray md;
|
||||||
WriteObject( vobj , (vobj ? vobj->GetClassInfo() : pci ) , persister , cti->GetKind()== wxT_OBJECT , md) ;
|
WriteObject( vobj, (vobj ? vobj->GetClassInfo() : pci ),
|
||||||
|
persister, cti->GetKind()== wxT_OBJECT, md);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -321,7 +349,7 @@ void wxWriter::WriteOneProperty( const wxObject *obj , const wxClassInfo* ci , c
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int wxWriter::GetObjectID(const wxObject *obj)
|
int wxObjectWriter::GetObjectID(const wxObject *obj)
|
||||||
{
|
{
|
||||||
if ( !IsObjectKnown( obj ) )
|
if ( !IsObjectKnown( obj ) )
|
||||||
return wxInvalidObjectID;
|
return wxInvalidObjectID;
|
||||||
@@ -329,32 +357,32 @@ int wxWriter::GetObjectID(const wxObject *obj)
|
|||||||
return m_data->m_writtenObjects[obj];
|
return m_data->m_writtenObjects[obj];
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxWriter::IsObjectKnown( const wxObject *obj )
|
bool wxObjectWriter::IsObjectKnown( const wxObject *obj )
|
||||||
{
|
{
|
||||||
return m_data->m_writtenObjects.find( obj ) != m_data->m_writtenObjects.end();
|
return m_data->m_writtenObjects.find( obj ) != m_data->m_writtenObjects.end();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// reading objects in
|
// wxObjectReader
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
struct wxReader::wxReaderInternal
|
struct wxObjectReader::wxObjectReaderInternal
|
||||||
{
|
{
|
||||||
map<int,wxClassInfo*> m_classInfos;
|
map<int,wxClassInfo*> m_classInfos;
|
||||||
};
|
};
|
||||||
|
|
||||||
wxReader::wxReader()
|
wxObjectReader::wxObjectReader()
|
||||||
{
|
{
|
||||||
m_data = new wxReaderInternal;
|
m_data = new wxObjectReaderInternal;
|
||||||
}
|
}
|
||||||
|
|
||||||
wxReader::~wxReader()
|
wxObjectReader::~wxObjectReader()
|
||||||
{
|
{
|
||||||
delete m_data;
|
delete m_data;
|
||||||
}
|
}
|
||||||
|
|
||||||
wxClassInfo* wxReader::GetObjectClassInfo(int objectID)
|
wxClassInfo* wxObjectReader::GetObjectClassInfo(int objectID)
|
||||||
{
|
{
|
||||||
if ( objectID == wxNullObjectID || objectID == wxInvalidObjectID )
|
if ( objectID == wxNullObjectID || objectID == wxInvalidObjectID )
|
||||||
{
|
{
|
||||||
@@ -369,7 +397,7 @@ wxClassInfo* wxReader::GetObjectClassInfo(int objectID)
|
|||||||
return m_data->m_classInfos[objectID];
|
return m_data->m_classInfos[objectID];
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxReader::SetObjectClassInfo(int objectID, wxClassInfo *classInfo )
|
void wxObjectReader::SetObjectClassInfo(int objectID, wxClassInfo *classInfo )
|
||||||
{
|
{
|
||||||
if ( objectID == wxNullObjectID || objectID == wxInvalidObjectID )
|
if ( objectID == wxNullObjectID || objectID == wxInvalidObjectID )
|
||||||
{
|
{
|
||||||
@@ -384,7 +412,7 @@ void wxReader::SetObjectClassInfo(int objectID, wxClassInfo *classInfo )
|
|||||||
m_data->m_classInfos[objectID] = classInfo;
|
m_data->m_classInfos[objectID] = classInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxReader::HasObjectClassInfo( int objectID )
|
bool wxObjectReader::HasObjectClassInfo( int objectID )
|
||||||
{
|
{
|
||||||
if ( objectID == wxNullObjectID || objectID == wxInvalidObjectID )
|
if ( objectID == wxNullObjectID || objectID == wxInvalidObjectID )
|
||||||
{
|
{
|
||||||
@@ -407,10 +435,10 @@ and create params are always toplevel class only
|
|||||||
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// depersisting to memory
|
// wxObjectRuntimeReaderCallback - depersisting to memory
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
struct wxRuntimeDepersister::wxRuntimeDepersisterInternal
|
struct wxObjectRuntimeReaderCallback::wxObjectRuntimeReaderCallbackInternal
|
||||||
{
|
{
|
||||||
map<int,wxObject *> m_objects;
|
map<int,wxObject *> m_objects;
|
||||||
|
|
||||||
@@ -429,7 +457,7 @@ struct wxRuntimeDepersister::wxRuntimeDepersisterInternal
|
|||||||
return NULL;
|
return NULL;
|
||||||
if ( m_objects.find(objectID) == m_objects.end() )
|
if ( m_objects.find(objectID) == m_objects.end() )
|
||||||
{
|
{
|
||||||
wxLogError( _("Passing an unknown object to GetObject") ) ;
|
wxLogError( _("Passing an unkown object to GetObject") );
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -437,31 +465,31 @@ struct wxRuntimeDepersister::wxRuntimeDepersisterInternal
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
wxRuntimeDepersister::wxRuntimeDepersister()
|
wxObjectRuntimeReaderCallback::wxObjectRuntimeReaderCallback()
|
||||||
{
|
{
|
||||||
m_data = new wxRuntimeDepersisterInternal() ;
|
m_data = new wxObjectRuntimeReaderCallbackInternal();
|
||||||
}
|
}
|
||||||
|
|
||||||
wxRuntimeDepersister::~wxRuntimeDepersister()
|
wxObjectRuntimeReaderCallback::~wxObjectRuntimeReaderCallback()
|
||||||
{
|
{
|
||||||
delete m_data;
|
delete m_data;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxRuntimeDepersister::AllocateObject(int objectID, wxClassInfo *classInfo ,
|
void wxObjectRuntimeReaderCallback::AllocateObject(int objectID, wxClassInfo *classInfo,
|
||||||
wxxVariantArray &WXUNUSED(metadata))
|
wxVariantBaseArray &WXUNUSED(metadata))
|
||||||
{
|
{
|
||||||
wxObject *O;
|
wxObject *O;
|
||||||
O = classInfo->CreateObject();
|
O = classInfo->CreateObject();
|
||||||
m_data->SetObject(objectID, O);
|
m_data->SetObject(objectID, O);
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxRuntimeDepersister::CreateObject(int objectID,
|
void wxObjectRuntimeReaderCallback::CreateObject(int objectID,
|
||||||
const wxClassInfo *classInfo,
|
const wxClassInfo *classInfo,
|
||||||
int paramCount,
|
int paramCount,
|
||||||
wxxVariant *params,
|
wxVariantBase *params,
|
||||||
int *objectIdValues,
|
int *objectIdValues,
|
||||||
const wxClassInfo **objectClassInfos,
|
const wxClassInfo **objectClassInfos,
|
||||||
wxxVariantArray &WXUNUSED(metadata))
|
wxVariantBaseArray &WXUNUSED(metadata))
|
||||||
{
|
{
|
||||||
wxObject *o;
|
wxObject *o;
|
||||||
o = m_data->GetObject(objectID);
|
o = m_data->GetObject(objectID);
|
||||||
@@ -473,7 +501,7 @@ void wxRuntimeDepersister::CreateObject(int objectID,
|
|||||||
o = m_data->GetObject(objectIdValues[i]);
|
o = m_data->GetObject(objectIdValues[i]);
|
||||||
// if this is a dynamic object and we are asked for another class
|
// if this is a dynamic object and we are asked for another class
|
||||||
// than wxDynamicObject we cast it down manually.
|
// than wxDynamicObject we cast it down manually.
|
||||||
wxDynamicObject *dyno = dynamic_cast< wxDynamicObject * > (o) ;
|
wxDynamicObject *dyno = wx_dynamic_cast( wxDynamicObject *, o);
|
||||||
if ( dyno!=NULL && (objectClassInfos[i] != dyno->GetClassInfo()) )
|
if ( dyno!=NULL && (objectClassInfos[i] != dyno->GetClassInfo()) )
|
||||||
{
|
{
|
||||||
o = dyno->GetSuperClassInstance();
|
o = dyno->GetSuperClassInstance();
|
||||||
@@ -484,13 +512,13 @@ void wxRuntimeDepersister::CreateObject(int objectID,
|
|||||||
classInfo->Create(o, paramCount, params);
|
classInfo->Create(o, paramCount, params);
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxRuntimeDepersister::ConstructObject(int objectID,
|
void wxObjectRuntimeReaderCallback::ConstructObject(int objectID,
|
||||||
const wxClassInfo *classInfo,
|
const wxClassInfo *classInfo,
|
||||||
int paramCount,
|
int paramCount,
|
||||||
wxxVariant *params,
|
wxVariantBase *params,
|
||||||
int *objectIdValues,
|
int *objectIdValues,
|
||||||
const wxClassInfo **objectClassInfos,
|
const wxClassInfo **objectClassInfos,
|
||||||
wxxVariantArray &WXUNUSED(metadata))
|
wxVariantBaseArray &WXUNUSED(metadata))
|
||||||
{
|
{
|
||||||
wxObject *o;
|
wxObject *o;
|
||||||
for ( int i = 0; i < paramCount; ++i )
|
for ( int i = 0; i < paramCount; ++i )
|
||||||
@@ -501,7 +529,7 @@ void wxRuntimeDepersister::ConstructObject(int objectID,
|
|||||||
o = m_data->GetObject(objectIdValues[i]);
|
o = m_data->GetObject(objectIdValues[i]);
|
||||||
// if this is a dynamic object and we are asked for another class
|
// if this is a dynamic object and we are asked for another class
|
||||||
// than wxDynamicObject we cast it down manually.
|
// than wxDynamicObject we cast it down manually.
|
||||||
wxDynamicObject *dyno = dynamic_cast< wxDynamicObject * > (o) ;
|
wxDynamicObject *dyno = wx_dynamic_cast( wxDynamicObject *, o);
|
||||||
if ( dyno!=NULL && (objectClassInfos[i] != dyno->GetClassInfo()) )
|
if ( dyno!=NULL && (objectClassInfos[i] != dyno->GetClassInfo()) )
|
||||||
{
|
{
|
||||||
o = dyno->GetSuperClassInstance();
|
o = dyno->GetSuperClassInstance();
|
||||||
@@ -514,24 +542,24 @@ void wxRuntimeDepersister::ConstructObject(int objectID,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void wxRuntimeDepersister::DestroyObject(int objectID, wxClassInfo *WXUNUSED(classInfo))
|
void wxObjectRuntimeReaderCallback::DestroyObject(int objectID, wxClassInfo *WXUNUSED(classInfo))
|
||||||
{
|
{
|
||||||
wxObject *o;
|
wxObject *o;
|
||||||
o = m_data->GetObject(objectID);
|
o = m_data->GetObject(objectID);
|
||||||
delete o;
|
delete o;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxRuntimeDepersister::SetProperty(int objectID,
|
void wxObjectRuntimeReaderCallback::SetProperty(int objectID,
|
||||||
const wxClassInfo *classInfo,
|
const wxClassInfo *classInfo,
|
||||||
const wxPropertyInfo* propertyInfo,
|
const wxPropertyInfo* propertyInfo,
|
||||||
const wxxVariant &value)
|
const wxVariantBase &value)
|
||||||
{
|
{
|
||||||
wxObject *o;
|
wxObject *o;
|
||||||
o = m_data->GetObject(objectID);
|
o = m_data->GetObject(objectID);
|
||||||
classInfo->SetProperty( o, propertyInfo->GetName(), value );
|
classInfo->SetProperty( o, propertyInfo->GetName(), value );
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxRuntimeDepersister::SetPropertyAsObject(int objectID,
|
void wxObjectRuntimeReaderCallback::SetPropertyAsObject(int objectID,
|
||||||
const wxClassInfo *classInfo,
|
const wxClassInfo *classInfo,
|
||||||
const wxPropertyInfo* propertyInfo,
|
const wxPropertyInfo* propertyInfo,
|
||||||
int valueObjectId)
|
int valueObjectId)
|
||||||
@@ -539,31 +567,37 @@ void wxRuntimeDepersister::SetPropertyAsObject(int objectID,
|
|||||||
wxObject *o, *valo;
|
wxObject *o, *valo;
|
||||||
o = m_data->GetObject(objectID);
|
o = m_data->GetObject(objectID);
|
||||||
valo = m_data->GetObject(valueObjectId);
|
valo = m_data->GetObject(valueObjectId);
|
||||||
const wxClassInfo* valClassInfo = (dynamic_cast<const wxClassTypeInfo*>(propertyInfo->GetTypeInfo()))->GetClassInfo() ;
|
const wxClassInfo* valClassInfo =
|
||||||
|
(wx_dynamic_cast(const wxClassTypeInfo*,propertyInfo->GetTypeInfo()))->GetClassInfo();
|
||||||
|
|
||||||
// if this is a dynamic object and we are asked for another class
|
// if this is a dynamic object and we are asked for another class
|
||||||
// than wxDynamicObject we cast it down manually.
|
// than wxDynamicObject we cast it down manually.
|
||||||
wxDynamicObject *dynvalo = dynamic_cast< wxDynamicObject * > (valo) ;
|
wxDynamicObject *dynvalo = wx_dynamic_cast( wxDynamicObject *, valo);
|
||||||
if ( dynvalo!=NULL && (valClassInfo != dynvalo->GetClassInfo()) )
|
if ( dynvalo!=NULL && (valClassInfo != dynvalo->GetClassInfo()) )
|
||||||
{
|
{
|
||||||
valo = dynvalo->GetSuperClassInstance();
|
valo = dynvalo->GetSuperClassInstance();
|
||||||
}
|
}
|
||||||
|
|
||||||
classInfo->SetProperty( o , propertyInfo->GetName() , valClassInfo->InstanceToVariant(valo) ) ;
|
classInfo->SetProperty( o, propertyInfo->GetName(),
|
||||||
|
valClassInfo->InstanceToVariant(valo) );
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxRuntimeDepersister::SetConnect(int eventSourceObjectID,
|
void wxObjectRuntimeReaderCallback::SetConnect(int eventSourceObjectID,
|
||||||
const wxClassInfo *WXUNUSED(eventSourceClassInfo),
|
const wxClassInfo *WXUNUSED(eventSourceClassInfo),
|
||||||
const wxPropertyInfo *delegateInfo,
|
const wxPropertyInfo *delegateInfo,
|
||||||
const wxClassInfo *WXUNUSED(eventSinkClassInfo),
|
const wxClassInfo *WXUNUSED(eventSinkClassInfo),
|
||||||
const wxHandlerInfo* handlerInfo,
|
const wxHandlerInfo* handlerInfo,
|
||||||
int eventSinkObjectID )
|
int eventSinkObjectID )
|
||||||
{
|
{
|
||||||
wxEvtHandler *ehsource = dynamic_cast< wxEvtHandler* >( m_data->GetObject( eventSourceObjectID ) ) ;
|
wxEvtHandler *ehsource =
|
||||||
wxEvtHandler *ehsink = dynamic_cast< wxEvtHandler *>(m_data->GetObject(eventSinkObjectID) ) ;
|
wx_dynamic_cast( wxEvtHandler* , m_data->GetObject( eventSourceObjectID ) );
|
||||||
|
wxEvtHandler *ehsink =
|
||||||
|
wx_dynamic_cast( wxEvtHandler *,m_data->GetObject(eventSinkObjectID) );
|
||||||
|
|
||||||
if ( ehsource && ehsink )
|
if ( ehsource && ehsink )
|
||||||
{
|
{
|
||||||
const wxDelegateTypeInfo *delegateTypeInfo = dynamic_cast<const wxDelegateTypeInfo*>(delegateInfo->GetTypeInfo());
|
const wxEventSourceTypeInfo *delegateTypeInfo =
|
||||||
|
wx_dynamic_cast(const wxEventSourceTypeInfo*,delegateInfo->GetTypeInfo());
|
||||||
if( delegateTypeInfo && delegateTypeInfo->GetLastEventType() == -1 )
|
if( delegateTypeInfo && delegateTypeInfo->GetLastEventType() == -1 )
|
||||||
{
|
{
|
||||||
ehsource->Connect( -1, delegateTypeInfo->GetEventType(),
|
ehsource->Connect( -1, delegateTypeInfo->GetEventType(),
|
||||||
@@ -572,7 +606,8 @@ void wxRuntimeDepersister::SetConnect(int eventSourceObjectID,
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
for ( wxEventType iter = delegateTypeInfo->GetEventType() ; iter <= delegateTypeInfo->GetLastEventType() ; ++iter )
|
for ( wxEventType iter = delegateTypeInfo->GetEventType();
|
||||||
|
iter <= delegateTypeInfo->GetLastEventType(); ++iter )
|
||||||
{
|
{
|
||||||
ehsource->Connect( -1, iter,
|
ehsource->Connect( -1, iter,
|
||||||
handlerInfo->GetEventFunction(), NULL /*user data*/,
|
handlerInfo->GetEventFunction(), NULL /*user data*/,
|
||||||
@@ -582,24 +617,22 @@ void wxRuntimeDepersister::SetConnect(int eventSourceObjectID,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
wxObject *wxRuntimeDepersister::GetObject(int objectID)
|
wxObject *wxObjectRuntimeReaderCallback::GetObject(int objectID)
|
||||||
{
|
{
|
||||||
return m_data->GetObject( objectID );
|
return m_data->GetObject( objectID );
|
||||||
}
|
}
|
||||||
|
|
||||||
// adds an element to a property collection
|
void wxObjectRuntimeReaderCallback::AddToPropertyCollection( int objectID,
|
||||||
void wxRuntimeDepersister::AddToPropertyCollection( int objectID ,
|
|
||||||
const wxClassInfo *classInfo,
|
const wxClassInfo *classInfo,
|
||||||
const wxPropertyInfo* propertyInfo,
|
const wxPropertyInfo* propertyInfo,
|
||||||
const wxxVariant &value)
|
const wxVariantBase &value)
|
||||||
{
|
{
|
||||||
wxObject *o;
|
wxObject *o;
|
||||||
o = m_data->GetObject(objectID);
|
o = m_data->GetObject(objectID);
|
||||||
classInfo->AddToPropertyCollection( o, propertyInfo->GetName(), value );
|
classInfo->AddToPropertyCollection( o, propertyInfo->GetName(), value );
|
||||||
}
|
}
|
||||||
|
|
||||||
// sets the corresponding property (value is an object)
|
void wxObjectRuntimeReaderCallback::AddToPropertyCollectionAsObject(int objectID,
|
||||||
void wxRuntimeDepersister::AddToPropertyCollectionAsObject(int objectID,
|
|
||||||
const wxClassInfo *classInfo,
|
const wxClassInfo *classInfo,
|
||||||
const wxPropertyInfo* propertyInfo,
|
const wxPropertyInfo* propertyInfo,
|
||||||
int valueObjectId)
|
int valueObjectId)
|
||||||
@@ -607,241 +640,26 @@ void wxRuntimeDepersister::AddToPropertyCollectionAsObject(int objectID,
|
|||||||
wxObject *o, *valo;
|
wxObject *o, *valo;
|
||||||
o = m_data->GetObject(objectID);
|
o = m_data->GetObject(objectID);
|
||||||
valo = m_data->GetObject(valueObjectId);
|
valo = m_data->GetObject(valueObjectId);
|
||||||
const wxCollectionTypeInfo * collectionTypeInfo = dynamic_cast< const wxCollectionTypeInfo * >(propertyInfo->GetTypeInfo() ) ;
|
const wxCollectionTypeInfo * collectionTypeInfo =
|
||||||
const wxClassInfo* valClassInfo = (dynamic_cast<const wxClassTypeInfo*>(collectionTypeInfo->GetElementType()))->GetClassInfo() ;
|
wx_dynamic_cast( const wxCollectionTypeInfo *, propertyInfo->GetTypeInfo() );
|
||||||
|
const wxClassInfo* valClassInfo =
|
||||||
|
(wx_dynamic_cast(const wxClassTypeInfo*,collectionTypeInfo->GetElementType()))->GetClassInfo();
|
||||||
|
|
||||||
// if this is a dynamic object and we are asked for another class
|
// if this is a dynamic object and we are asked for another class
|
||||||
// than wxDynamicObject we cast it down manually.
|
// than wxDynamicObject we cast it down manually.
|
||||||
wxDynamicObject *dynvalo = dynamic_cast< wxDynamicObject * > (valo) ;
|
wxDynamicObject *dynvalo = wx_dynamic_cast( wxDynamicObject *, valo);
|
||||||
if ( dynvalo!=NULL && (valClassInfo != dynvalo->GetClassInfo()) )
|
if ( dynvalo!=NULL && (valClassInfo != dynvalo->GetClassInfo()) )
|
||||||
{
|
{
|
||||||
valo = dynvalo->GetSuperClassInstance();
|
valo = dynvalo->GetSuperClassInstance();
|
||||||
}
|
}
|
||||||
|
|
||||||
classInfo->AddToPropertyCollection( o , propertyInfo->GetName() , valClassInfo->InstanceToVariant(valo) ) ;
|
classInfo->AddToPropertyCollection( o, propertyInfo->GetName(),
|
||||||
|
valClassInfo->InstanceToVariant(valo) );
|
||||||
}
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
#if TEST_XVARIANT
|
||||||
// depersisting to code
|
#include "wx/arrimpl.cpp"
|
||||||
// ----------------------------------------------------------------------------
|
WX_DEFINE_OBJARRAY(wxVariantBaseArray);
|
||||||
|
|
||||||
struct wxCodeDepersister::wxCodeDepersisterInternal
|
|
||||||
{
|
|
||||||
#if wxUSE_UNICODE
|
|
||||||
map<int,wstring> m_objectNames ;
|
|
||||||
#else
|
|
||||||
map<int,string> m_objectNames ;
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void SetObjectName(int objectID, const wxString &name )
|
|
||||||
{
|
|
||||||
if ( m_objectNames.find(objectID) != m_objectNames.end() )
|
|
||||||
{
|
|
||||||
wxLogError( _("Passing a already registered object to SetObjectName") ) ;
|
|
||||||
return ;
|
|
||||||
}
|
|
||||||
m_objectNames[objectID] = (const wxChar *)name;
|
|
||||||
}
|
|
||||||
|
|
||||||
wxString GetObjectName( int objectID )
|
|
||||||
{
|
|
||||||
if ( objectID == wxNullObjectID )
|
|
||||||
return wxT("NULL") ;
|
|
||||||
|
|
||||||
if ( m_objectNames.find(objectID) == m_objectNames.end() )
|
|
||||||
{
|
|
||||||
wxLogError( _("Passing an unknown object to GetObject") ) ;
|
|
||||||
return wxEmptyString ;
|
|
||||||
}
|
|
||||||
return wxString( m_objectNames[objectID].c_str() ) ;
|
|
||||||
}
|
|
||||||
} ;
|
|
||||||
|
|
||||||
wxCodeDepersister::wxCodeDepersister(wxTextOutputStream *out)
|
|
||||||
: m_fp(out)
|
|
||||||
{
|
|
||||||
m_data = new wxCodeDepersisterInternal ;
|
|
||||||
}
|
|
||||||
|
|
||||||
wxCodeDepersister::~wxCodeDepersister()
|
|
||||||
{
|
|
||||||
delete m_data ;
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxCodeDepersister::AllocateObject(int objectID, wxClassInfo *classInfo ,
|
|
||||||
wxxVariantArray &WXUNUSED(metadata))
|
|
||||||
{
|
|
||||||
wxString objectName = wxString::Format( wxT("LocalObject_%d") , objectID ) ;
|
|
||||||
m_fp->WriteString( wxString::Format( wxT("\t%s *%s = new %s;\n"),
|
|
||||||
classInfo->GetClassName(),
|
|
||||||
objectName.c_str(),
|
|
||||||
classInfo->GetClassName()) );
|
|
||||||
m_data->SetObjectName( objectID , objectName ) ;
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxCodeDepersister::DestroyObject(int objectID, wxClassInfo *WXUNUSED(classInfo))
|
|
||||||
{
|
|
||||||
m_fp->WriteString( wxString::Format( wxT("\tdelete %s;\n"),
|
|
||||||
m_data->GetObjectName( objectID).c_str() ) );
|
|
||||||
}
|
|
||||||
|
|
||||||
wxString wxCodeDepersister::ValueAsCode( const wxxVariant ¶m )
|
|
||||||
{
|
|
||||||
wxString value ;
|
|
||||||
const wxTypeInfo* type = param.GetTypeInfo() ;
|
|
||||||
if ( type->GetKind() == wxT_CUSTOM )
|
|
||||||
{
|
|
||||||
const wxCustomTypeInfo* cti = dynamic_cast<const wxCustomTypeInfo*>(type) ;
|
|
||||||
if ( cti )
|
|
||||||
{
|
|
||||||
value.Printf( wxT("%s(%s)"), cti->GetTypeName().c_str(),param.GetAsString().c_str() );
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
wxLogError ( _("Internal error, illegal wxCustomTypeInfo") ) ;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if ( type->GetKind() == wxT_STRING )
|
|
||||||
{
|
|
||||||
value.Printf( wxT("\"%s\""),param.GetAsString().c_str() );
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
value.Printf( wxT("%s"), param.GetAsString().c_str() );
|
|
||||||
}
|
|
||||||
return value ;
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxCodeDepersister::CreateObject(int objectID,
|
|
||||||
const wxClassInfo *WXUNUSED(classInfo),
|
|
||||||
int paramCount,
|
|
||||||
wxxVariant *params,
|
|
||||||
int *objectIDValues,
|
|
||||||
const wxClassInfo **WXUNUSED(objectClassInfos) ,
|
|
||||||
wxxVariantArray &WXUNUSED(metadata)
|
|
||||||
)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
m_fp->WriteString( wxString::Format( wxT("\t%s->Create("), m_data->GetObjectName(objectID).c_str() ) );
|
|
||||||
for (i = 0; i < paramCount; i++)
|
|
||||||
{
|
|
||||||
if ( objectIDValues[i] != wxInvalidObjectID )
|
|
||||||
m_fp->WriteString( wxString::Format( wxT("%s"), m_data->GetObjectName( objectIDValues[i] ).c_str() ) );
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_fp->WriteString( wxString::Format( wxT("%s"), ValueAsCode(params[i]).c_str() ) );
|
|
||||||
}
|
|
||||||
if (i < paramCount - 1)
|
|
||||||
m_fp->WriteString( wxT(", "));
|
|
||||||
}
|
|
||||||
m_fp->WriteString( wxT(");\n") );
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxCodeDepersister::ConstructObject(int objectID,
|
|
||||||
const wxClassInfo *classInfo,
|
|
||||||
int paramCount,
|
|
||||||
wxxVariant *params,
|
|
||||||
int *objectIDValues,
|
|
||||||
const wxClassInfo **WXUNUSED(objectClassInfos) ,
|
|
||||||
wxxVariantArray &WXUNUSED(metadata)
|
|
||||||
)
|
|
||||||
{
|
|
||||||
wxString objectName = wxString::Format( wxT("LocalObject_%d") , objectID ) ;
|
|
||||||
m_fp->WriteString( wxString::Format( wxT("\t%s *%s = new %s("),
|
|
||||||
classInfo->GetClassName(),
|
|
||||||
objectName.c_str(),
|
|
||||||
classInfo->GetClassName()) );
|
|
||||||
m_data->SetObjectName( objectID , objectName ) ;
|
|
||||||
|
|
||||||
int i;
|
|
||||||
for (i = 0; i < paramCount; i++)
|
|
||||||
{
|
|
||||||
if ( objectIDValues[i] != wxInvalidObjectID )
|
|
||||||
m_fp->WriteString( wxString::Format( wxT("%s"), m_data->GetObjectName( objectIDValues[i] ).c_str() ) );
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_fp->WriteString( wxString::Format( wxT("%s"), ValueAsCode(params[i]).c_str() ) );
|
|
||||||
}
|
|
||||||
if (i < paramCount - 1)
|
|
||||||
m_fp->WriteString( wxT(", ") );
|
|
||||||
}
|
|
||||||
m_fp->WriteString( wxT(");\n") );
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxCodeDepersister::SetProperty(int objectID,
|
|
||||||
const wxClassInfo *WXUNUSED(classInfo),
|
|
||||||
const wxPropertyInfo* propertyInfo,
|
|
||||||
const wxxVariant &value)
|
|
||||||
{
|
|
||||||
m_fp->WriteString( wxString::Format( wxT("\t%s->%s(%s);\n"),
|
|
||||||
m_data->GetObjectName(objectID).c_str(),
|
|
||||||
propertyInfo->GetAccessor()->GetSetterName().c_str(),
|
|
||||||
ValueAsCode(value).c_str()) );
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxCodeDepersister::SetPropertyAsObject(int objectID,
|
|
||||||
const wxClassInfo *WXUNUSED(classInfo),
|
|
||||||
const wxPropertyInfo* propertyInfo,
|
|
||||||
int valueObjectId)
|
|
||||||
{
|
|
||||||
if ( propertyInfo->GetTypeInfo()->GetKind() == wxT_OBJECT )
|
|
||||||
m_fp->WriteString( wxString::Format( wxT("\t%s->%s(*%s);\n"),
|
|
||||||
m_data->GetObjectName(objectID).c_str(),
|
|
||||||
propertyInfo->GetAccessor()->GetSetterName().c_str(),
|
|
||||||
m_data->GetObjectName( valueObjectId).c_str() ) );
|
|
||||||
else
|
|
||||||
m_fp->WriteString( wxString::Format( wxT("\t%s->%s(%s);\n"),
|
|
||||||
m_data->GetObjectName(objectID).c_str(),
|
|
||||||
propertyInfo->GetAccessor()->GetSetterName().c_str(),
|
|
||||||
m_data->GetObjectName( valueObjectId).c_str() ) );
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxCodeDepersister::AddToPropertyCollection( int objectID ,
|
|
||||||
const wxClassInfo *WXUNUSED(classInfo),
|
|
||||||
const wxPropertyInfo* propertyInfo ,
|
|
||||||
const wxxVariant &value)
|
|
||||||
{
|
|
||||||
m_fp->WriteString( wxString::Format( wxT("\t%s->%s(%s);\n"),
|
|
||||||
m_data->GetObjectName(objectID).c_str(),
|
|
||||||
propertyInfo->GetAccessor()->GetAdderName().c_str(),
|
|
||||||
ValueAsCode(value).c_str()) );
|
|
||||||
}
|
|
||||||
|
|
||||||
// sets the corresponding property (value is an object)
|
|
||||||
void wxCodeDepersister::AddToPropertyCollectionAsObject(int WXUNUSED(objectID),
|
|
||||||
const wxClassInfo *WXUNUSED(classInfo),
|
|
||||||
const wxPropertyInfo* WXUNUSED(propertyInfo) ,
|
|
||||||
int WXUNUSED(valueObjectId))
|
|
||||||
{
|
|
||||||
// TODO
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxCodeDepersister::SetConnect(int eventSourceObjectID,
|
|
||||||
const wxClassInfo *WXUNUSED(eventSourceClassInfo),
|
|
||||||
const wxPropertyInfo *delegateInfo ,
|
|
||||||
const wxClassInfo *eventSinkClassInfo ,
|
|
||||||
const wxHandlerInfo* handlerInfo ,
|
|
||||||
int eventSinkObjectID )
|
|
||||||
{
|
|
||||||
wxString ehsource = m_data->GetObjectName( eventSourceObjectID ) ;
|
|
||||||
wxString ehsink = m_data->GetObjectName(eventSinkObjectID) ;
|
|
||||||
wxString ehsinkClass = eventSinkClassInfo->GetClassName() ;
|
|
||||||
const wxDelegateTypeInfo *delegateTypeInfo = dynamic_cast<const wxDelegateTypeInfo*>(delegateInfo->GetTypeInfo());
|
|
||||||
if ( delegateTypeInfo )
|
|
||||||
{
|
|
||||||
int eventType = delegateTypeInfo->GetEventType() ;
|
|
||||||
wxString handlerName = handlerInfo->GetName() ;
|
|
||||||
|
|
||||||
m_fp->WriteString( wxString::Format( wxT("\t%s->Connect( %s->GetId() , %d , (wxObjectEventFunction)(wxEventFunction) & %s::%s , NULL , %s ) ;") ,
|
|
||||||
ehsource.c_str() , ehsource.c_str() , eventType , ehsinkClass.c_str() , handlerName.c_str() , ehsink.c_str() ) );
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
wxLogError(_("delegate has no type info"));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#include "wx/arrimpl.cpp"
|
|
||||||
|
|
||||||
WX_DEFINE_OBJARRAY(wxxVariantArray)
|
|
||||||
|
|
||||||
#endif // wxUSE_EXTENDED_RTTI
|
#endif // wxUSE_EXTENDED_RTTI
|
||||||
|
|||||||
Reference in New Issue
Block a user