git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@7879
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
/////////////////////////////////////////////////////////////////////////////
// Name: xh_notbk.cpp
/////////////////////////////////////////////////////////////////////////////
// Name: xh_notbk.cpp
-// Purpose: XML resource for wxBoxSizer
+// Purpose: XML resource for wxNotebook
// Author: Vaclav Slavik
// Created: 2000/03/21
// RCS-ID: $Id$
// Author: Vaclav Slavik
// Created: 2000/03/21
// RCS-ID: $Id$
#include "wx/log.h"
#include "wx/notebook.h"
#include "wx/log.h"
#include "wx/notebook.h"
wxNotebookXmlHandler::wxNotebookXmlHandler()
: wxXmlResourceHandler(), m_IsInside(FALSE), m_Notebook(NULL)
wxNotebookXmlHandler::wxNotebookXmlHandler()
: wxXmlResourceHandler(), m_IsInside(FALSE), m_Notebook(NULL)
wxObject *wxNotebookXmlHandler::DoCreateResource()
{
wxObject *wxNotebookXmlHandler::DoCreateResource()
{
- if (m_Node->GetName() == _T("page"))
+ if (m_Node->GetName() == _T("notebookpage"))
- wxXmlNode *n = GetParamNode(_T("child"))->GetChildren();
+ wxXmlNode *n = GetParamNode(_T("window"))->GetChildren();
while (n)
{
if (n->GetType() == wxXML_ELEMENT_NODE)
while (n)
{
if (n->GetType() == wxXML_ELEMENT_NODE)
bool old_ins = m_IsInside;
m_IsInside = FALSE;
m_IsInside = old_ins;
bool old_ins = m_IsInside;
m_IsInside = FALSE;
m_IsInside = old_ins;
wxWindow *wnd = wxDynamicCast(item, wxWindow);
if (wnd)
wxWindow *wnd = wxDynamicCast(item, wxWindow);
if (wnd)
- m_Notebook->AddPage(wnd, GetText(_T("label")),
+ m_Notebook->AddPage(wnd, GetText(_T("label")),
GetBool(_T("selected"), 0));
else
wxLogError(_T("Error in resource."));
GetBool(_T("selected"), 0));
else
wxLogError(_T("Error in resource."));
CreateChildren(m_Notebook, TRUE/*only this handler*/);
m_IsInside = old_ins;
m_Notebook = old_par;
CreateChildren(m_Notebook, TRUE/*only this handler*/);
m_IsInside = old_ins;
m_Notebook = old_par;
+
+ if (GetBool(_T("usenotebooksizer"), FALSE))
+ return new wxNotebookSizer(nb);
+ else
+ return nb;
bool wxNotebookXmlHandler::CanHandle(wxXmlNode *node)
{
return ((!m_IsInside && node->GetName() == _T("notebook")) ||
bool wxNotebookXmlHandler::CanHandle(wxXmlNode *node)
{
return ((!m_IsInside && node->GetName() == _T("notebook")) ||
- (m_IsInside && node->GetName() == _T("page")));
+ (m_IsInside && node->GetName() == _T("notebookpage")));
#include "wx/statbox.h"
#include "wx/notebook.h"
#include "wx/statbox.h"
#include "wx/notebook.h"
+static bool IsSizerNode(wxXmlNode *node)
+{
+ return (node->GetName() == _T("boxsizer")) ||
+ (node->GetName() == _T("staticboxsizer")) ||
+ (node->GetName() == _T("gridsizer")) ||
+ (node->GetName() == _T("flexgridsizer"));
+}
+
+
+
wxSizerXmlHandler::wxSizerXmlHandler()
: wxXmlResourceHandler(), m_IsInside(FALSE), m_ParentSizer(NULL)
{
wxSizerXmlHandler::wxSizerXmlHandler()
: wxXmlResourceHandler(), m_IsInside(FALSE), m_ParentSizer(NULL)
{
if (n->GetType() == wxXML_ELEMENT_NODE)
{
bool old_ins = m_IsInside;
if (n->GetType() == wxXML_ELEMENT_NODE)
{
bool old_ins = m_IsInside;
+ wxSizer *old_par = m_ParentSizer;
+ if (!IsSizerNode(n)) m_ParentSizer = NULL;
wxObject *item = CreateResFromNode(n, m_Parent, NULL);
m_IsInside = old_ins;
wxObject *item = CreateResFromNode(n, m_Parent, NULL);
m_IsInside = old_ins;
+ m_ParentSizer = old_par;
wxSizer *sizer = wxDynamicCast(item, wxSizer);
wxWindow *wnd = wxDynamicCast(item, wxWindow);
wxSizer *sizer = wxDynamicCast(item, wxSizer);
wxWindow *wnd = wxDynamicCast(item, wxWindow);
-#if wxUSE_NOTEBOOK
- else if (m_Node->GetName() == _T("notebooksizer"))
- {
- wxCHECK_MSG(m_ParentSizer, NULL, _T("Incorrect syntax of XML resource: notebooksizer not within sizer!"));
- wxSizer *old_par = m_ParentSizer;
- m_ParentSizer = NULL;
-
- wxNotebook *nb = NULL;
- wxObject *item;
- wxXmlNode *n = GetParamNode(_T("window"))->GetChildren();
- while (n)
- {
- if (n->GetType() == wxXML_ELEMENT_NODE)
- {
- item = CreateResFromNode(n, m_Parent, NULL);
- nb = wxDynamicCast(item, wxNotebook);
- break;
- }
- n = n->GetNext();
- }
-
- m_ParentSizer = old_par;
-
- wxCHECK_MSG(nb, NULL, _T("Incorrect syntax of XML resource: notebooksizer must contain a notebook!"));
- return new wxNotebookSizer(nb);
- }
-#endif
-
else {
wxSizer *sizer = NULL;
else {
wxSizer *sizer = NULL;
bool wxSizerXmlHandler::CanHandle(wxXmlNode *node)
{
bool wxSizerXmlHandler::CanHandle(wxXmlNode *node)
{
- return ((!m_IsInside && node->GetName() == _T("boxsizer")) ||
- (!m_IsInside && node->GetName() == _T("staticboxsizer")) ||
- (!m_IsInside && node->GetName() == _T("gridsizer")) ||
- (!m_IsInside && node->GetName() == _T("flexgridsizer")) ||
-#if wxUSE_NOTEBOOK
- (!m_IsInside && node->GetName() == _T("notebooksizer")) ||
-#endif
+ return ((!m_IsInside && IsSizerNode(node)) ||
(m_IsInside && node->GetName() == _T("sizeritem")) ||
(m_IsInside && node->GetName() == _T("spacer")));
}
(m_IsInside && node->GetName() == _T("sizeritem")) ||
(m_IsInside && node->GetName() == _T("spacer")));
}