}
};
-wxObjectCodeReaderCallback::wxObjectCodeReaderCallback(wxTextOutputStream *out)
-: m_fp(out)
+wxObjectCodeReaderCallback::wxObjectCodeReaderCallback(wxString& headerincludes, wxString &source)
+: m_headerincludes(headerincludes),m_source(source)
{
m_data = new wxObjectCodeReaderCallbackInternal;
}
}
void wxObjectCodeReaderCallback::AllocateObject(int objectID, wxClassInfo *classInfo,
- wxVariantBaseArray &WXUNUSED(metadata))
+ wxStringToAnyHashMap &WXUNUSED(metadata))
{
+ if ( classInfo->GetIncludeName() != wxEmptyString)
+ {
+ // add corresponding header if not already included
+ wxString include;
+ include.Printf(wxT("#include \"%s\"\n"),classInfo->GetIncludeName());
+ if ( m_headerincludes.Find(include) == wxNOT_FOUND)
+ m_headerincludes += include;
+ }
+
wxString objectName = wxString::Format( wxT("LocalObject_%d"), objectID );
- m_fp->WriteString( wxString::Format( wxT("\t%s *%s = new %s;\n"),
+ m_source += ( wxString::Format( wxT("\t%s *%s = new %s;\n"),
classInfo->GetClassName(),
objectName.c_str(),
classInfo->GetClassName()) );
void wxObjectCodeReaderCallback::DestroyObject(int objectID, wxClassInfo *WXUNUSED(classInfo))
{
- m_fp->WriteString( wxString::Format( wxT("\tdelete %s;\n"),
+ m_source += ( wxString::Format( wxT("\tdelete %s;\n"),
m_data->GetObjectName( objectID).c_str() ) );
}
-wxString wxObjectCodeReaderCallback::ValueAsCode( const wxVariantBase ¶m )
+class WXDLLIMPEXP_BASE wxObjectConstructorWriter: public wxObjectWriterFunctor
+{
+public:
+ wxObjectConstructorWriter(const wxClassTypeInfo* cti,
+ wxObjectCodeReaderCallback* writer) :
+ m_cti(cti),m_writer(writer)
+ {}
+
+ virtual void operator()(const wxObject *vobj)
+ {
+ const wxClassInfo* ci = m_cti->GetClassInfo();
+
+ for ( int i = 0; i < ci->GetCreateParamCount(); ++i )
+ {
+ wxString name = ci->GetCreateParamName(i);
+ const wxPropertyInfo* prop = ci->FindPropertyInfo(name);
+ if ( i > 0 )
+ m_constructor += ", ";
+ wxAny value;
+ prop->GetAccessor()->GetProperty(vobj, value);
+ m_constructor+= m_writer->ValueAsCode(value);
+ }
+ }
+
+ const wxString& GetConstructorString() const { return m_constructor;}
+private:
+ const wxClassTypeInfo* m_cti;
+ wxObjectCodeReaderCallback* m_writer;
+ wxString m_constructor;
+};
+
+wxString wxObjectCodeReaderCallback::ValueAsCode( const wxAny ¶m )
{
wxString value;
+
const wxTypeInfo* type = param.GetTypeInfo();
if ( type->GetKind() == wxT_CUSTOM )
{
if ( cti )
{
value.Printf( wxT("%s(%s)"), cti->GetTypeName().c_str(),
- param.GetAsString().c_str() );
+ wxAnyGetAsString(param).c_str() );
}
else
{
}
else if ( type->GetKind() == wxT_STRING )
{
- value.Printf( wxT("\"%s\""),param.GetAsString().c_str() );
+ value.Printf( wxT("\"%s\""), wxAnyGetAsString(param).c_str() );
+ }
+ else if ( type->GetKind() == wxT_OBJECT )
+ {
+ const wxClassTypeInfo* ctype = wx_dynamic_cast(const wxClassTypeInfo*,type);
+ const wxClassInfo* ci = ctype->GetClassInfo();
+ if( ci->NeedsDirectConstruction())
+ {
+ wxObjectConstructorWriter cw(ctype,this);
+
+ ci->CallOnAny(param,&cw);
+
+ value.Printf( wxT("%s(%s)"), ctype->GetClassInfo()->GetClassName(),
+ cw.GetConstructorString() );
+ }
}
else
{
- value.Printf( wxT("%s"), param.GetAsString().c_str() );
+ value.Printf( wxT("%s"), wxAnyGetAsString(param).c_str() );
}
+
return value;
}
void wxObjectCodeReaderCallback::CreateObject(int objectID,
const wxClassInfo *WXUNUSED(classInfo),
int paramCount,
- wxVariantBase *params,
+ wxAny *params,
int *objectIDValues,
const wxClassInfo **WXUNUSED(objectClassInfos),
- wxVariantBaseArray &WXUNUSED(metadata)
+ wxStringToAnyHashMap &WXUNUSED(metadata)
)
{
int i;
- m_fp->WriteString( wxString::Format( wxT("\t%s->Create("),
+ m_source += ( wxString::Format( wxT("\t%s->Create("),
m_data->GetObjectName(objectID).c_str() ) );
for (i = 0; i < paramCount; i++)
{
wxString str =
wxString::Format( wxT("%s"),
m_data->GetObjectName( objectIDValues[i] ).c_str() );
- m_fp->WriteString( str );
+ m_source += ( str );
}
else
{
- m_fp->WriteString(
+ m_source += (
wxString::Format( wxT("%s"), ValueAsCode(params[i]).c_str() ) );
}
if (i < paramCount - 1)
- m_fp->WriteString( wxT(", "));
+ m_source += ( wxT(", "));
}
- m_fp->WriteString( wxT(");\n") );
+ m_source += ( wxT(");\n") );
}
void wxObjectCodeReaderCallback::ConstructObject(int objectID,
const wxClassInfo *classInfo,
int paramCount,
- wxVariantBase *params,
+ wxAny *params,
int *objectIDValues,
const wxClassInfo **WXUNUSED(objectClassInfos),
- wxVariantBaseArray &WXUNUSED(metadata)
+ wxStringToAnyHashMap &WXUNUSED(metadata)
)
{
wxString objectName = wxString::Format( wxT("LocalObject_%d"), objectID );
- m_fp->WriteString( wxString::Format( wxT("\t%s *%s = new %s("),
+ m_source += ( wxString::Format( wxT("\t%s *%s = new %s("),
classInfo->GetClassName(),
objectName.c_str(),
classInfo->GetClassName()) );
for (i = 0; i < paramCount; i++)
{
if ( objectIDValues[i] != wxInvalidObjectID )
- m_fp->WriteString( wxString::Format( wxT("%s"),
+ m_source += ( wxString::Format( wxT("%s"),
m_data->GetObjectName( objectIDValues[i] ).c_str() ) );
else
{
- m_fp->WriteString(
+ m_source += (
wxString::Format( wxT("%s"), ValueAsCode(params[i]).c_str() ) );
}
if (i < paramCount - 1)
- m_fp->WriteString( wxT(", ") );
+ m_source += ( wxT(", ") );
}
- m_fp->WriteString( wxT(");\n") );
+ m_source += ( wxT(");\n") );
}
void wxObjectCodeReaderCallback::SetProperty(int objectID,
const wxClassInfo *WXUNUSED(classInfo),
const wxPropertyInfo* propertyInfo,
- const wxVariantBase &value)
+ const wxAny &value)
{
- m_fp->WriteString( wxString::Format( wxT("\t%s->%s(%s);\n"),
+ m_source += ( wxString::Format( wxT("\t%s->%s(%s);\n"),
m_data->GetObjectName(objectID).c_str(),
propertyInfo->GetAccessor()->GetSetterName().c_str(),
ValueAsCode(value).c_str()) );
int valueObjectId)
{
if ( propertyInfo->GetTypeInfo()->GetKind() == wxT_OBJECT )
- m_fp->WriteString( wxString::Format( wxT("\t%s->%s(*%s);\n"),
+ m_source += ( 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_source += ( 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 wxObjectCodeReaderCallback::AddToPropertyCollection( int objectID,
const wxClassInfo *WXUNUSED(classInfo),
const wxPropertyInfo* propertyInfo,
- const wxVariantBase &value)
+ const wxAny &value)
{
- m_fp->WriteString( wxString::Format( wxT("\t%s->%s(%s);\n"),
+ m_source += ( wxString::Format( wxT("\t%s->%s(%s);\n"),
m_data->GetObjectName(objectID).c_str(),
propertyInfo->GetAccessor()->GetAdderName().c_str(),
ValueAsCode(value).c_str()) );
ehsource.c_str(), ehsource.c_str(), eventType, ehsinkClass.c_str(),
handlerName.c_str(), ehsink.c_str() );
- m_fp->WriteString( code );
+ m_source += ( code );
}
else
{
private:
// any class wishing to process wxWidgets events must use this macro
- wxDECLARE_EVENT_TABLE()
+ wxDECLARE_EVENT_TABLE();
};
// ----------------------------------------------------------------------------
EVT_MENU(Minimal_About, MyFrame::OnAbout)
END_EVENT_TABLE()
-wxIMPLEMENT_APP(MyApp)
+wxIMPLEMENT_APP(MyApp);
// ============================================================================
// implementation
// the following class "persists" (i.e. saves) a wxFrame into a wxObjectWriter
-class MyDesignerPersister : public wxObjectReaderCallback
+class MyDesignerPersister : public wxObjectWriterCallback
{
public:
MyDesignerPersister( wxDynamicObject * frame)
const wxObject *&eventSink,
const wxHandlerInfo* &handlerInfo )
{
- // this approach would be used it the handler would not
+ // this approach would be used if the handler would not
// be connected really in the designer, so we have to supply
// the information
- if ( object == m_frame->GetProperty(wxT("Button")).GetAsObject() &&
- propInfo == wxCLASSINFO( wxButton )->FindPropertyInfo("OnClick") )
+ const wxObject* but = wxAnyGetAsObjectPtr( m_frame->GetProperty(wxT("Button")) );
+ if ( object == but &&
+ propInfo == wxCLASSINFO( wxButton )->FindPropertyInfo(wxT("OnClick")) )
{
eventSink = m_frame;
handlerInfo = m_frame->GetClassInfo()->
- FindHandlerInfo("ButtonClickHandler");
+ FindHandlerInfo(wxT("ButtonClickHandler"));
return true;
}
return false;
CLASSINFO(wxFrame) );
// this class has a property named "Button" and the relative handler:
- dyninfo->AddProperty("Button", wxGetTypeInfo((wxButton**) NULL));
- dyninfo->AddHandler("ButtonClickHandler",
+ dyninfo->AddProperty(wxT("Button"), wxGetTypeInfo((wxButton**) NULL));
+ dyninfo->AddHandler(wxT("ButtonClickHandler"),
NULL /* no instance of the handler method */, CLASSINFO( wxEvent ) );
}
}
wxDynamicObject* CreateFrameRTTI()
{
int baseID = 100;
- wxVariantBase Params[10];
+ wxAny Params[10];
// the class is now part of XTI internal table so that we can
// get a pointer to it just searching it like any other class:
wxASSERT( info );
wxDynamicObject* frameWrapper =
wx_dynamic_cast(wxDynamicObject*, info->CreateObject() );
- Params[0] = wxVariantBase((wxWindow*)(NULL));
- Params[1] = wxVariantBase(wxWindowID(baseID++));
- Params[2] = wxVariantBase(wxString(wxT("This is a frame created from XTI")));
- Params[3] = wxVariantBase(wxPoint(-1,-1));
- Params[4] = wxVariantBase(wxSize(400,300));
- Params[5] = wxVariantBase((long)wxDEFAULT_FRAME_STYLE);
+ Params[0] = wxAny((wxWindow*)(NULL));
+ Params[1] = wxAny(wxWindowID(baseID++));
+ Params[2] = wxAny(wxString(wxT("This is a frame created from XTI")));
+ Params[3] = wxAny(wxPoint(-1,-1));
+ Params[4] = wxAny(wxSize(400,300));
+ Params[5] = wxAny((long)wxDEFAULT_FRAME_STYLE);
wxASSERT( info->Create(frameWrapper, 6, Params ));
frame = wx_dynamic_cast(wxFrame*, frameWrapper->GetSuperClassInstance());
+#if 1
// now build a notebook inside it:
wxNotebook* notebook;
info = wxClassInfo::FindClass("wxNotebook");
wxASSERT( info );
notebook = wxDynamicCast( info->CreateObject(), wxNotebook );
- Params[0] = wxVariantBase((wxWindow*)frame);
- Params[1] = wxVariantBase(wxWindowID(baseID++));
- Params[2] = wxVariantBase(wxPoint( 10, 10 ));
- Params[3] = wxVariantBase(wxDefaultSize);
- Params[4] = wxVariantBase((long)0);
+ Params[0] = wxAny((wxWindow*)frame);
+ Params[1] = wxAny(wxWindowID(baseID++));
+ Params[2] = wxAny(wxPoint( 10, 10 ));
+ Params[3] = wxAny(wxDefaultSize);
+ Params[4] = wxAny((long)0);
wxASSERT( info->Create(notebook, 5, Params ));
// button page
info = wxClassInfo::FindClass("wxPanel");
wxASSERT( info );
panel = wxDynamicCast( info->CreateObject(), wxPanel );
- Params[0] = wxVariantBase((wxWindow*)(notebook));
- Params[1] = wxVariantBase(wxWindowID(baseID++));
- Params[2] = wxVariantBase(wxPoint(-1,-1));
- Params[3] = wxVariantBase(wxSize(-1,-1));
- Params[4] = wxVariantBase((long)0);
- Params[5] = wxVariantBase(wxString(wxT("Hello")));
+ Params[0] = wxAny((wxWindow*)(notebook));
+ Params[1] = wxAny(wxWindowID(baseID++));
+ Params[2] = wxAny(wxPoint(-1,-1));
+ Params[3] = wxAny(wxSize(-1,-1));
+ Params[4] = wxAny((long)0);
+ Params[5] = wxAny(wxString(wxT("Hello")));
wxASSERT( info->Create(panel, 6, Params ));
notebook->AddPage( panel, "Buttons" );
info = wxClassInfo::FindClass("wxButton");
wxASSERT( info );
button = wxDynamicCast( info->CreateObject(), wxButton );
- Params[0] = wxVariantBase((wxWindow*)(panel));
- Params[1] = wxVariantBase(wxWindowID(baseID++));
- Params[2] = wxVariantBase(wxString(wxT("Click Me!")));
- Params[3] = wxVariantBase(wxPoint( 10, 10 ));
- Params[4] = wxVariantBase(wxSize(-1,-1));
- Params[5] = wxVariantBase((long)0);
+ Params[0] = wxAny((wxWindow*)(panel));
+ Params[1] = wxAny(wxWindowID(baseID++));
+ Params[2] = wxAny(wxString(wxT("Click Me!")));
+ Params[3] = wxAny(wxPoint( 10, 10 ));
+ Params[4] = wxAny(wxSize(-1,-1));
+ Params[5] = wxAny((long)0);
wxASSERT( info->Create(button, 6, Params ));
- frameWrapper->SetProperty( "Button", wxVariantBase( button ) );
+ frameWrapper->SetProperty( wxT("Button"), wxAny( button ) );
// other controls page
info = wxClassInfo::FindClass("wxPanel");
wxASSERT( info );
panel = wxDynamicCast( info->CreateObject(), wxPanel );
- Params[0] = wxVariantBase((wxWindow*)(notebook));
- Params[1] = wxVariantBase(wxWindowID(baseID++));
- Params[2] = wxVariantBase(wxPoint(-1,-1));
- Params[3] = wxVariantBase(wxSize(-1,-1));
- Params[4] = wxVariantBase((long)0);
- Params[5] = wxVariantBase(wxString(wxT("Hello")));
+ Params[0] = wxAny((wxWindow*)(notebook));
+ Params[1] = wxAny(wxWindowID(baseID++));
+ Params[2] = wxAny(wxPoint(-1,-1));
+ Params[3] = wxAny(wxSize(-1,-1));
+ Params[4] = wxAny((long)0);
+ Params[5] = wxAny(wxString(wxT("Hello")));
wxASSERT( info->Create(panel, 6, Params ));
notebook->AddPage( panel, "Other Standard controls" );
info = wxClassInfo::FindClass("wxCheckBox");
wxASSERT( info );
control = wxDynamicCast( info->CreateObject(), wxControl );
- Params[0] = wxVariantBase((wxWindow*)(panel));
- Params[1] = wxVariantBase(wxWindowID(baseID++));
- Params[2] = wxVariantBase(wxString(wxT("A Checkbox")));
- Params[3] = wxVariantBase(wxPoint( 10, 10 ));
- Params[4] = wxVariantBase(wxSize(-1,-1));
- Params[5] = wxVariantBase((long)0);
+ Params[0] = wxAny((wxWindow*)(panel));
+ Params[1] = wxAny(wxWindowID(baseID++));
+ Params[2] = wxAny(wxString(wxT("A Checkbox")));
+ Params[3] = wxAny(wxPoint( 10, 10 ));
+ Params[4] = wxAny(wxSize(-1,-1));
+ Params[5] = wxAny((long)0);
wxASSERT( info->Create(control, 6, Params ));
info = wxClassInfo::FindClass("wxRadioButton");
wxASSERT( info );
control = wxDynamicCast( info->CreateObject(), wxControl );
- Params[0] = wxVariantBase((wxWindow*)(panel));
- Params[1] = wxVariantBase(wxWindowID(baseID++));
- Params[2] = wxVariantBase(wxString(wxT("A Radiobutton")));
- Params[3] = wxVariantBase(wxPoint( 10, 30 ));
- Params[4] = wxVariantBase(wxSize(-1,-1));
- Params[5] = wxVariantBase((long)0);
+ Params[0] = wxAny((wxWindow*)(panel));
+ Params[1] = wxAny(wxWindowID(baseID++));
+ Params[2] = wxAny(wxString(wxT("A Radiobutton")));
+ Params[3] = wxAny(wxPoint( 10, 30 ));
+ Params[4] = wxAny(wxSize(-1,-1));
+ Params[5] = wxAny((long)0);
wxASSERT( info->Create(control, 6, Params ));
control = wxDynamicCast( info->CreateObject(), wxControl );
- Params[1] = wxVariantBase(wxWindowID(baseID++));
- Params[2] = wxVariantBase(wxString(wxT("Another One")));
- Params[3] = wxVariantBase(wxPoint( 10, 50 ));
+ Params[1] = wxAny(wxWindowID(baseID++));
+ Params[2] = wxAny(wxString(wxT("Another One")));
+ Params[3] = wxAny(wxPoint( 10, 50 ));
wxASSERT( info->Create(control, 6, Params ));
info = wxClassInfo::FindClass("wxStaticText");
wxASSERT( info );
control = wxDynamicCast( info->CreateObject(), wxControl );
- Params[0] = wxVariantBase((wxWindow*)(panel));
- Params[1] = wxVariantBase(wxWindowID(baseID++));
- Params[2] = wxVariantBase(wxString(wxT("A Static Text!")));
- Params[3] = wxVariantBase(wxPoint( 10, 70 ));
- Params[4] = wxVariantBase(wxSize(-1,-1));
- Params[5] = wxVariantBase((long)0);
+ Params[0] = wxAny((wxWindow*)(panel));
+ Params[1] = wxAny(wxWindowID(baseID++));
+ Params[2] = wxAny(wxString(wxT("A Static Text!")));
+ Params[3] = wxAny(wxPoint( 10, 70 ));
+ Params[4] = wxAny(wxSize(-1,-1));
+ Params[5] = wxAny((long)0);
wxASSERT( info->Create(control, 6, Params ));
info = wxClassInfo::FindClass("wxStaticBox");
wxASSERT( info );
control = wxDynamicCast( info->CreateObject(), wxControl );
- Params[0] = wxVariantBase((wxWindow*)(panel));
- Params[1] = wxVariantBase(wxWindowID(baseID++));
- Params[2] = wxVariantBase(wxString(wxT("A Static Box")));
- Params[3] = wxVariantBase(wxPoint( 10, 90 ));
- Params[4] = wxVariantBase(wxSize(100,80));
- Params[5] = wxVariantBase((long)0);
+ Params[0] = wxAny((wxWindow*)(panel));
+ Params[1] = wxAny(wxWindowID(baseID++));
+ Params[2] = wxAny(wxString(wxT("A Static Box")));
+ Params[3] = wxAny(wxPoint( 10, 90 ));
+ Params[4] = wxAny(wxSize(100,80));
+ Params[5] = wxAny((long)0);
wxASSERT( info->Create(control, 6, Params ));
info = wxClassInfo::FindClass("wxTextCtrl");
wxASSERT( info );
control = wxDynamicCast( info->CreateObject(), wxControl );
- Params[0] = wxVariantBase((wxWindow*)(panel));
- Params[1] = wxVariantBase(wxWindowID(baseID++));
- Params[2] = wxVariantBase(wxString(wxT("A Text Control")));
- Params[3] = wxVariantBase(wxPoint( 10, 200 ));
- Params[4] = wxVariantBase(wxSize(-1,-1));
- Params[5] = wxVariantBase((long)0);
+ Params[0] = wxAny((wxWindow*)(panel));
+ Params[1] = wxAny(wxWindowID(baseID++));
+ Params[2] = wxAny(wxString(wxT("A Text Control")));
+ Params[3] = wxAny(wxPoint( 10, 200 ));
+ Params[4] = wxAny(wxSize(-1,-1));
+ Params[5] = wxAny((long)0);
wxASSERT( info->Create(control, 6, Params ));
// spins and gauges page
info = wxClassInfo::FindClass("wxPanel");
wxASSERT( info );
panel = wxDynamicCast( info->CreateObject(), wxPanel );
- Params[0] = wxVariantBase((wxWindow*)(notebook));
- Params[1] = wxVariantBase(wxWindowID(baseID++));
- Params[2] = wxVariantBase(wxPoint(-1,-1));
- Params[3] = wxVariantBase(wxSize(-1,-1));
- Params[4] = wxVariantBase((long)0);
- Params[5] = wxVariantBase(wxString(wxT("Hello")));
+ Params[0] = wxAny((wxWindow*)(notebook));
+ Params[1] = wxAny(wxWindowID(baseID++));
+ Params[2] = wxAny(wxPoint(-1,-1));
+ Params[3] = wxAny(wxSize(-1,-1));
+ Params[4] = wxAny((long)0);
+ Params[5] = wxAny(wxString(wxT("Hello")));
wxASSERT( info->Create(panel, 6, Params ));
notebook->AddPage( panel, "Spins and Sliders" );
info = wxClassInfo::FindClass("wxSpinButton");
wxASSERT( info );
control = wxDynamicCast( info->CreateObject(), wxControl );
- Params[0] = wxVariantBase((wxWindow*)(panel));
- Params[1] = wxVariantBase(wxWindowID(baseID++));
- Params[2] = wxVariantBase(wxPoint( 10, 10 ));
- Params[3] = wxVariantBase(wxSize(-1,-1));
- Params[4] = wxVariantBase((long)wxSP_VERTICAL | wxSP_ARROW_KEYS);
+ Params[0] = wxAny((wxWindow*)(panel));
+ Params[1] = wxAny(wxWindowID(baseID++));
+ Params[2] = wxAny(wxPoint( 10, 10 ));
+ Params[3] = wxAny(wxSize(-1,-1));
+ Params[4] = wxAny((long)wxSP_VERTICAL | wxSP_ARROW_KEYS);
wxASSERT( info->Create(control, 5, Params ));
wxENSURE_CLASS_IS_LINKED(wxSpinCtrl);
info = wxClassInfo::FindClass("wxSpinCtrl");
wxASSERT( info );
control = wxDynamicCast( info->CreateObject(), wxControl );
- Params[0] = wxVariantBase((wxWindow*)(panel));
- Params[1] = wxVariantBase(wxWindowID(baseID++));
- Params[2] = wxVariantBase(wxString("20"));
- Params[3] = wxVariantBase(wxPoint( 40, 10 ));
- Params[4] = wxVariantBase(wxSize(40,-1));
- Params[5] = wxVariantBase((long) wxSP_ARROW_KEYS);
+ Params[0] = wxAny((wxWindow*)(panel));
+ Params[1] = wxAny(wxWindowID(baseID++));
+ Params[2] = wxAny(wxString("20"));
+ Params[3] = wxAny(wxPoint( 40, 10 ));
+ Params[4] = wxAny(wxSize(40,-1));
+ Params[5] = wxAny((long) wxSP_ARROW_KEYS);
wxASSERT( info->Create(control, 6, Params ));
// MSVC likes to exclude from link wxGauge...
wxENSURE_CLASS_IS_LINKED(wxCheckBox)
wxENSURE_CLASS_IS_LINKED(wxSpinCtrl)
-#ifdef __WXMSW__
- // under wxMSW wxGauge is simply #defined to wxGauge95
- info = wxClassInfo::FindClass("wxGauge95");
-#else
info = wxClassInfo::FindClass("wxGauge");
-#endif
+
wxASSERT( info );
control = wxDynamicCast( info->CreateObject(), wxControl );
- Params[0] = wxVariantBase((wxWindow*)(panel));
- Params[1] = wxVariantBase(wxWindowID(baseID++));
- Params[2] = wxVariantBase((int) 100);
- Params[3] = wxVariantBase(wxPoint( 10, 50 ));
- Params[4] = wxVariantBase(wxSize(-1,-1));
- Params[5] = wxVariantBase((long) wxGA_HORIZONTAL);
+ Params[0] = wxAny((wxWindow*)(panel));
+ Params[1] = wxAny(wxWindowID(baseID++));
+ Params[2] = wxAny((int) 100);
+ Params[3] = wxAny(wxPoint( 10, 50 ));
+ Params[4] = wxAny(wxSize(-1,-1));
+ Params[5] = wxAny((long) wxGA_HORIZONTAL);
wxASSERT( info->Create(control, 6, Params ));
wx_dynamic_cast(wxGauge*, control)->SetValue(20);
+#endif
return frameWrapper;
}
MyDesignerPersister persister(frame);
// write the given wxObject into the XML document
- wxVariantBaseArray empty;
+ wxStringToAnyHashMap empty;
writer.WriteObject( frame, frame->GetClassInfo(), &persister,
wxString("myTestFrame"), empty );
return false;
// read the XML file using the wxObjectCodeReaderCallback
- wxObjectCodeReaderCallback Callbacks(&tos);
+
+ wxString headerincludes;
+ wxString sourcecode;
+ wxObjectCodeReaderCallback Callbacks(headerincludes,sourcecode);
wxObjectXmlReader Reader(root);
// ReadObject will return the ID of the object read??
Reader.ReadObject( wxString("myTestFrame"), &Callbacks );
+ // header preamble
+ tos <<
+ "#include \"wx/wxprec.h\" \n#ifdef __BORLANDC__\n#pragma hdrstop\n#endif\n#ifndef WX_PRECOMP\n#include \"wx/wx.h\" \n#endif\n\n";
+ // add object includes
+ tos.WriteString( headerincludes );
+
+ tos << "\n\nvoid test()\n{";
+ tos.WriteString( sourcecode );
+ tos << "}";
return true;
}