// Created: 04/01/98
// RCS-ID: $Id$
// Copyright: (c) Julian Smart and Markus Holzem
-// Licence: wxWindows license
+// Licence: wxWindows license
/////////////////////////////////////////////////////////////////////////////
#ifdef __GNUG__
#pragma hdrstop
#endif
+#if wxUSE_WX_RESOURCES
+
+#ifdef __VISUALC__
+#pragma warning(disable:4706) // assignment within conditional expression
+#endif // VC++
+
#ifndef WX_PRECOMP
#include "wx/defs.h"
#include "wx/setup.h"
#include "wx/menu.h"
#include "wx/stattext.h"
#include "wx/button.h"
+#include "wx/bmpbuttn.h"
#include "wx/radiobox.h"
#include "wx/listbox.h"
#include "wx/choice.h"
#include "wx/checkbox.h"
+#include "wx/settings.h"
#include "wx/slider.h"
+#include "wx/icon.h"
#include "wx/statbox.h"
-#if USE_GAUGE
+#include "wx/statbmp.h"
#include "wx/gauge.h"
-#endif
#include "wx/textctrl.h"
-#include "wx/msgbxdlg.h"
+#include "wx/msgdlg.h"
+#include "wx/intl.h"
+#endif
+
+#if wxUSE_RADIOBTN
+#include "wx/radiobut.h"
#endif
-#if USE_SCROLLBAR
+#if wxUSE_SCROLLBAR
#include "wx/scrolbar.h"
#endif
-#if USE_COMBOBOX
+#if wxUSE_COMBOBOX
#include "wx/combobox.h"
#endif
#include "wx/validate.h"
-#if USE_WX_RESOURCES
+#include "wx/log.h"
#include <ctype.h>
#include <math.h>
#include "wx/string.h"
#include "wx/wxexpr.h"
+#include "wx/settings.h"
+#include "wx/stream.h"
+
// Forward (private) declarations
-bool wxResourceInterpretResources(wxResourceTable& table, PrologDatabase& db);
-wxItemResource *wxResourceInterpretDialog(wxResourceTable& table, PrologExpr *expr, bool isPanel = FALSE);
-wxItemResource *wxResourceInterpretControl(wxResourceTable& table, PrologExpr *expr);
-wxItemResource *wxResourceInterpretMenu(wxResourceTable& table, PrologExpr *expr);
-wxItemResource *wxResourceInterpretMenuBar(wxResourceTable& table, PrologExpr *expr);
-wxItemResource *wxResourceInterpretString(wxResourceTable& table, PrologExpr *expr);
-wxItemResource *wxResourceInterpretBitmap(wxResourceTable& table, PrologExpr *expr);
-wxItemResource *wxResourceInterpretIcon(wxResourceTable& table, PrologExpr *expr);
+bool wxResourceInterpretResources(wxResourceTable& table, wxExprDatabase& db);
+wxItemResource *wxResourceInterpretDialog(wxResourceTable& table, wxExpr *expr, bool isPanel = FALSE);
+wxItemResource *wxResourceInterpretControl(wxResourceTable& table, wxExpr *expr);
+wxItemResource *wxResourceInterpretMenu(wxResourceTable& table, wxExpr *expr);
+wxItemResource *wxResourceInterpretMenuBar(wxResourceTable& table, wxExpr *expr);
+wxItemResource *wxResourceInterpretString(wxResourceTable& table, wxExpr *expr);
+wxItemResource *wxResourceInterpretBitmap(wxResourceTable& table, wxExpr *expr);
+wxItemResource *wxResourceInterpretIcon(wxResourceTable& table, wxExpr *expr);
// Interpret list expression
-wxFont *wxResourceInterpretFontSpec(PrologExpr *expr);
+wxFont wxResourceInterpretFontSpec(wxExpr *expr);
-bool wxResourceReadOneResource(FILE *fd, PrologDatabase& db, bool *eof, wxResourceTable *table = NULL);
-bool wxResourceParseIncludeFile(char *f, wxResourceTable *table = NULL);
+bool wxResourceReadOneResource(FILE *fd, wxExprDatabase& db, bool *eof, wxResourceTable *table = (wxResourceTable *) NULL);
+bool wxResourceReadOneResource(wxInputStream *fd, wxExprDatabase& db, bool *eof, wxResourceTable *table) ;
+bool wxResourceParseIncludeFile(const wxString& f, wxResourceTable *table = (wxResourceTable *) NULL);
-wxResourceTable *wxDefaultResourceTable = NULL;
+wxResourceTable *wxDefaultResourceTable = (wxResourceTable *) NULL;
-static char *wxResourceBuffer = NULL;
-static long wxResourceBufferSize = 0;
-static long wxResourceBufferCount = 0;
-static int wxResourceStringPtr = 0;
+char *wxResourceBuffer = (char *) NULL;
+long wxResourceBufferSize = 0;
+long wxResourceBufferCount = 0;
+int wxResourceStringPtr = 0;
-void wxInitializeResourceSystem(void)
+void wxInitializeResourceSystem()
{
wxDefaultResourceTable = new wxResourceTable;
}
-void wxCleanUpResourceSystem(void)
+void wxCleanUpResourceSystem()
{
delete wxDefaultResourceTable;
+ if (wxResourceBuffer)
+ delete[] wxResourceBuffer;
}
-void wxWarning(char *msg)
+void wxLogWarning(char *msg)
{
- wxMessageBox(msg, "Warning", wxOK);
+ wxMessageBox(msg, _("Warning"), wxOK);
}
-#if !USE_SHARED_LIBRARY
IMPLEMENT_DYNAMIC_CLASS(wxItemResource, wxObject)
IMPLEMENT_DYNAMIC_CLASS(wxResourceTable, wxHashTable)
-#endif
-
-wxItemResource::wxItemResource(void)
-{
- itemType = NULL;
- title = NULL;
- name = NULL;
- windowStyle = 0;
- x = y = width = height = 0;
- value1 = value2 = value3 = value5 = 0;
- value4 = NULL;
- stringValues = NULL;
- bitmap = NULL;
- backgroundColour = labelColour = buttonColour = NULL;
- windowFont = NULL;
- m_windowId = 0;
-}
-
-wxItemResource::~wxItemResource(void)
-{
- if (itemType) delete[] itemType;
- if (title) delete[] title;
- if (name) delete[] name;
- if (value4) delete[] value4;
- if (stringValues)
- delete stringValues;
- if (bitmap)
- delete bitmap;
- if (backgroundColour)
- delete backgroundColour;
- if (labelColour)
- delete labelColour;
- if (buttonColour)
- delete buttonColour;
- wxNode *node = children.First();
- while (node)
- {
- wxItemResource *item = (wxItemResource *)node->Data();
- delete item;
- delete node;
- node = children.First();
- }
-}
-
-void wxItemResource::SetTitle(char *t)
-{
- if (t == title)
- return;
-
- if (title) delete[] title;
- if (t)
- title = copystring(t);
- else
- title = NULL;
-}
-void wxItemResource::SetType(char *t)
+wxItemResource::wxItemResource()
{
- if (itemType == t)
- return;
-
- if (itemType) delete[] itemType;
- if (t)
- itemType = copystring(t);
- else
- itemType = NULL;
+ m_itemType = "";
+ m_title = "";
+ m_name = "";
+ m_windowStyle = 0;
+ m_x = m_y = m_width = m_height = 0;
+ m_value1 = m_value2 = m_value3 = m_value5 = 0;
+ m_value4 = "";
+ m_windowId = 0;
+ m_exStyle = 0;
}
-void wxItemResource::SetName(char *n)
+wxItemResource::~wxItemResource()
{
- if (n == name)
- return;
-
- if (name) delete[] name;
- if (n)
- name = copystring(n);
- else
- name = NULL;
+ wxNode *node = m_children.First();
+ while (node)
+ {
+ wxItemResource *item = (wxItemResource *)node->Data();
+ delete item;
+ delete node;
+ node = m_children.First();
+ }
}
-void wxItemResource::SetStringValues(wxStringList *svalues)
-{
- if (stringValues)
- delete stringValues;
- if (svalues)
- stringValues = svalues;
- else
- stringValues = NULL;
-}
+/*
+* Resource table
+*/
-void wxItemResource::SetValue4(char *v)
+wxResourceTable::wxResourceTable():wxHashTable(wxKEY_STRING), identifiers(wxKEY_STRING)
{
- if (value4 == v)
- return;
-
- if (value4) delete[] value4;
- if (v)
- value4 = copystring(v);
- else
- value4 = NULL;
}
-/*
- * Resource table
- */
-
-wxResourceTable::wxResourceTable(void):wxHashTable(wxKEY_STRING), identifiers(wxKEY_STRING)
+wxResourceTable::~wxResourceTable()
{
+ ClearTable();
}
-wxResourceTable::~wxResourceTable(void)
-{
- ClearTable();
-}
-
wxItemResource *wxResourceTable::FindResource(const wxString& name) const
{
- wxItemResource *item = (wxItemResource *)Get((char *)(const char *)name);
- return item;
+ wxItemResource *item = (wxItemResource *)Get(WXSTRINGCAST name);
+ return item;
}
void wxResourceTable::AddResource(wxItemResource *item)
{
- char *name = item->GetName();
- if (!name)
- name = item->GetTitle();
- if (!name)
- name = "no name";
+ wxString name = item->GetName();
+ if (name == wxT(""))
+ name = item->GetTitle();
+ if (name == wxT(""))
+ name = wxT("no name");
- // Delete existing resource, if any.
- Delete(name);
+ // Delete existing resource, if any.
+ Delete(name);
- Put(name, item);
+ Put(name, item);
}
bool wxResourceTable::DeleteResource(const wxString& name)
{
- wxItemResource *item = (wxItemResource *)Delete((char *)(const char *)name);
- if (item)
- {
- // See if any resource has this as its child; if so, delete from
- // parent's child list.
- BeginFind();
- wxNode *node = NULL;
- while ((node = Next()))
- {
- wxItemResource *parent = (wxItemResource *)node->Data();
- if (parent->GetChildren().Member(item))
- {
- parent->GetChildren().DeleteObject(item);
- break;
- }
- }
-
- delete item;
- return TRUE;
- }
- else
- return FALSE;
+ wxItemResource *item = (wxItemResource *)Delete(WXSTRINGCAST name);
+ if (item)
+ {
+ // See if any resource has this as its child; if so, delete from
+ // parent's child list.
+ BeginFind();
+ wxNode *node = (wxNode *) NULL;
+ node = Next();
+ while (node != NULL)
+ {
+ wxItemResource *parent = (wxItemResource *)node->Data();
+ if (parent->GetChildren().Member(item))
+ {
+ parent->GetChildren().DeleteObject(item);
+ break;
+ }
+ node = Next();
+ }
+
+ delete item;
+ return TRUE;
+ }
+ else
+ return FALSE;
}
-bool wxResourceTable::ParseResourceFile(char *filename)
+bool wxResourceTable::ParseResourceFile( wxInputStream *is )
{
- PrologDatabase db;
+ wxExprDatabase db;
+ int len = is->StreamSize() ;
- FILE *fd = fopen(filename, "r");
- if (!fd)
- return FALSE;
- bool eof = FALSE;
- while (wxResourceReadOneResource(fd, db, &eof, this) && !eof)
- {
- // Loop
- }
- fclose(fd);
- return wxResourceInterpretResources(*this, db);
+ bool eof = FALSE;
+ while ( is->TellI() + 10 < len) // it's a hack because the streams dont support EOF
+ {
+ wxResourceReadOneResource(is, db, &eof, this) ;
+ }
+ return wxResourceInterpretResources(*this, db);
}
-bool wxResourceTable::ParseResourceData(char *data)
+bool wxResourceTable::ParseResourceFile(const wxString& filename)
{
- PrologDatabase db;
- if (!db.ReadPrologFromString(data))
- {
- wxWarning("Ill-formed resource file syntax.");
- return FALSE;
- }
+ wxExprDatabase db;
+
+#if defined(__WXMAC__) && !defined(__UNIX__)
+ FILE *fd = fopen(wxUnix2MacFilename(filename.fn_str()), "r");
+#else
+ FILE *fd = wxFopen(filename, _T("r"));
+#endif
+ if (!fd)
+ return FALSE;
+ bool eof = FALSE;
+ while (wxResourceReadOneResource(fd, db, &eof, this) && !eof)
+ {
+ // Loop
+ }
+ fclose(fd);
+ return wxResourceInterpretResources(*this, db);
+}
+
+bool wxResourceTable::ParseResourceData(const wxString& data)
+{
+ wxExprDatabase db;
+ if (!db.ReadFromString(data))
+ {
+ wxLogWarning(_("Ill-formed resource file syntax."));
+ return FALSE;
+ }
- return wxResourceInterpretResources(*this, db);
+ return wxResourceInterpretResources(*this, db);
}
-bool wxResourceTable::RegisterResourceBitmapData(char *name, char bits[], int width, int height)
-{
- // Register pre-loaded bitmap data
- wxItemResource *item = new wxItemResource;
-// item->SetType(wxRESOURCE_TYPE_XBM_DATA);
- item->SetType("wxXBMData");
- item->SetName(name);
- item->SetValue1((long)bits);
- item->SetValue2((long)width);
- item->SetValue3((long)height);
- AddResource(item);
- return TRUE;
+bool wxResourceTable::RegisterResourceBitmapData(const wxString& name, char bits[], int width, int height)
+{
+ // Register pre-loaded bitmap data
+ wxItemResource *item = new wxItemResource;
+ // item->SetType(wxRESOURCE_TYPE_XBM_DATA);
+ item->SetType(wxT("wxXBMData"));
+ item->SetName(name);
+ item->SetValue1((long)bits);
+ item->SetValue2((long)width);
+ item->SetValue3((long)height);
+ AddResource(item);
+ return TRUE;
}
-bool wxResourceTable::RegisterResourceBitmapData(char *name, char **data)
+bool wxResourceTable::RegisterResourceBitmapData(const wxString& name, char **data)
{
- // Register pre-loaded bitmap data
- wxItemResource *item = new wxItemResource;
-// item->SetType(wxRESOURCE_TYPE_XPM_DATA);
- item->SetType("wxXPMData");
- item->SetName(name);
- item->SetValue1((long)data);
- AddResource(item);
- return TRUE;
+ // Register pre-loaded bitmap data
+ wxItemResource *item = new wxItemResource;
+ // item->SetType(wxRESOURCE_TYPE_XPM_DATA);
+ item->SetType(wxT("wxXPMData"));
+ item->SetName(name);
+ item->SetValue1((long)data);
+ AddResource(item);
+ return TRUE;
}
-bool wxResourceTable::SaveResource(char *WXUNUSED(filename))
+bool wxResourceTable::SaveResource(const wxString& WXUNUSED(filename))
{
- return FALSE;
+ return FALSE;
}
-void wxResourceTable::ClearTable(void)
+void wxResourceTable::ClearTable()
{
- BeginFind();
- wxNode *node = Next();
- while (node)
- {
- wxNode *next = Next();
- wxItemResource *item = (wxItemResource *)node->Data();
- delete item;
- delete node;
- node = next;
- }
+ BeginFind();
+ wxNode *node = Next();
+ while (node)
+ {
+ wxNode *next = Next();
+ wxItemResource *item = (wxItemResource *)node->Data();
+ delete item;
+ delete node;
+ node = next;
+ }
}
-wxControl *wxResourceTable::CreateItem(wxWindow *parent, wxItemResource *childResource) const
+wxControl *wxResourceTable::CreateItem(wxWindow *parent, const wxItemResource* childResource, const wxItemResource* parentResource) const
{
- int id = childResource->GetId();
- if ( id == 0 )
- id = -1;
+ int id = childResource->GetId();
+ if ( id == 0 )
+ id = -1;
+
+ bool dlgUnits = ((parentResource->GetResourceStyle() & wxRESOURCE_DIALOG_UNITS) != 0);
+
+ wxControl *control = (wxControl *) NULL;
+ wxString itemType(childResource->GetType());
+
+ wxPoint pos;
+ wxSize size;
+ if (dlgUnits)
+ {
+ pos = parent->ConvertDialogToPixels(wxPoint(childResource->GetX(), childResource->GetY()));
+ size = parent->ConvertDialogToPixels(wxSize(childResource->GetWidth(), childResource->GetHeight()));
+ }
+ else
+ {
+ pos = wxPoint(childResource->GetX(), childResource->GetY());
+ size = wxSize(childResource->GetWidth(), childResource->GetHeight());
+ }
- wxControl *control = NULL;
- wxString itemType(childResource->GetType());
- if (itemType == wxString("wxButton") || itemType == wxString("wxBitmapButton"))
- {
- if (childResource->GetValue4())
+ if (itemType == wxString(wxT("wxButton")) || itemType == wxString(wxT("wxBitmapButton")))
+ {
+ if (childResource->GetValue4() != wxT(""))
{
- // Bitmap button
- wxBitmap *bitmap = childResource->GetBitmap();
- if (!bitmap)
- {
- bitmap = wxResourceCreateBitmap(childResource->GetValue4(), (wxResourceTable *)this);
- childResource->SetBitmap(bitmap);
- }
- if (bitmap)
- control = new wxBitmapButton(parent, id, *bitmap,
- wxPoint(childResource->GetX(), childResource->GetY()),
- wxSize(childResource->GetWidth(), childResource->GetHeight()),
- childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
+ // Bitmap button
+ wxBitmap bitmap = childResource->GetBitmap();
+ if (!bitmap.Ok())
+ {
+ bitmap = wxResourceCreateBitmap(childResource->GetValue4(), (wxResourceTable *)this);
+ ((wxItemResource*) childResource)->SetBitmap(bitmap);
+ }
+ if (!bitmap.Ok())
+ bitmap.LoadFile("cross_bmp", wxBITMAP_TYPE_BMP_RESOURCE);
+ control = new wxBitmapButton(parent, id, bitmap, pos, size,
+ childResource->GetStyle() | wxBU_AUTODRAW, wxDefaultValidator, childResource->GetName());
}
else
- // Normal, text button
- control = new wxButton(parent, id, childResource->GetTitle(),
- wxPoint(childResource->GetX(), childResource->GetY()),
- wxSize(childResource->GetWidth(), childResource->GetHeight()),
- childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
- }
- else if (itemType == wxString("wxMessage") || itemType == wxString("wxStaticText") ||
- itemType == wxString("wxStaticBitmap"))
- {
- if (childResource->GetValue4())
+ // Normal, text button
+ control = new wxButton(parent, id, childResource->GetTitle(), pos, size,
+ childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
+ }
+ else if (itemType == wxString(wxT("wxMessage")) || itemType == wxString(wxT("wxStaticText")) ||
+ itemType == wxString(wxT("wxStaticBitmap")))
+ {
+ if (childResource->GetValue4() != wxT("") || itemType == wxString(wxT("wxStaticBitmap")) )
{
- // Bitmap message
- wxBitmap *bitmap = childResource->GetBitmap();
- if (!bitmap)
- {
- bitmap = wxResourceCreateBitmap(childResource->GetValue4(), (wxResourceTable *)this);
- childResource->SetBitmap(bitmap);
- }
-#if USE_BITMAP_MESSAGE
- if (bitmap)
- control = new wxStaticBitmap(parent, id, *bitmap,
- wxPoint(childResource->GetX(), childResource->GetY()),
- wxSize(childResource->GetWidth(), childResource->GetHeight()),
- childResource->GetStyle(), childResource->GetName());
+ // Bitmap message
+ wxBitmap bitmap = childResource->GetBitmap();
+ if (!bitmap.Ok())
+ {
+ bitmap = wxResourceCreateBitmap(childResource->GetValue4(), (wxResourceTable *)this);
+ ((wxItemResource*) childResource)->SetBitmap(bitmap);
+ }
+#if wxUSE_BITMAP_MESSAGE
+#ifdef __WXMSW__
+ // Use a default bitmap
+ if (!bitmap.Ok())
+ bitmap.LoadFile("cross_bmp", wxBITMAP_TYPE_BMP_RESOURCE);
+#endif
+
+ if (bitmap.Ok())
+ control = new wxStaticBitmap(parent, id, bitmap, pos, size,
+ childResource->GetStyle(), childResource->GetName());
#endif
}
else
{
- control = new wxStaticText(parent, id, childResource->GetTitle(),
- wxPoint(childResource->GetX(), childResource->GetY()),
- wxSize(childResource->GetWidth(), childResource->GetHeight()),
- childResource->GetStyle(), childResource->GetName());
+ control = new wxStaticText(parent, id, childResource->GetTitle(), pos, size,
+ childResource->GetStyle(), childResource->GetName());
}
- }
- else if (itemType == wxString("wxText") || itemType == wxString("wxTextCtrl") || itemType == wxString("wxMultiText"))
- {
- control = new wxTextCtrl(parent, id, childResource->GetValue4(),
- wxPoint(childResource->GetX(), childResource->GetY()),
- wxSize(childResource->GetWidth(), childResource->GetHeight()),
- childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
- }
- else if (itemType == wxString("wxCheckBox"))
- {
- control = new wxCheckBox(parent, id, childResource->GetTitle(),
- wxPoint(childResource->GetX(), childResource->GetY()),
- wxSize(childResource->GetWidth(), childResource->GetHeight()),
- childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
+ }
+ else if (itemType == wxString(wxT("wxText")) || itemType == wxString(wxT("wxTextCtrl")) || itemType == wxString(wxT("wxMultiText")))
+ {
+ control = new wxTextCtrl(parent, id, childResource->GetValue4(), pos, size,
+ childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
+ }
+ else if (itemType == wxString(wxT("wxCheckBox")))
+ {
+ control = new wxCheckBox(parent, id, childResource->GetTitle(), pos, size,
+ childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
((wxCheckBox *)control)->SetValue((childResource->GetValue1() != 0));
- }
-#if USE_GAUGE
- else if (itemType == wxString("wxGauge"))
- {
- control = new wxGauge(parent, id, (int)childResource->GetValue2(),
- wxPoint(childResource->GetX(), childResource->GetY()),
- wxSize(childResource->GetWidth(), childResource->GetHeight()),
- childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
+ }
+#if wxUSE_GAUGE
+ else if (itemType == wxString(wxT("wxGauge")))
+ {
+ control = new wxGauge(parent, id, (int)childResource->GetValue2(), pos, size,
+ childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
((wxGauge *)control)->SetValue((int)childResource->GetValue1());
- }
+ }
#endif
-#if USE_RADIOBUTTON
- else if (itemType == wxString("wxRadioButton"))
- {
+#if wxUSE_RADIOBTN
+ else if (itemType == wxString(wxT("wxRadioButton")))
+ {
control = new wxRadioButton(parent, id, childResource->GetTitle(), // (int)childResource->GetValue1(),
- wxPoint(childResource->GetX(), childResource->GetY()),
- wxSize(childResource->GetWidth(), childResource->GetHeight()),
- childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
- }
+ pos, size,
+ childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
+ }
#endif
-#if USE_SCROLLBAR
- else if (itemType == wxString("wxScrollBar"))
- {
- control = new wxScrollBar(parent, id,
- wxPoint(childResource->GetX(), childResource->GetY()),
- wxSize(childResource->GetWidth(), childResource->GetHeight()),
- childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
- ((wxScrollBar *)control)->SetValue((int)childResource->GetValue1());
- ((wxScrollBar *)control)->SetPageSize((int)childResource->GetValue2());
- ((wxScrollBar *)control)->SetObjectLength((int)childResource->GetValue3());
- ((wxScrollBar *)control)->SetViewLength((int)(long)childResource->GetValue5());
- }
+#if wxUSE_SCROLLBAR
+ else if (itemType == wxString(wxT("wxScrollBar")))
+ {
+ control = new wxScrollBar(parent, id, pos, size,
+ childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
+ /*
+ ((wxScrollBar *)control)->SetValue((int)childResource->GetValue1());
+ ((wxScrollBar *)control)->SetPageSize((int)childResource->GetValue2());
+ ((wxScrollBar *)control)->SetObjectLength((int)childResource->GetValue3());
+ ((wxScrollBar *)control)->SetViewLength((int)(long)childResource->GetValue5());
+ */
+ ((wxScrollBar *)control)->SetScrollbar((int)childResource->GetValue1(),(int)childResource->GetValue2(),
+ (int)childResource->GetValue3(),(int)(long)childResource->GetValue5(),FALSE);
+
+ }
#endif
- else if (itemType == wxString("wxSlider"))
- {
+ else if (itemType == wxString(wxT("wxSlider")))
+ {
control = new wxSlider(parent, id, (int)childResource->GetValue1(),
- (int)childResource->GetValue2(), (int)childResource->GetValue3(),
- wxPoint(childResource->GetX(), childResource->GetY()),
- wxSize(childResource->GetWidth(), childResource->GetHeight()),
- childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
- }
- else if (itemType == wxString("wxGroupBox") || itemType == wxString("wxStaticBox"))
- {
- control = new wxStaticBox(parent, id, childResource->GetTitle(),
- wxPoint(childResource->GetX(), childResource->GetY()),
- wxSize(childResource->GetWidth(), childResource->GetHeight()),
- childResource->GetStyle(), childResource->GetName());
- }
- else if (itemType == wxString("wxListBox"))
- {
- wxStringList *stringList = childResource->GetStringValues();
- wxString *strings = NULL;
+ (int)childResource->GetValue2(), (int)childResource->GetValue3(), pos, size,
+ childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
+ }
+ else if (itemType == wxString(wxT("wxGroupBox")) || itemType == wxString(wxT("wxStaticBox")))
+ {
+ control = new wxStaticBox(parent, id, childResource->GetTitle(), pos, size,
+ childResource->GetStyle(), childResource->GetName());
+ }
+ else if (itemType == wxString(wxT("wxListBox")))
+ {
+ wxStringList& stringList = childResource->GetStringValues();
+ wxString *strings = (wxString *) NULL;
int noStrings = 0;
- if (stringList && (stringList->Number() > 0))
+ if (stringList.Number() > 0)
{
- noStrings = stringList->Number();
- strings = new wxString[noStrings];
- wxNode *node = stringList->First();
- int i = 0;
- while (node)
- {
- strings[i] = (char *)node->Data();
- i ++;
- node = node->Next();
- }
+ noStrings = stringList.Number();
+ strings = new wxString[noStrings];
+ wxNode *node = stringList.First();
+ int i = 0;
+ while (node)
+ {
+ strings[i] = (wxChar *)node->Data();
+ i ++;
+ node = node->Next();
+ }
}
- control = new wxListBox(parent, id,
- wxPoint(childResource->GetX(), childResource->GetY()),
- wxSize(childResource->GetWidth(), childResource->GetHeight()),
- noStrings, strings, childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
+ control = new wxListBox(parent, id, pos, size,
+ noStrings, strings, childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
if (strings)
- delete[] strings;
- }
- else if (itemType == wxString("wxChoice"))
- {
- wxStringList *stringList = childResource->GetStringValues();
- wxString *strings = NULL;
+ delete[] strings;
+ }
+ else if (itemType == wxString(wxT("wxChoice")))
+ {
+ wxStringList& stringList = childResource->GetStringValues();
+ wxString *strings = (wxString *) NULL;
int noStrings = 0;
- if (stringList && (stringList->Number() > 0))
+ if (stringList.Number() > 0)
{
- noStrings = stringList->Number();
- strings = new wxString[noStrings];
- wxNode *node = stringList->First();
- int i = 0;
- while (node)
- {
- strings[i] = (char *)node->Data();
- i ++;
- node = node->Next();
- }
+ noStrings = stringList.Number();
+ strings = new wxString[noStrings];
+ wxNode *node = stringList.First();
+ int i = 0;
+ while (node)
+ {
+ strings[i] = (wxChar *)node->Data();
+ i ++;
+ node = node->Next();
+ }
}
- control = new wxChoice(parent, id,
- wxPoint(childResource->GetX(), childResource->GetY()),
- wxSize(childResource->GetWidth(), childResource->GetHeight()),
- noStrings, strings, childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
+ control = new wxChoice(parent, id, pos, size,
+ noStrings, strings, childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
if (strings)
- delete[] strings;
- }
-#if USE_COMBOBOX
- else if (itemType == wxString("wxComboBox"))
- {
- wxStringList *stringList = childResource->GetStringValues();
- wxString *strings = NULL;
+ delete[] strings;
+ }
+#if wxUSE_COMBOBOX
+ else if (itemType == wxString(wxT("wxComboBox")))
+ {
+ wxStringList& stringList = childResource->GetStringValues();
+ wxString *strings = (wxString *) NULL;
int noStrings = 0;
- if (stringList && (stringList->Number() > 0))
+ if (stringList.Number() > 0)
{
- noStrings = stringList->Number();
- strings = new wxString[noStrings];
- wxNode *node = stringList->First();
- int i = 0;
- while (node)
- {
- strings[i] = (char *)node->Data();
- i ++;
- node = node->Next();
- }
+ noStrings = stringList.Number();
+ strings = new wxString[noStrings];
+ wxNode *node = stringList.First();
+ int i = 0;
+ while (node)
+ {
+ strings[i] = (wxChar *)node->Data();
+ i ++;
+ node = node->Next();
+ }
}
- control = new wxComboBox(parent, id, childResource->GetValue4(),
- wxPoint(childResource->GetX(), childResource->GetY()),
- wxSize(childResource->GetWidth(), childResource->GetHeight()),
- noStrings, strings, childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
+ control = new wxComboBox(parent, id, childResource->GetValue4(), pos, size,
+ noStrings, strings, childResource->GetStyle(), wxDefaultValidator, childResource->GetName());
if (strings)
- delete[] strings;
- }
+ delete[] strings;
+ }
#endif
- else if (itemType == wxString("wxRadioBox"))
- {
- wxStringList *stringList = childResource->GetStringValues();
- wxString *strings = NULL;
+ else if (itemType == wxString(wxT("wxRadioBox")))
+ {
+ wxStringList& stringList = childResource->GetStringValues();
+ wxString *strings = (wxString *) NULL;
int noStrings = 0;
- if (stringList && (stringList->Number() > 0))
+ if (stringList.Number() > 0)
{
- noStrings = stringList->Number();
- strings = new wxString[noStrings];
- wxNode *node = stringList->First();
- int i = 0;
- while (node)
- {
- strings[i] = (char *)node->Data();
- i ++;
- node = node->Next();
- }
+ noStrings = stringList.Number();
+ strings = new wxString[noStrings];
+ wxNode *node = stringList.First();
+ int i = 0;
+ while (node)
+ {
+ strings[i] = (wxChar *)node->Data();
+ i ++;
+ node = node->Next();
+ }
}
- control = new wxRadioBox(parent, (const wxWindowID) id, wxString(childResource->GetTitle()),
- wxPoint(childResource->GetX(), childResource->GetY()),
- wxSize(childResource->GetWidth(), childResource->GetHeight()),
- noStrings, strings, (int)childResource->GetValue1(), childResource->GetStyle(), wxDefaultValidator,
- childResource->GetName());
+ control = new wxRadioBox(parent, (wxWindowID) id, wxString(childResource->GetTitle()), pos, size,
+ noStrings, strings, (int)childResource->GetValue1(), childResource->GetStyle(), wxDefaultValidator,
+ childResource->GetName());
if (strings)
- delete[] strings;
- }
+ delete[] strings;
+ }
- if (control && childResource->GetFont())
- control->SetFont(*childResource->GetFont());
- return control;
+ if ((parentResource->GetResourceStyle() & wxRESOURCE_USE_DEFAULTS) != 0)
+ {
+ // Don't set font; will be inherited from parent.
+ }
+ else
+ {
+ if (control && childResource->GetFont().Ok())
+ {
+ control->SetFont(childResource->GetFont());
+
+#ifdef __WXMSW__
+ // Force the layout algorithm since the size changes the layout
+ if (control->IsKindOf(CLASSINFO(wxRadioBox)))
+ {
+ control->SetSize(-1, -1, -1, -1, wxSIZE_AUTO_WIDTH|wxSIZE_AUTO_HEIGHT);
+ }
+#endif
+ }
+ }
+ return control;
}
/*
- * Interpret database as a series of resources
- */
+* Interpret database as a series of resources
+*/
-bool wxResourceInterpretResources(wxResourceTable& table, PrologDatabase& db)
+bool wxResourceInterpretResources(wxResourceTable& table, wxExprDatabase& db)
{
- wxNode *node = db.First();
- while (node)
- {
- PrologExpr *clause = (PrologExpr *)node->Data();
- wxString functor(clause->Functor());
-
- wxItemResource *item = NULL;
- if (functor == "dialog")
- item = wxResourceInterpretDialog(table, clause);
- else if (functor == "panel")
- item = wxResourceInterpretDialog(table, clause, TRUE);
- else if (functor == "menubar")
- item = wxResourceInterpretMenuBar(table, clause);
- else if (functor == "menu")
- item = wxResourceInterpretMenu(table, clause);
- else if (functor == "string")
- item = wxResourceInterpretString(table, clause);
- else if (functor == "bitmap")
- item = wxResourceInterpretBitmap(table, clause);
- else if (functor == "icon")
- item = wxResourceInterpretIcon(table, clause);
-
- if (item)
+ wxNode *node = db.First();
+ while (node)
{
- // Remove any existing resource of same name
- if (item->GetName())
- table.DeleteResource(item->GetName());
- table.AddResource(item);
+ wxExpr *clause = (wxExpr *)node->Data();
+ wxString functor(clause->Functor());
+
+ wxItemResource *item = (wxItemResource *) NULL;
+ if (functor == wxT("dialog"))
+ item = wxResourceInterpretDialog(table, clause);
+ else if (functor == wxT("panel"))
+ item = wxResourceInterpretDialog(table, clause, TRUE);
+ else if (functor == wxT("menubar"))
+ item = wxResourceInterpretMenuBar(table, clause);
+ else if (functor == wxT("menu"))
+ item = wxResourceInterpretMenu(table, clause);
+ else if (functor == wxT("string"))
+ item = wxResourceInterpretString(table, clause);
+ else if (functor == wxT("bitmap"))
+ item = wxResourceInterpretBitmap(table, clause);
+ else if (functor == wxT("icon"))
+ item = wxResourceInterpretIcon(table, clause);
+
+ if (item)
+ {
+ // Remove any existing resource of same name
+ if (item->GetName() != wxT(""))
+ table.DeleteResource(item->GetName());
+ table.AddResource(item);
+ }
+ node = node->Next();
}
- node = node->Next();
- }
- return TRUE;
+ return TRUE;
}
-static char *g_ValidControlClasses[] = { "wxButton", "wxBitmapButton", "wxMessage",
- "wxStaticText", "wxStaticBitmap", "wxText", "wxTextCtrl", "wxMultiText",
- "wxListBox", "wxRadioBox", "wxRadioButton", "wxCheckBox", "wxBitmapCheckBox",
- "wxGroupBox", "wxStaticBox", "wxSlider", "wxGauge", "wxScrollBar",
- "wxChoice", "wxComboBox" } ;
-static int g_ValidControlClassesCount = sizeof(g_ValidControlClasses) / sizeof(char *) ;
+static const wxChar *g_ValidControlClasses[] =
+{
+ wxT("wxButton"),
+ wxT("wxBitmapButton"),
+ wxT("wxMessage"),
+ wxT("wxStaticText"),
+ wxT("wxStaticBitmap"),
+ wxT("wxText"),
+ wxT("wxTextCtrl"),
+ wxT("wxMultiText"),
+ wxT("wxListBox"),
+ wxT("wxRadioBox"),
+ wxT("wxRadioButton"),
+ wxT("wxCheckBox"),
+ wxT("wxBitmapCheckBox"),
+ wxT("wxGroupBox"),
+ wxT("wxStaticBox"),
+ wxT("wxSlider"),
+ wxT("wxGauge"),
+ wxT("wxScrollBar"),
+ wxT("wxChoice"),
+ wxT("wxComboBox")
+};
static bool wxIsValidControlClass(const wxString& c)
{
- int i;
- for ( i = 0; i < g_ValidControlClassesCount; i++)
- {
- if ( c == g_ValidControlClasses[i] )
- return TRUE;
- }
- return FALSE;
+ for ( size_t i = 0; i < WXSIZEOF(g_ValidControlClasses); i++ )
+ {
+ if ( c == g_ValidControlClasses[i] )
+ return TRUE;
+ }
+ return FALSE;
}
-wxItemResource *wxResourceInterpretDialog(wxResourceTable& table, PrologExpr *expr, bool isPanel)
+wxItemResource *wxResourceInterpretDialog(wxResourceTable& table, wxExpr *expr, bool isPanel)
{
- wxItemResource *dialogItem = new wxItemResource;
- if (isPanel)
- dialogItem->SetType("wxPanel");
- else
- dialogItem->SetType("wxDialog");
- char *style = NULL;
- char *title = NULL;
- char *name = NULL;
- char *backColourHex = NULL;
- char *labelColourHex = NULL;
- char *buttonColourHex = NULL;
-
- long windowStyle = wxDEFAULT_DIALOG_STYLE;
- if (isPanel)
- windowStyle = 0;
-
- int x = 0; int y = 0; int width = -1; int height = -1;
- int isModal = 0;
- PrologExpr *labelFontExpr = NULL;
- PrologExpr *buttonFontExpr = NULL;
- PrologExpr *fontExpr = NULL;
- expr->AssignAttributeValue("style", &style);
- expr->AssignAttributeValue("name", &name);
- expr->AssignAttributeValue("title", &title);
- expr->AssignAttributeValue("x", &x);
- expr->AssignAttributeValue("y", &y);
- expr->AssignAttributeValue("width", &width);
- expr->AssignAttributeValue("height", &height);
- expr->AssignAttributeValue("modal", &isModal);
- expr->AssignAttributeValue("label_font", &labelFontExpr);
- expr->AssignAttributeValue("button_font", &buttonFontExpr);
- expr->AssignAttributeValue("font", &fontExpr);
- expr->AssignAttributeValue("background_colour", &backColourHex);
- expr->AssignAttributeValue("label_colour", &labelColourHex);
- expr->AssignAttributeValue("button_colour", &buttonColourHex);
-
- if (style)
- {
- windowStyle = wxParseWindowStyle(style);
- }
- dialogItem->SetStyle(windowStyle);
- dialogItem->SetValue1(isModal);
- if (name)
+ wxItemResource *dialogItem = new wxItemResource;
+ if (isPanel)
+ dialogItem->SetType(wxT("wxPanel"));
+ else
+ dialogItem->SetType(wxT("wxDialog"));
+ wxString style = wxT("");
+ wxString title = wxT("");
+ wxString name = wxT("");
+ wxString backColourHex = wxT("");
+ wxString labelColourHex = wxT("");
+ wxString buttonColourHex = wxT("");
+
+ long windowStyle = wxDEFAULT_DIALOG_STYLE;
+ if (isPanel)
+ windowStyle = 0;
+
+ int x = 0; int y = 0; int width = -1; int height = -1;
+ int isModal = 0;
+ wxExpr *labelFontExpr = (wxExpr *) NULL;
+ wxExpr *buttonFontExpr = (wxExpr *) NULL;
+ wxExpr *fontExpr = (wxExpr *) NULL;
+ expr->GetAttributeValue(wxT("style"), style);
+ expr->GetAttributeValue(wxT("name"), name);
+ expr->GetAttributeValue(wxT("title"), title);
+ expr->GetAttributeValue(wxT("x"), x);
+ expr->GetAttributeValue(wxT("y"), y);
+ expr->GetAttributeValue(wxT("width"), width);
+ expr->GetAttributeValue(wxT("height"), height);
+ expr->GetAttributeValue(wxT("modal"), isModal);
+ expr->GetAttributeValue(wxT("label_font"), &labelFontExpr);
+ expr->GetAttributeValue(wxT("button_font"), &buttonFontExpr);
+ expr->GetAttributeValue(wxT("font"), &fontExpr);
+ expr->GetAttributeValue(wxT("background_colour"), backColourHex);
+ expr->GetAttributeValue(wxT("label_colour"), labelColourHex);
+ expr->GetAttributeValue(wxT("button_colour"), buttonColourHex);
+
+ int useDialogUnits = 0;
+ expr->GetAttributeValue(wxT("use_dialog_units"), useDialogUnits);
+ if (useDialogUnits != 0)
+ dialogItem->SetResourceStyle(dialogItem->GetResourceStyle() | wxRESOURCE_DIALOG_UNITS);
+
+ int useDefaults = 0;
+ expr->GetAttributeValue(wxT("use_system_defaults"), useDefaults);
+ if (useDefaults != 0)
+ dialogItem->SetResourceStyle(dialogItem->GetResourceStyle() | wxRESOURCE_USE_DEFAULTS);
+
+ int id = 0;
+ expr->GetAttributeValue(wxT("id"), id);
+ dialogItem->SetId(id);
+
+ if (style != wxT(""))
+ {
+ windowStyle = wxParseWindowStyle(style);
+ }
+ dialogItem->SetStyle(windowStyle);
+ dialogItem->SetValue1(isModal);
+ if (windowStyle & wxDIALOG_MODAL) // Uses style in wxWin 2
+ dialogItem->SetValue1(TRUE);
+
dialogItem->SetName(name);
- if (title)
dialogItem->SetTitle(title);
- dialogItem->SetSize(x, y, width, height);
-
- if (backColourHex)
- {
- int r = 0;
- int g = 0;
- int b = 0;
- r = wxHexToDec(backColourHex);
- g = wxHexToDec(backColourHex+2);
- b = wxHexToDec(backColourHex+4);
- dialogItem->SetBackgroundColour(new wxColour((unsigned char)r,(unsigned char)g,(unsigned char)b));
- delete[] backColourHex;
- }
- if (labelColourHex)
- {
- int r = 0;
- int g = 0;
- int b = 0;
- r = wxHexToDec(labelColourHex);
- g = wxHexToDec(labelColourHex+2);
- b = wxHexToDec(labelColourHex+4);
- dialogItem->SetLabelColour(new wxColour((unsigned char)r,(unsigned char)g,(unsigned char)b));
- delete[] labelColourHex;
- }
- if (buttonColourHex)
- {
- int r = 0;
- int g = 0;
- int b = 0;
- r = wxHexToDec(buttonColourHex);
- g = wxHexToDec(buttonColourHex+2);
- b = wxHexToDec(buttonColourHex+4);
- dialogItem->SetButtonColour(new wxColour((unsigned char)r,(unsigned char)g,(unsigned char)b));
- delete[] buttonColourHex;
- }
+ dialogItem->SetSize(x, y, width, height);
- if (name)
- delete[] name;
- if (title)
- delete[] title;
- if (style)
- delete[] style;
-
- if (fontExpr)
- dialogItem->SetFont(wxResourceInterpretFontSpec(fontExpr));
- else if (buttonFontExpr)
- dialogItem->SetFont(wxResourceInterpretFontSpec(buttonFontExpr));
- else if (labelFontExpr)
- dialogItem->SetFont(wxResourceInterpretFontSpec(labelFontExpr));
-
- // Now parse all controls
- PrologExpr *controlExpr = expr->GetFirst();
- while (controlExpr)
- {
- if (controlExpr->Number() == 3)
- {
- wxString controlKeyword(controlExpr->Nth(1)->StringValue());
- if (controlKeyword != "" && controlKeyword == "control")
- {
- // The value part: always a list.
- PrologExpr *listExpr = controlExpr->Nth(2);
- if (listExpr->Type() == PrologList)
+ // Check for wxWin 1.68-style specifications
+ if (style.Find(wxT("VERTICAL_LABEL")) != -1)
+ dialogItem->SetResourceStyle(dialogItem->GetResourceStyle() | wxRESOURCE_VERTICAL_LABEL);
+ else if (style.Find(wxT("HORIZONTAL_LABEL")) != -1)
+ dialogItem->SetResourceStyle(dialogItem->GetResourceStyle() | wxRESOURCE_HORIZONTAL_LABEL);
+
+ if (backColourHex != wxT(""))
+ {
+ int r = 0;
+ int g = 0;
+ int b = 0;
+ r = wxHexToDec(backColourHex.Mid(0, 2));
+ g = wxHexToDec(backColourHex.Mid(2, 2));
+ b = wxHexToDec(backColourHex.Mid(4, 2));
+ dialogItem->SetBackgroundColour(wxColour((unsigned char)r,(unsigned char)g,(unsigned char)b));
+ }
+ if (labelColourHex != wxT(""))
+ {
+ int r = 0;
+ int g = 0;
+ int b = 0;
+ r = wxHexToDec(labelColourHex.Mid(0, 2));
+ g = wxHexToDec(labelColourHex.Mid(2, 2));
+ b = wxHexToDec(labelColourHex.Mid(4, 2));
+ dialogItem->SetLabelColour(wxColour((unsigned char)r,(unsigned char)g,(unsigned char)b));
+ }
+ if (buttonColourHex != wxT(""))
+ {
+ int r = 0;
+ int g = 0;
+ int b = 0;
+ r = wxHexToDec(buttonColourHex.Mid(0, 2));
+ g = wxHexToDec(buttonColourHex.Mid(2, 2));
+ b = wxHexToDec(buttonColourHex.Mid(4, 2));
+ dialogItem->SetButtonColour(wxColour((unsigned char)r,(unsigned char)g,(unsigned char)b));
+ }
+
+ if (fontExpr)
+ dialogItem->SetFont(wxResourceInterpretFontSpec(fontExpr));
+ else if (buttonFontExpr)
+ dialogItem->SetFont(wxResourceInterpretFontSpec(buttonFontExpr));
+ else if (labelFontExpr)
+ dialogItem->SetFont(wxResourceInterpretFontSpec(labelFontExpr));
+
+ // Now parse all controls
+ wxExpr *controlExpr = expr->GetFirst();
+ while (controlExpr)
+ {
+ if (controlExpr->Number() == 3)
{
- wxItemResource *controlItem = wxResourceInterpretControl(table, listExpr);
- if (controlItem)
- {
- dialogItem->GetChildren().Append(controlItem);
- }
+ wxString controlKeyword(controlExpr->Nth(1)->StringValue());
+ if (controlKeyword != wxT("") && controlKeyword == wxT("control"))
+ {
+ // The value part: always a list.
+ wxExpr *listExpr = controlExpr->Nth(2);
+ if (listExpr->Type() == PrologList)
+ {
+ wxItemResource *controlItem = wxResourceInterpretControl(table, listExpr);
+ if (controlItem)
+ {
+ dialogItem->GetChildren().Append(controlItem);
+ }
+ }
+ }
}
- }
+ controlExpr = controlExpr->GetNext();
}
- controlExpr = controlExpr->GetNext();
- }
- return dialogItem;
+ return dialogItem;
}
-wxItemResource *wxResourceInterpretControl(wxResourceTable& table, PrologExpr *expr)
+wxItemResource *wxResourceInterpretControl(wxResourceTable& table, wxExpr *expr)
{
- wxItemResource *controlItem = new wxItemResource;
+ wxItemResource *controlItem = new wxItemResource;
- // First, find the standard features of a control definition:
- // [optional integer/string id], control name, title, style, name, x, y, width, height
+ // First, find the standard features of a control definition:
+ // [optional integer/string id], control name, title, style, name, x, y, width, height
- wxString controlType;
- wxString style;
- wxString title;
- wxString name;
- int id = 0;
- long windowStyle = 0;
- int x = 0; int y = 0; int width = -1; int height = -1;
- int count = 0;
+ wxString controlType;
+ wxString style;
+ wxString title;
+ wxString name;
+ int id = 0;
+ long windowStyle = 0;
+ int x = 0; int y = 0; int width = -1; int height = -1;
+ int count = 0;
- PrologExpr *expr1 = expr->Nth(0);
+ wxExpr *expr1 = expr->Nth(0);
- if ( expr1->Type() == PrologString || expr1->Type() == PrologWord )
- {
- if ( wxIsValidControlClass(expr1->StringValue()) )
- {
- count = 1;
- controlType = expr1->StringValue();
- }
- else
- {
- id = wxResourceGetIdentifier(WXSTRINGCAST expr1->StringValue(), &table);
- if (id == 0)
+ if ( expr1->Type() == PrologString || expr1->Type() == PrologWord )
+ {
+ if ( wxIsValidControlClass(expr1->StringValue()) )
{
- char buf[300];
- sprintf(buf, "Could not resolve control class or id '%s'. Use (non-zero) integer instead\n or provide #define (see manual for caveats)",
- (const char*) expr1->StringValue());
- wxWarning(buf);
- delete controlItem;
- return NULL;
+ count = 1;
+ controlType = expr1->StringValue();
}
- else
- {
- // Success - we have an id, so the 2nd element must be the control class.
- controlType = expr->Nth(1)->StringValue();
- count = 2;
- }
- }
- }
- else if (expr1->Type() == PrologInteger)
- {
+ else
+ {
+ wxString str(expr1->StringValue());
+ id = wxResourceGetIdentifier(str, &table);
+ if (id == 0)
+ {
+ wxLogWarning(_("Could not resolve control class or id '%s'. Use (non-zero) integer instead\n or provide #define (see manual for caveats)"),
+ (const wxChar*) expr1->StringValue());
+ delete controlItem;
+ return (wxItemResource *) NULL;
+ }
+ else
+ {
+ // Success - we have an id, so the 2nd element must be the control class.
+ controlType = expr->Nth(1)->StringValue();
+ count = 2;
+ }
+ }
+ }
+ else if (expr1->Type() == PrologInteger)
+ {
id = (int)expr1->IntegerValue();
- // Success - we have an id, so the 2nd element must be the control class.
- controlType = expr->Nth(1)->StringValue();
- count = 2;
- }
+ // Success - we have an id, so the 2nd element must be the control class.
+ controlType = expr->Nth(1)->StringValue();
+ count = 2;
+ }
- expr1 = expr->Nth(count);
- count ++;
- if ( expr1 )
- title = expr1->StringValue();
+ expr1 = expr->Nth(count);
+ count ++;
+ if ( expr1 )
+ title = expr1->StringValue();
- expr1 = expr->Nth(count);
- count ++;
- if (expr1)
- {
- style = expr1->StringValue();
- windowStyle = wxParseWindowStyle(WXSTRINGCAST style);
- }
+ expr1 = expr->Nth(count);
+ count ++;
+ if (expr1)
+ {
+ style = expr1->StringValue();
+ windowStyle = wxParseWindowStyle(style);
+ }
- expr1 = expr->Nth(count);
- count ++;
- if (expr1)
- name = expr1->StringValue();
-
- expr1 = expr->Nth(count);
- count ++;
- if (expr1)
- x = (int)expr1->IntegerValue();
-
- expr1 = expr->Nth(count);
- count ++;
- if (expr1)
- y = (int)expr1->IntegerValue();
-
- expr1 = expr->Nth(count);
- count ++;
- if (expr1)
- width = (int)expr1->IntegerValue();
-
- expr1 = expr->Nth(count);
- count ++;
- if (expr1)
- height = (int)expr1->IntegerValue();
-
- controlItem->SetStyle(windowStyle);
- controlItem->SetName(WXSTRINGCAST name);
- controlItem->SetTitle(WXSTRINGCAST title);
- controlItem->SetSize(x, y, width, height);
- controlItem->SetType(WXSTRINGCAST controlType);
- controlItem->SetId(id);
-
- if (controlType == "wxButton")
- {
- // Check for bitmap resource name
- if (expr->Nth(count) && ((expr->Nth(count)->Type() == PrologString) || (expr->Nth(count)->Type() == PrologWord)))
+ expr1 = expr->Nth(count);
+ count ++;
+ if (expr1)
+ name = expr1->StringValue();
+
+ expr1 = expr->Nth(count);
+ count ++;
+ if (expr1)
+ x = (int)expr1->IntegerValue();
+
+ expr1 = expr->Nth(count);
+ count ++;
+ if (expr1)
+ y = (int)expr1->IntegerValue();
+
+ expr1 = expr->Nth(count);
+ count ++;
+ if (expr1)
+ width = (int)expr1->IntegerValue();
+
+ expr1 = expr->Nth(count);
+ count ++;
+ if (expr1)
+ height = (int)expr1->IntegerValue();
+
+ controlItem->SetStyle(windowStyle);
+ controlItem->SetName(name);
+ controlItem->SetTitle(title);
+ controlItem->SetSize(x, y, width, height);
+ controlItem->SetType(controlType);
+ controlItem->SetId(id);
+
+ // Check for wxWin 1.68-style specifications
+ if (style.Find(wxT("VERTICAL_LABEL")) != -1)
+ controlItem->SetResourceStyle(controlItem->GetResourceStyle() | wxRESOURCE_VERTICAL_LABEL);
+ else if (style.Find(wxT("HORIZONTAL_LABEL")) != -1)
+ controlItem->SetResourceStyle(controlItem->GetResourceStyle() | wxRESOURCE_HORIZONTAL_LABEL);
+
+ if (controlType == wxT("wxButton"))
{
- controlItem->SetValue4(WXSTRINGCAST expr->Nth(count)->StringValue());
- count ++;
- if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
- controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
+ // Check for bitmap resource name (in case loading old-style resource file)
+ if (expr->Nth(count) && ((expr->Nth(count)->Type() == PrologString) || (expr->Nth(count)->Type() == PrologWord)))
+ {
+ wxString str(expr->Nth(count)->StringValue());
+ count ++;
+
+ if (str != wxT(""))
+ {
+ controlItem->SetValue4(str);
+ controlItem->SetType(wxT("wxBitmapButton"));
+ }
+ }
+ if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
+ controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
}
- }
- else if (controlType == "wxCheckBox")
- {
- // Check for default value
- if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
- {
- controlItem->SetValue1(expr->Nth(count)->IntegerValue());
- count ++;
- if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
- controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
+ else if (controlType == wxT("wxBitmapButton"))
+ {
+ // Check for bitmap resource name
+ if (expr->Nth(count) && ((expr->Nth(count)->Type() == PrologString) || (expr->Nth(count)->Type() == PrologWord)))
+ {
+ wxString str(expr->Nth(count)->StringValue());
+ controlItem->SetValue4(str);
+ count ++;
+ if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
+ controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
+ }
}
- }
-#if USE_RADIOBUTTON
- else if (controlType == "wxRadioButton")
- {
- // Check for default value
- if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
- {
- controlItem->SetValue1(expr->Nth(count)->IntegerValue());
- count ++;
- if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
- controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
+ else if (controlType == wxT("wxCheckBox"))
+ {
+ // Check for default value
+ if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
+ {
+ controlItem->SetValue1(expr->Nth(count)->IntegerValue());
+ count ++;
+ if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
+ controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
+ }
}
- }
-#endif
- else if (controlType == "wxText" || controlType == "wxTextCtrl")
- {
- // Check for default value
- if (expr->Nth(count) && ((expr->Nth(count)->Type() == PrologString) || (expr->Nth(count)->Type() == PrologWord)))
- {
- controlItem->SetValue4(WXSTRINGCAST expr->Nth(count)->StringValue());
- count ++;
-
- if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
- {
- // controlItem->SetLabelFont(wxResourceInterpretFontSpec(expr->Nth(count)));
- // Do nothing - no label font any more
- count ++;
- if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
- controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
- }
- }
- }
- else if (controlType == "wxMessage" || controlType == "wxStaticText")
- {
- // Check for bitmap resource name
- if (expr->Nth(count) && ((expr->Nth(count)->Type() == PrologString) || (expr->Nth(count)->Type() == PrologWord)))
+#if wxUSE_RADIOBTN
+ else if (controlType == wxT("wxRadioButton"))
{
- controlItem->SetValue4(WXSTRINGCAST expr->Nth(count)->StringValue());
- count ++;
- if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
- controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
+ // Check for default value
+ if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
+ {
+ controlItem->SetValue1(expr->Nth(count)->IntegerValue());
+ count ++;
+ if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
+ controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
+ }
}
- }
- else if (controlType == "wxGroupBox" || controlType == "wxStaticBox")
- {
- if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
- controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
- }
- else if (controlType == "wxGauge")
- {
- // Check for default value
- if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
- {
- controlItem->SetValue1(expr->Nth(count)->IntegerValue());
- count ++;
-
- // Check for range
- if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
- {
- controlItem->SetValue2(expr->Nth(count)->IntegerValue());
- count ++;
-
- if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
+#endif
+ else if (controlType == wxT("wxText") || controlType == wxT("wxTextCtrl") || controlType == wxT("wxMultiText"))
+ {
+ // Check for default value
+ if (expr->Nth(count) && ((expr->Nth(count)->Type() == PrologString) || (expr->Nth(count)->Type() == PrologWord)))
{
- // controlItem->SetLabelFont(wxResourceInterpretFontSpec(expr->Nth(count)));
- // Do nothing
- count ++;
-
- if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
- controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
- }
- }
- }
- }
- else if (controlType == "wxSlider")
- {
- // Check for default value
- if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
- {
- controlItem->SetValue1(expr->Nth(count)->IntegerValue());
- count ++;
-
- // Check for min
- if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
- {
- controlItem->SetValue2(expr->Nth(count)->IntegerValue());
- count ++;
-
- // Check for max
- if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
- {
- controlItem->SetValue3(expr->Nth(count)->IntegerValue());
- count ++;
-
- if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
- {
- // controlItem->SetLabelFont(wxResourceInterpretFontSpec(expr->Nth(count)));
- // do nothing
- count ++;
+ wxString str(expr->Nth(count)->StringValue());
+ controlItem->SetValue4(str);
+ count ++;
if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
- controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
- }
- }
- }
- }
- }
- else if (controlType == "wxScrollBar")
- {
- // DEFAULT VALUE
- if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
- {
- controlItem->SetValue1(expr->Nth(count)->IntegerValue());
- count ++;
-
- // PAGE LENGTH
- if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
- {
- controlItem->SetValue2(expr->Nth(count)->IntegerValue());
- count ++;
-
- // OBJECT LENGTH
- if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
- {
- controlItem->SetValue3(expr->Nth(count)->IntegerValue());
- count ++;
-
- // VIEW LENGTH
- if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
- controlItem->SetValue5(expr->Nth(count)->IntegerValue());
- }
- }
- }
- }
- else if (controlType == "wxListBox")
- {
- PrologExpr *valueList = NULL;
-
- if ((valueList = expr->Nth(count)) && (valueList->Type() == PrologList))
- {
- wxStringList *stringList = new wxStringList;
- PrologExpr *stringExpr = valueList->GetFirst();
- while (stringExpr)
- {
- stringList->Add(stringExpr->StringValue());
- stringExpr = stringExpr->GetNext();
- }
- controlItem->SetStringValues(stringList);
- count ++;
-
- // Check for wxSINGLE/wxMULTIPLE
- PrologExpr *mult = NULL;
- controlItem->SetValue1(wxLB_SINGLE);
- if ((mult = expr->Nth(count)) && ((mult->Type() == PrologString)||(mult->Type() == PrologWord)))
- {
- wxString m(mult->StringValue());
- if (m == "wxMULTIPLE")
- controlItem->SetValue1(wxLB_MULTIPLE);
- else if (m == "wxEXTENDED")
- controlItem->SetValue1(wxLB_EXTENDED);
- count ++;
+ {
+ // controlItem->SetLabelFont(wxResourceInterpretFontSpec(expr->Nth(count)));
+ // Skip past the obsolete label font spec if there are two consecutive specs
+ if (expr->Nth(count+1) && expr->Nth(count+1)->Type() == PrologList)
+ count ++;
+ controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
+ }
+ }
+ }
+ else if (controlType == wxT("wxMessage") || controlType == wxT("wxStaticText"))
+ {
+ // Check for bitmap resource name (in case it's an old-style .wxr file)
+ if (expr->Nth(count) && ((expr->Nth(count)->Type() == PrologString) || (expr->Nth(count)->Type() == PrologWord)))
+ {
+ wxString str(expr->Nth(count)->StringValue());
+ controlItem->SetValue4(str);
+ count ++;
+ controlItem->SetType(wxT("wxStaticText"));
+ }
if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
- {
- // controlItem->SetLabelFont(wxResourceInterpretFontSpec(expr->Nth(count)));
- count ++;
- if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
- }
- }
- }
- }
- else if (controlType == "wxChoice")
- {
- PrologExpr *valueList = NULL;
- // Check for default value list
- if ((valueList = expr->Nth(count)) && (valueList->Type() == PrologList))
- {
- wxStringList *stringList = new wxStringList;
- PrologExpr *stringExpr = valueList->GetFirst();
- while (stringExpr)
- {
- stringList->Add(stringExpr->StringValue());
- stringExpr = stringExpr->GetNext();
- }
- controlItem->SetStringValues(stringList);
-
- count ++;
-
- if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
- {
- // controlItem->SetLabelFont(wxResourceInterpretFontSpec(expr->Nth(count)));
- count ++;
-
- if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
- controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
- }
- }
- }
-#if USE_COMBOBOX
- else if (controlType == "wxComboBox")
- {
- PrologExpr *textValue = expr->Nth(count);
- if (textValue && (textValue->Type() == PrologString || textValue->Type() == PrologWord))
- {
- controlItem->SetValue4(WXSTRINGCAST textValue->StringValue());
-
- count ++;
-
- PrologExpr *valueList = NULL;
- // Check for default value list
- if ((valueList = expr->Nth(count)) && (valueList->Type() == PrologList))
- {
- wxStringList *stringList = new wxStringList;
- PrologExpr *stringExpr = valueList->GetFirst();
- while (stringExpr)
+ }
+ else if (controlType == wxT("wxStaticBitmap"))
+ {
+ // Check for bitmap resource name
+ if (expr->Nth(count) && ((expr->Nth(count)->Type() == PrologString) || (expr->Nth(count)->Type() == PrologWord)))
{
- stringList->Add(stringExpr->StringValue());
- stringExpr = stringExpr->GetNext();
+ wxString str(expr->Nth(count)->StringValue());
+ controlItem->SetValue4(str);
+ count ++;
}
- controlItem->SetStringValues(stringList);
-
- count ++;
-
if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
- {
- // controlItem->SetLabelFont(wxResourceInterpretFontSpec(expr->Nth(count)));
- count ++;
-
- if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
- }
- }
- }
- }
-#endif
-#if 0
- else if (controlType == "wxRadioBox")
- {
- PrologExpr *valueList = NULL;
- // Check for default value list
- if ((valueList = expr->Nth(count)) && (valueList->Type() == PrologList))
- {
- wxStringList *stringList = new wxStringList;
- PrologExpr *stringExpr = valueList->GetFirst();
- while (stringExpr)
- {
- stringList->Add(stringExpr->StringValue());
- stringExpr = stringExpr->GetNext();
- }
- controlItem->SetStringValues(stringList);
- count ++;
-
- // majorDim (number of rows or cols)
- if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
- {
- controlItem->SetValue1(expr->Nth(count)->IntegerValue());
- count ++;
- }
- else
- controlItem->SetValue1(0);
-
- if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
- {
- // controlItem->SetLabelFont(wxResourceInterpretFontSpec(expr->Nth(count)));
- count ++;
-
+ }
+ else if (controlType == wxT("wxGroupBox") || controlType == wxT("wxStaticBox"))
+ {
if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
- controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
- }
- }
- }
-#endif
- else
- {
- delete controlItem;
- return NULL;
- }
- return controlItem;
-}
-
-// Forward declaration
-wxItemResource *wxResourceInterpretMenu1(wxResourceTable& table, PrologExpr *expr);
+ controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
+ }
+ else if (controlType == wxT("wxGauge"))
+ {
+ // Check for default value
+ if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
+ {
+ controlItem->SetValue1(expr->Nth(count)->IntegerValue());
+ count ++;
+
+ // Check for range
+ if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
+ {
+ controlItem->SetValue2(expr->Nth(count)->IntegerValue());
+ count ++;
+
+ if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
+ {
+ // Skip past the obsolete label font spec if there are two consecutive specs
+ if (expr->Nth(count+1) && expr->Nth(count+1)->Type() == PrologList)
+ count ++;
+ controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
+ }
+ }
+ }
+ }
+ else if (controlType == wxT("wxSlider"))
+ {
+ // Check for default value
+ if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
+ {
+ controlItem->SetValue1(expr->Nth(count)->IntegerValue());
+ count ++;
+
+ // Check for min
+ if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
+ {
+ controlItem->SetValue2(expr->Nth(count)->IntegerValue());
+ count ++;
+
+ // Check for max
+ if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
+ {
+ controlItem->SetValue3(expr->Nth(count)->IntegerValue());
+ count ++;
+
+ if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
+ {
+ // controlItem->SetLabelFont(wxResourceInterpretFontSpec(expr->Nth(count)));
+ // do nothing
+ count ++;
+
+ if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
+ controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
+ }
+ }
+ }
+ }
+ }
+ else if (controlType == wxT("wxScrollBar"))
+ {
+ // DEFAULT VALUE
+ if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
+ {
+ controlItem->SetValue1(expr->Nth(count)->IntegerValue());
+ count ++;
+
+ // PAGE LENGTH
+ if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
+ {
+ controlItem->SetValue2(expr->Nth(count)->IntegerValue());
+ count ++;
+
+ // OBJECT LENGTH
+ if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
+ {
+ controlItem->SetValue3(expr->Nth(count)->IntegerValue());
+ count ++;
+
+ // VIEW LENGTH
+ if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
+ controlItem->SetValue5(expr->Nth(count)->IntegerValue());
+ }
+ }
+ }
+ }
+ else if (controlType == wxT("wxListBox"))
+ {
+ wxExpr *valueList = (wxExpr *) NULL;
-/*
- * Interpet a menu item
- */
+ if (((valueList = expr->Nth(count)) != 0) && (valueList->Type() == PrologList))
+ {
+ wxStringList stringList;
+ wxExpr *stringExpr = valueList->GetFirst();
+ while (stringExpr)
+ {
+ stringList.Add(stringExpr->StringValue());
+ stringExpr = stringExpr->GetNext();
+ }
+ controlItem->SetStringValues(stringList);
+ count ++;
+ // This is now obsolete: it's in the window style.
+ // Check for wxSINGLE/wxMULTIPLE
+ wxExpr *mult = (wxExpr *) NULL;
+ /*
+ controlItem->SetValue1(wxLB_SINGLE);
+ */
+ if (((mult = expr->Nth(count)) != 0) && ((mult->Type() == PrologString)||(mult->Type() == PrologWord)))
+ {
+ /*
+ wxString m(mult->StringValue());
+ if (m == "wxLB_MULTIPLE")
+ controlItem->SetValue1(wxLB_MULTIPLE);
+ else if (m == "wxLB_EXTENDED")
+ controlItem->SetValue1(wxLB_EXTENDED);
+ */
+ // Ignore the value
+ count ++;
+ }
+ if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
+ {
+ // Skip past the obsolete label font spec if there are two consecutive specs
+ if (expr->Nth(count+1) && expr->Nth(count+1)->Type() == PrologList)
+ count ++;
+ controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
+ }
+ }
+ }
+ else if (controlType == wxT("wxChoice"))
+ {
+ wxExpr *valueList = (wxExpr *) NULL;
+ // Check for default value list
+ if (((valueList = expr->Nth(count)) != 0) && (valueList->Type() == PrologList))
+ {
+ wxStringList stringList;
+ wxExpr *stringExpr = valueList->GetFirst();
+ while (stringExpr)
+ {
+ stringList.Add(stringExpr->StringValue());
+ stringExpr = stringExpr->GetNext();
+ }
+ controlItem->SetStringValues(stringList);
-wxItemResource *wxResourceInterpretMenuItem(wxResourceTable& table, PrologExpr *expr)
-{
- wxItemResource *item = new wxItemResource;
-
- PrologExpr *labelExpr = expr->Nth(0);
- PrologExpr *idExpr = expr->Nth(1);
- PrologExpr *helpExpr = expr->Nth(2);
- PrologExpr *checkableExpr = expr->Nth(3);
+ count ++;
- // Further keywords/attributes to follow sometime...
- if (expr->Number() == 0)
- {
-// item->SetType(wxRESOURCE_TYPE_SEPARATOR);
- item->SetType("wxMenuSeparator");
- return item;
- }
- else
- {
-// item->SetType(wxTYPE_MENU); // Well, menu item, but doesn't matter.
- item->SetType("wxMenu"); // Well, menu item, but doesn't matter.
- if (labelExpr)
+ if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
+ {
+ // Skip past the obsolete label font spec if there are two consecutive specs
+ if (expr->Nth(count+1) && expr->Nth(count+1)->Type() == PrologList)
+ count ++;
+ controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
+ }
+ }
+ }
+#if wxUSE_COMBOBOX
+ else if (controlType == wxT("wxComboBox"))
{
- item->SetTitle(WXSTRINGCAST labelExpr->StringValue());
+ wxExpr *textValue = expr->Nth(count);
+ if (textValue && (textValue->Type() == PrologString || textValue->Type() == PrologWord))
+ {
+ wxString str(textValue->StringValue());
+ controlItem->SetValue4(str);
+
+ count ++;
+
+ wxExpr *valueList = (wxExpr *) NULL;
+ // Check for default value list
+ if (((valueList = expr->Nth(count)) != 0) && (valueList->Type() == PrologList))
+ {
+ wxStringList stringList;
+ wxExpr *stringExpr = valueList->GetFirst();
+ while (stringExpr)
+ {
+ stringList.Add(stringExpr->StringValue());
+ stringExpr = stringExpr->GetNext();
+ }
+ controlItem->SetStringValues(stringList);
+
+ count ++;
+
+ if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
+ {
+ // Skip past the obsolete label font spec if there are two consecutive specs
+ if (expr->Nth(count+1) && expr->Nth(count+1)->Type() == PrologList)
+ count ++;
+ controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
+ }
+ }
+ }
}
- if (idExpr)
+#endif
+#if 1
+ else if (controlType == wxT("wxRadioBox"))
{
- int id = 0;
- // If a string or word, must look up in identifier table.
- if ((idExpr->Type() == PrologString) || (idExpr->Type() == PrologWord))
- {
- id = wxResourceGetIdentifier(WXSTRINGCAST idExpr->StringValue(), &table);
- if (id == 0)
+ wxExpr *valueList = (wxExpr *) NULL;
+ // Check for default value list
+ if (((valueList = expr->Nth(count)) != 0) && (valueList->Type() == PrologList))
{
- char buf[300];
- sprintf(buf, "Could not resolve menu id '%s'. Use (non-zero) integer instead\n or provide #define (see manual for caveats)",
- (const char*) idExpr->StringValue());
- wxWarning(buf);
+ wxStringList stringList;
+ wxExpr *stringExpr = valueList->GetFirst();
+ while (stringExpr)
+ {
+ stringList.Add(stringExpr->StringValue());
+ stringExpr = stringExpr->GetNext();
+ }
+ controlItem->SetStringValues(stringList);
+ count ++;
+
+ // majorDim (number of rows or cols)
+ if (expr->Nth(count) && (expr->Nth(count)->Type() == PrologInteger))
+ {
+ controlItem->SetValue1(expr->Nth(count)->IntegerValue());
+ count ++;
+ }
+ else
+ controlItem->SetValue1(0);
+
+ if (expr->Nth(count) && expr->Nth(count)->Type() == PrologList)
+ {
+ // Skip past the obsolete label font spec if there are two consecutive specs
+ if (expr->Nth(count+1) && expr->Nth(count+1)->Type() == PrologList)
+ count ++;
+ controlItem->SetFont(wxResourceInterpretFontSpec(expr->Nth(count)));
+ }
}
- }
- else if (idExpr->Type() == PrologInteger)
- id = (int)idExpr->IntegerValue();
- item->SetValue1(id);
}
- if (helpExpr)
+#endif
+ else
{
- item->SetValue4(WXSTRINGCAST helpExpr->StringValue());
+ delete controlItem;
+ return (wxItemResource *) NULL;
}
- if (checkableExpr)
- item->SetValue2(checkableExpr->IntegerValue());
+ return controlItem;
+}
+
+// Forward declaration
+wxItemResource *wxResourceInterpretMenu1(wxResourceTable& table, wxExpr *expr);
+
+/*
+* Interpet a menu item
+*/
+
+wxItemResource *wxResourceInterpretMenuItem(wxResourceTable& table, wxExpr *expr)
+{
+ wxItemResource *item = new wxItemResource;
+
+ wxExpr *labelExpr = expr->Nth(0);
+ wxExpr *idExpr = expr->Nth(1);
+ wxExpr *helpExpr = expr->Nth(2);
+ wxExpr *checkableExpr = expr->Nth(3);
- // Find the first expression that's a list, for submenu
- PrologExpr *subMenuExpr = expr->GetFirst();
- while (subMenuExpr && (subMenuExpr->Type() != PrologList))
- subMenuExpr = subMenuExpr->GetNext();
-
- while (subMenuExpr)
+ // Further keywords/attributes to follow sometime...
+ if (expr->Number() == 0)
{
- wxItemResource *child = wxResourceInterpretMenuItem(table, subMenuExpr);
- item->GetChildren().Append(child);
- subMenuExpr = subMenuExpr->GetNext();
+ // item->SetType(wxRESOURCE_TYPE_SEPARATOR);
+ item->SetType(wxT("wxMenuSeparator"));
+ return item;
}
- }
- return item;
+ else
+ {
+ // item->SetType(wxTYPE_MENU); // Well, menu item, but doesn't matter.
+ item->SetType(wxT("wxMenu")); // Well, menu item, but doesn't matter.
+ if (labelExpr)
+ {
+ wxString str(labelExpr->StringValue());
+ item->SetTitle(str);
+ }
+ if (idExpr)
+ {
+ int id = 0;
+ // If a string or word, must look up in identifier table.
+ if ((idExpr->Type() == PrologString) || (idExpr->Type() == PrologWord))
+ {
+ wxString str(idExpr->StringValue());
+ id = wxResourceGetIdentifier(str, &table);
+ if (id == 0)
+ {
+ wxLogWarning(_("Could not resolve menu id '%s'. Use (non-zero) integer instead\nor provide #define (see manual for caveats)"),
+ (const wxChar*) idExpr->StringValue());
+ }
+ }
+ else if (idExpr->Type() == PrologInteger)
+ id = (int)idExpr->IntegerValue();
+ item->SetValue1(id);
+ }
+ if (helpExpr)
+ {
+ wxString str(helpExpr->StringValue());
+ item->SetValue4(str);
+ }
+ if (checkableExpr)
+ item->SetValue2(checkableExpr->IntegerValue());
+
+ // Find the first expression that's a list, for submenu
+ wxExpr *subMenuExpr = expr->GetFirst();
+ while (subMenuExpr && (subMenuExpr->Type() != PrologList))
+ subMenuExpr = subMenuExpr->GetNext();
+
+ while (subMenuExpr)
+ {
+ wxItemResource *child = wxResourceInterpretMenuItem(table, subMenuExpr);
+ item->GetChildren().Append(child);
+ subMenuExpr = subMenuExpr->GetNext();
+ }
+ }
+ return item;
}
/*
- * Interpret a nested list as a menu
- */
+* Interpret a nested list as a menu
+*/
/*
-wxItemResource *wxResourceInterpretMenu1(wxResourceTable& table, PrologExpr *expr)
+wxItemResource *wxResourceInterpretMenu1(wxResourceTable& table, wxExpr *expr)
{
- wxItemResource *menu = new wxItemResource;
+wxItemResource *menu = new wxItemResource;
// menu->SetType(wxTYPE_MENU);
- menu->SetType("wxMenu");
- PrologExpr *element = expr->GetFirst();
- while (element)
- {
- wxItemResource *item = wxResourceInterpretMenuItem(table, element);
- if (item)
- menu->GetChildren().Append(item);
- element = element->GetNext();
- }
- return menu;
+menu->SetType("wxMenu");
+wxExpr *element = expr->GetFirst();
+while (element)
+{
+wxItemResource *item = wxResourceInterpretMenuItem(table, element);
+if (item)
+menu->GetChildren().Append(item);
+element = element->GetNext();
+}
+return menu;
}
*/
-wxItemResource *wxResourceInterpretMenu(wxResourceTable& table, PrologExpr *expr)
-{
- PrologExpr *listExpr = NULL;
- expr->AssignAttributeValue("menu", &listExpr);
- if (!listExpr)
- return NULL;
-
- wxItemResource *menuResource = wxResourceInterpretMenuItem(table, listExpr);
-
- if (!menuResource)
- return NULL;
-
- char *name = NULL;
- expr->AssignAttributeValue("name", &name);
- if (name)
- {
- menuResource->SetName(name);
- delete[] name;
- }
-
- return menuResource;
+wxItemResource *wxResourceInterpretMenu(wxResourceTable& table, wxExpr *expr)
+{
+ wxExpr *listExpr = (wxExpr *) NULL;
+ expr->GetAttributeValue(wxT("menu"), &listExpr);
+ if (!listExpr)
+ return (wxItemResource *) NULL;
+
+ wxItemResource *menuResource = wxResourceInterpretMenuItem(table, listExpr);
+
+ if (!menuResource)
+ return (wxItemResource *) NULL;
+
+ wxString name;
+ if (expr->GetAttributeValue(wxT("name"), name))
+ {
+ menuResource->SetName(name);
+ }
+
+ return menuResource;
}
-wxItemResource *wxResourceInterpretMenuBar(wxResourceTable& table, PrologExpr *expr)
+wxItemResource *wxResourceInterpretMenuBar(wxResourceTable& table, wxExpr *expr)
{
- PrologExpr *listExpr = NULL;
- expr->AssignAttributeValue("menu", &listExpr);
- if (!listExpr)
- return NULL;
+ wxExpr *listExpr = (wxExpr *) NULL;
+ expr->GetAttributeValue(wxT("menu"), &listExpr);
+ if (!listExpr)
+ return (wxItemResource *) NULL;
- wxItemResource *resource = new wxItemResource;
- resource->SetType("wxMenu");
-// resource->SetType(wxTYPE_MENU);
-
- PrologExpr *element = listExpr->GetFirst();
- while (element)
- {
- wxItemResource *menuResource = wxResourceInterpretMenuItem(table, listExpr);
- resource->GetChildren().Append(menuResource);
- element = element->GetNext();
- }
+ wxItemResource *resource = new wxItemResource;
+ resource->SetType(wxT("wxMenu"));
+ // resource->SetType(wxTYPE_MENU);
- char *name = NULL;
- expr->AssignAttributeValue("name", &name);
- if (name)
- {
- resource->SetName(name);
- delete[] name;
- }
-
- return resource;
+ wxExpr *element = listExpr->GetFirst();
+ while (element)
+ {
+ wxItemResource *menuResource = wxResourceInterpretMenuItem(table, listExpr);
+ resource->GetChildren().Append(menuResource);
+ element = element->GetNext();
+ }
+
+ wxString name;
+ if (expr->GetAttributeValue(wxT("name"), name))
+ {
+ resource->SetName(name);
+ }
+
+ return resource;
}
-wxItemResource *wxResourceInterpretString(wxResourceTable& WXUNUSED(table), PrologExpr *WXUNUSED(expr))
+wxItemResource *wxResourceInterpretString(wxResourceTable& WXUNUSED(table), wxExpr *WXUNUSED(expr))
{
- return NULL;
+ return (wxItemResource *) NULL;
}
-wxItemResource *wxResourceInterpretBitmap(wxResourceTable& WXUNUSED(table), PrologExpr *expr)
+wxItemResource *wxResourceInterpretBitmap(wxResourceTable& WXUNUSED(table), wxExpr *expr)
{
- wxItemResource *bitmapItem = new wxItemResource;
-// bitmapItem->SetType(wxTYPE_BITMAP);
- bitmapItem->SetType("wxBitmap");
- char *name = NULL;
- expr->AssignAttributeValue("name", &name);
- if (name)
- {
- bitmapItem->SetName(name);
- delete[] name;
- }
- // Now parse all bitmap specifications
- PrologExpr *bitmapExpr = expr->GetFirst();
- while (bitmapExpr)
- {
- if (bitmapExpr->Number() == 3)
- {
- wxString bitmapKeyword(bitmapExpr->Nth(1)->StringValue());
- if (bitmapKeyword == "bitmap" || bitmapKeyword == "icon")
- {
- // The value part: always a list.
- PrologExpr *listExpr = bitmapExpr->Nth(2);
- if (listExpr->Type() == PrologList)
+ wxItemResource *bitmapItem = new wxItemResource;
+ // bitmapItem->SetType(wxTYPE_BITMAP);
+ bitmapItem->SetType(wxT("wxBitmap"));
+ wxString name;
+ if (expr->GetAttributeValue(wxT("name"), name))
+ {
+ bitmapItem->SetName(name);
+ }
+ // Now parse all bitmap specifications
+ wxExpr *bitmapExpr = expr->GetFirst();
+ while (bitmapExpr)
+ {
+ if (bitmapExpr->Number() == 3)
{
- wxItemResource *bitmapSpec = new wxItemResource;
-// bitmapSpec->SetType(wxTYPE_BITMAP);
- bitmapSpec->SetType("wxBitmap");
-
- // List is of form: [filename, bitmaptype, platform, colours, xresolution, yresolution]
- // where everything after 'filename' is optional.
- PrologExpr *nameExpr = listExpr->Nth(0);
- PrologExpr *typeExpr = listExpr->Nth(1);
- PrologExpr *platformExpr = listExpr->Nth(2);
- PrologExpr *coloursExpr = listExpr->Nth(3);
- PrologExpr *xresExpr = listExpr->Nth(4);
- PrologExpr *yresExpr = listExpr->Nth(5);
- if (nameExpr && nameExpr->StringValue())
- bitmapSpec->SetName(WXSTRINGCAST nameExpr->StringValue());
- if (typeExpr && typeExpr->StringValue())
- bitmapSpec->SetValue1(wxParseWindowStyle(WXSTRINGCAST typeExpr->StringValue()));
- else
- bitmapSpec->SetValue1(0);
-
- if (platformExpr && platformExpr->StringValue())
- {
- wxString plat(platformExpr->StringValue());
- if (plat == "windows" || plat == "WINDOWS")
- bitmapSpec->SetValue2(RESOURCE_PLATFORM_WINDOWS);
- else if (plat == "x" || plat == "X")
- bitmapSpec->SetValue2(RESOURCE_PLATFORM_X);
- else if (plat == "mac" || plat == "MAC")
- bitmapSpec->SetValue2(RESOURCE_PLATFORM_MAC);
- else
- bitmapSpec->SetValue2(RESOURCE_PLATFORM_ANY);
- }
- else
- bitmapSpec->SetValue2(RESOURCE_PLATFORM_ANY);
-
- if (coloursExpr)
- bitmapSpec->SetValue3(coloursExpr->IntegerValue());
- int xres = 0;
- int yres = 0;
- if (xresExpr)
- xres = (int)xresExpr->IntegerValue();
- if (yresExpr)
- yres = (int)yresExpr->IntegerValue();
- bitmapSpec->SetSize(0, 0, xres, yres);
-
- bitmapItem->GetChildren().Append(bitmapSpec);
+ wxString bitmapKeyword(bitmapExpr->Nth(1)->StringValue());
+ if (bitmapKeyword == wxT("bitmap") || bitmapKeyword == wxT("icon"))
+ {
+ // The value part: always a list.
+ wxExpr *listExpr = bitmapExpr->Nth(2);
+ if (listExpr->Type() == PrologList)
+ {
+ wxItemResource *bitmapSpec = new wxItemResource;
+ // bitmapSpec->SetType(wxTYPE_BITMAP);
+ bitmapSpec->SetType(wxT("wxBitmap"));
+
+ // List is of form: [filename, bitmaptype, platform, colours, xresolution, yresolution]
+ // where everything after 'filename' is optional.
+ wxExpr *nameExpr = listExpr->Nth(0);
+ wxExpr *typeExpr = listExpr->Nth(1);
+ wxExpr *platformExpr = listExpr->Nth(2);
+ wxExpr *coloursExpr = listExpr->Nth(3);
+ wxExpr *xresExpr = listExpr->Nth(4);
+ wxExpr *yresExpr = listExpr->Nth(5);
+ if (nameExpr && nameExpr->StringValue() != wxT(""))
+ {
+ bitmapSpec->SetName(nameExpr->StringValue());
+ }
+ if (typeExpr && typeExpr->StringValue() != wxT(""))
+ {
+ bitmapSpec->SetValue1(wxParseWindowStyle(typeExpr->StringValue()));
+ }
+ else
+ bitmapSpec->SetValue1(0);
+
+ if (platformExpr && platformExpr->StringValue() != wxT(""))
+ {
+ wxString plat(platformExpr->StringValue());
+ if (plat == wxT("windows") || plat == wxT("WINDOWS"))
+ bitmapSpec->SetValue2(RESOURCE_PLATFORM_WINDOWS);
+ else if (plat == wxT("x") || plat == wxT("X"))
+ bitmapSpec->SetValue2(RESOURCE_PLATFORM_X);
+ else if (plat == wxT("mac") || plat == wxT("MAC"))
+ bitmapSpec->SetValue2(RESOURCE_PLATFORM_MAC);
+ else
+ bitmapSpec->SetValue2(RESOURCE_PLATFORM_ANY);
+ }
+ else
+ bitmapSpec->SetValue2(RESOURCE_PLATFORM_ANY);
+
+ if (coloursExpr)
+ bitmapSpec->SetValue3(coloursExpr->IntegerValue());
+ int xres = 0;
+ int yres = 0;
+ if (xresExpr)
+ xres = (int)xresExpr->IntegerValue();
+ if (yresExpr)
+ yres = (int)yresExpr->IntegerValue();
+ bitmapSpec->SetSize(0, 0, xres, yres);
+
+ bitmapItem->GetChildren().Append(bitmapSpec);
+ }
+ }
}
- }
+ bitmapExpr = bitmapExpr->GetNext();
}
- bitmapExpr = bitmapExpr->GetNext();
- }
-
- return bitmapItem;
+
+ return bitmapItem;
}
-wxItemResource *wxResourceInterpretIcon(wxResourceTable& table, PrologExpr *expr)
+wxItemResource *wxResourceInterpretIcon(wxResourceTable& table, wxExpr *expr)
{
- wxItemResource *item = wxResourceInterpretBitmap(table, expr);
- if (item)
- {
-// item->SetType(wxTYPE_ICON);
- item->SetType("wxIcon");
- return item;
- }
- else
- return NULL;
+ wxItemResource *item = wxResourceInterpretBitmap(table, expr);
+ if (item)
+ {
+ // item->SetType(wxTYPE_ICON);
+ item->SetType(wxT("wxIcon"));
+ return item;
+ }
+ else
+ return (wxItemResource *) NULL;
}
// Interpret list expression as a font
-wxFont *wxResourceInterpretFontSpec(PrologExpr *expr)
-{
- if (expr->Type() != PrologList)
- return NULL;
-
- int point = 10;
- int family = wxSWISS;
- int style = wxNORMAL;
- int weight = wxNORMAL;
- int underline = 0;
- wxString faceName("");
-
- PrologExpr *pointExpr = expr->Nth(0);
- PrologExpr *familyExpr = expr->Nth(1);
- PrologExpr *styleExpr = expr->Nth(2);
- PrologExpr *weightExpr = expr->Nth(3);
- PrologExpr *underlineExpr = expr->Nth(4);
- PrologExpr *faceNameExpr = expr->Nth(5);
- if (pointExpr)
- point = (int)pointExpr->IntegerValue();
- if (familyExpr)
- family = (int)wxParseWindowStyle(WXSTRINGCAST familyExpr->StringValue());
- if (styleExpr)
- style = (int)wxParseWindowStyle(WXSTRINGCAST styleExpr->StringValue());
- if (weightExpr)
- weight = (int)wxParseWindowStyle(WXSTRINGCAST weightExpr->StringValue());
- if (underlineExpr)
- underline = (int)underlineExpr->IntegerValue();
- if (faceNameExpr)
- faceName = faceNameExpr->StringValue();
-
- char *faceName1 = NULL;
- if (faceName != "")
- faceName1 = WXSTRINGCAST faceName;
- wxFont *font = wxTheFontList->FindOrCreateFont(point, family, style, weight, (underline != 0), faceName1);
- return font;
+wxFont wxResourceInterpretFontSpec(wxExpr *expr)
+{
+ if (expr->Type() != PrologList)
+ return wxNullFont;
+
+ int point = 10;
+ int family = wxSWISS;
+ int style = wxNORMAL;
+ int weight = wxNORMAL;
+ int underline = 0;
+ wxString faceName(wxT(""));
+
+ wxExpr *pointExpr = expr->Nth(0);
+ wxExpr *familyExpr = expr->Nth(1);
+ wxExpr *styleExpr = expr->Nth(2);
+ wxExpr *weightExpr = expr->Nth(3);
+ wxExpr *underlineExpr = expr->Nth(4);
+ wxExpr *faceNameExpr = expr->Nth(5);
+ if (pointExpr)
+ point = (int)pointExpr->IntegerValue();
+
+ wxString str;
+ if (familyExpr)
+ {
+ str = familyExpr->StringValue();
+ family = (int)wxParseWindowStyle(str);
+ }
+ if (styleExpr)
+ {
+ str = styleExpr->StringValue();
+ style = (int)wxParseWindowStyle(str);
+ }
+ if (weightExpr)
+ {
+ str = weightExpr->StringValue();
+ weight = (int)wxParseWindowStyle(str);
+ }
+ if (underlineExpr)
+ underline = (int)underlineExpr->IntegerValue();
+ if (faceNameExpr)
+ faceName = faceNameExpr->StringValue();
+
+ wxFont font(point, family, style, weight, (underline != 0), faceName);
+ return font;
}
+// Separate file for the remainder of this, for BC++/Win16
+
+#if !((defined(__BORLANDC__) || defined(__SC__)) && defined(__WIN16__))
/*
- * (Re)allocate buffer for reading in from resource file
- */
+* (Re)allocate buffer for reading in from resource file
+*/
-bool wxReallocateResourceBuffer(void)
+bool wxReallocateResourceBuffer()
{
- if (!wxResourceBuffer)
- {
- wxResourceBufferSize = 1000;
- wxResourceBuffer = new char[wxResourceBufferSize];
+ if (!wxResourceBuffer)
+ {
+ wxResourceBufferSize = 1000;
+ wxResourceBuffer = new char[wxResourceBufferSize];
+ return TRUE;
+ }
+ if (wxResourceBuffer)
+ {
+ long newSize = wxResourceBufferSize + 1000;
+ char *tmp = new char[(int)newSize];
+ strncpy(tmp, wxResourceBuffer, (int)wxResourceBufferCount);
+ delete[] wxResourceBuffer;
+ wxResourceBuffer = tmp;
+ wxResourceBufferSize = newSize;
+ }
return TRUE;
- }
- if (wxResourceBuffer)
- {
- long newSize = wxResourceBufferSize + 1000;
- char *tmp = new char[(int)newSize];
- strncpy(tmp, wxResourceBuffer, (int)wxResourceBufferCount);
- delete[] wxResourceBuffer;
- wxResourceBuffer = tmp;
- wxResourceBufferSize = newSize;
- }
- return TRUE;
}
static bool wxEatWhiteSpace(FILE *fd)
{
- int ch = getc(fd);
- if ((ch != ' ') && (ch != '/') && (ch != ' ') && (ch != 10) && (ch != 13) && (ch != 9))
- {
- ungetc(ch, fd);
- return TRUE;
- }
+ int ch = 0;
- // Eat whitespace
- while (ch == ' ' || ch == 10 || ch == 13 || ch == 9)
- ch = getc(fd);
- // Check for comment
- if (ch == '/')
- {
- ch = getc(fd);
- if (ch == '*')
+ while ((ch = getc(fd)) != EOF)
{
- bool finished = FALSE;
- while (!finished)
- {
- ch = getc(fd);
- if (ch == EOF)
- return FALSE;
+ switch (ch)
+ {
+ case ' ':
+ case 0x0a:
+ case 0x0d:
+ case 0x09:
+ break;
+ case '/':
+ {
+ int prev_ch = ch;
+ ch = getc(fd);
+ if (ch == EOF)
+ {
+ ungetc(prev_ch, fd);
+ return TRUE;
+ }
+
+ if (ch == '*')
+ {
+ // Eat C comment
+ prev_ch = 0;
+ while ((ch = getc(fd)) != EOF)
+ {
+ if (ch == '/' && prev_ch == '*')
+ break;
+ prev_ch = ch;
+ }
+ }
+ else if (ch == '/')
+ {
+ // Eat C++ comment
+ static char buffer[255];
+ fgets(buffer, 255, fd);
+ }
+ else
+ {
+ ungetc(prev_ch, fd);
+ ungetc(ch, fd);
+ return TRUE;
+ }
+ }
+ break;
+ default:
+ ungetc(ch, fd);
+ return TRUE;
+
+ }
+ }
+ return FALSE;
+}
+static bool wxEatWhiteSpace(wxInputStream *is)
+{
+ int ch = is->GetC() ;
+ if ((ch != ' ') && (ch != '/') && (ch != ' ') && (ch != 10) && (ch != 13) && (ch != 9))
+ {
+ is->Ungetch(ch);
+ return TRUE;
+ }
+
+ // Eat whitespace
+ while (ch == ' ' || ch == 10 || ch == 13 || ch == 9)
+ ch = is->GetC();
+ // Check for comment
+ if (ch == '/')
+ {
+ ch = is->GetC();
if (ch == '*')
{
- int newCh = getc(fd);
- if (newCh == '/')
- finished = TRUE;
- else
- {
- ungetc(newCh, fd);
- }
+ bool finished = FALSE;
+ while (!finished)
+ {
+ ch = is->GetC();
+ if (ch == EOF)
+ return FALSE;
+ if (ch == '*')
+ {
+ int newCh = is->GetC();
+ if (newCh == '/')
+ finished = TRUE;
+ else
+ {
+ is->Ungetch(ch);
+ }
+ }
+ }
}
- }
+ else // False alarm
+ return FALSE;
}
- else // False alarm
- return FALSE;
- }
- else
- ungetc(ch, fd);
- return wxEatWhiteSpace(fd);
+ else
+ is->Ungetch(ch);
+ return wxEatWhiteSpace(is);
}
bool wxGetResourceToken(FILE *fd)
{
- if (!wxResourceBuffer)
- wxReallocateResourceBuffer();
- wxResourceBuffer[0] = 0;
- wxEatWhiteSpace(fd);
+ if (!wxResourceBuffer)
+ wxReallocateResourceBuffer();
+ wxResourceBuffer[0] = 0;
+ wxEatWhiteSpace(fd);
- int ch = getc(fd);
- if (ch == '"')
- {
- // Get string
- wxResourceBufferCount = 0;
- ch = getc(fd);
- while (ch != '"')
- {
- int actualCh = ch;
- if (ch == EOF)
- {
+ int ch = getc(fd);
+ if (ch == '"')
+ {
+ // Get string
+ wxResourceBufferCount = 0;
+ ch = getc(fd);
+ while (ch != '"')
+ {
+ int actualCh = ch;
+ if (ch == EOF)
+ {
+ wxResourceBuffer[wxResourceBufferCount] = 0;
+ return FALSE;
+ }
+ // Escaped characters
+ else if (ch == '\\')
+ {
+ int newCh = getc(fd);
+ if (newCh == '"')
+ actualCh = '"';
+ else if (newCh == 10)
+ actualCh = 10;
+ else
+ {
+ ungetc(newCh, fd);
+ }
+ }
+
+ if (wxResourceBufferCount >= wxResourceBufferSize-1)
+ wxReallocateResourceBuffer();
+ wxResourceBuffer[wxResourceBufferCount] = (char)actualCh;
+ wxResourceBufferCount ++;
+ ch = getc(fd);
+ }
wxResourceBuffer[wxResourceBufferCount] = 0;
- return FALSE;
- }
- // Escaped characters
- else if (ch == '\\')
- {
- int newCh = getc(fd);
- if (newCh == '"')
- actualCh = '"';
- else if (newCh == 10)
- actualCh = 10;
- else
+ }
+ else
+ {
+ wxResourceBufferCount = 0;
+ // Any other token
+ while (ch != ' ' && ch != EOF && ch != ' ' && ch != 13 && ch != 9 && ch != 10)
{
- ungetc(newCh, fd);
+ if (wxResourceBufferCount >= wxResourceBufferSize-1)
+ wxReallocateResourceBuffer();
+ wxResourceBuffer[wxResourceBufferCount] = (char)ch;
+ wxResourceBufferCount ++;
+
+ ch = getc(fd);
}
- }
+ wxResourceBuffer[wxResourceBufferCount] = 0;
+ if (ch == EOF)
+ return FALSE;
+ }
+ return TRUE;
+}
- if (wxResourceBufferCount >= wxResourceBufferSize-1)
+bool wxGetResourceToken(wxInputStream *is)
+{
+ if (!wxResourceBuffer)
wxReallocateResourceBuffer();
- wxResourceBuffer[wxResourceBufferCount] = (char)actualCh;
- wxResourceBufferCount ++;
- ch = getc(fd);
+ wxResourceBuffer[0] = 0;
+ wxEatWhiteSpace(is);
+
+ int ch = is->GetC() ;
+ if (ch == '"')
+ {
+ // Get string
+ wxResourceBufferCount = 0;
+ ch = is->GetC();
+ while (ch != '"')
+ {
+ int actualCh = ch;
+ if (ch == EOF)
+ {
+ wxResourceBuffer[wxResourceBufferCount] = 0;
+ return FALSE;
+ }
+ // Escaped characters
+ else if (ch == '\\')
+ {
+ int newCh = is->GetC();
+ if (newCh == '"')
+ actualCh = '"';
+ else if (newCh == 10)
+ actualCh = 10;
+ else if (newCh == 13) // mac
+ actualCh = 10;
+ else
+ {
+ is->Ungetch(newCh);
+ }
+ }
+
+ if (wxResourceBufferCount >= wxResourceBufferSize-1)
+ wxReallocateResourceBuffer();
+ wxResourceBuffer[wxResourceBufferCount] = (char)actualCh;
+ wxResourceBufferCount ++;
+ ch = is->GetC();
+ }
+ wxResourceBuffer[wxResourceBufferCount] = 0;
}
- wxResourceBuffer[wxResourceBufferCount] = 0;
- }
- else
- {
- wxResourceBufferCount = 0;
- // Any other token
- while (ch != ' ' && ch != EOF && ch != ' ' && ch != 13 && ch != 9 && ch != 10)
+ else
{
- if (wxResourceBufferCount >= wxResourceBufferSize-1)
- wxReallocateResourceBuffer();
- wxResourceBuffer[wxResourceBufferCount] = (char)ch;
- wxResourceBufferCount ++;
-
- ch = getc(fd);
- }
- wxResourceBuffer[wxResourceBufferCount] = 0;
- if (ch == EOF)
- return FALSE;
- }
- return TRUE;
+ wxResourceBufferCount = 0;
+ // Any other token
+ while (ch != ' ' && ch != EOF && ch != ' ' && ch != 13 && ch != 9 && ch != 10)
+ {
+ if (wxResourceBufferCount >= wxResourceBufferSize-1)
+ wxReallocateResourceBuffer();
+ wxResourceBuffer[wxResourceBufferCount] = (char)ch;
+ wxResourceBufferCount ++;
+
+ ch = is->GetC();
+ }
+ wxResourceBuffer[wxResourceBufferCount] = 0;
+ if (ch == EOF)
+ return FALSE;
+ }
+ return TRUE;
}
/*
- * Files are in form:
- static char *name = "....";
- with possible comments.
- */
-
-bool wxResourceReadOneResource(FILE *fd, PrologDatabase& db, bool *eof, wxResourceTable *table)
-{
- if (!table)
- table = wxDefaultResourceTable;
-
- // static or #define
- if (!wxGetResourceToken(fd))
- {
- *eof = TRUE;
- return FALSE;
- }
+* Files are in form:
+static char *name = "....";
+with possible comments.
+*/
- if (strcmp(wxResourceBuffer, "#define") == 0)
- {
- wxGetResourceToken(fd);
- char *name = copystring(wxResourceBuffer);
- wxGetResourceToken(fd);
- char *value = copystring(wxResourceBuffer);
- if (isalpha(value[0]))
+bool wxResourceReadOneResource(FILE *fd, wxExprDatabase& db, bool *eof, wxResourceTable *table)
+{
+ if (!table)
+ table = wxDefaultResourceTable;
+
+ // static or #define
+ if (!wxGetResourceToken(fd))
{
- int val = (int)atol(value);
- wxResourceAddIdentifier(name, val, table);
+ *eof = TRUE;
+ return FALSE;
+ }
+
+ if (strcmp(wxResourceBuffer, "#define") == 0)
+ {
+ wxGetResourceToken(fd);
+ wxChar *name = copystring(wxConvCurrent->cMB2WX(wxResourceBuffer));
+ wxGetResourceToken(fd);
+ wxChar *value = copystring(wxConvCurrent->cMB2WX(wxResourceBuffer));
+ if (wxIsdigit(value[0]))
+ {
+ int val = (int)wxAtol(value);
+ wxResourceAddIdentifier(name, val, table);
+ }
+ else
+ {
+ wxLogWarning(_("#define %s must be an integer."), name);
+ delete[] name;
+ delete[] value;
+ return FALSE;
+ }
+ delete[] name;
+ delete[] value;
+
+ return TRUE;
+ }
+ else if (strcmp(wxResourceBuffer, "#include") == 0)
+ {
+ wxGetResourceToken(fd);
+ wxChar *name = copystring(wxConvCurrent->cMB2WX(wxResourceBuffer));
+ wxChar *actualName = name;
+ if (name[0] == wxT('"'))
+ actualName = name + 1;
+ int len = wxStrlen(name);
+ if ((len > 0) && (name[len-1] == wxT('"')))
+ name[len-1] = 0;
+ if (!wxResourceParseIncludeFile(actualName, table))
+ {
+ wxLogWarning(_("Could not find resource include file %s."), actualName);
+ }
+ delete[] name;
+ return TRUE;
+ }
+ else if (strcmp(wxResourceBuffer, "static") != 0)
+ {
+ wxChar buf[300];
+ wxStrcpy(buf, _("Found "));
+ wxStrncat(buf, wxConvCurrent->cMB2WX(wxResourceBuffer), 30);
+ wxStrcat(buf, _(", expected static, #include or #define\nwhilst parsing resource."));
+ wxLogWarning(buf);
+ return FALSE;
+ }
+
+ // char
+ if (!wxGetResourceToken(fd))
+ {
+ wxLogWarning(_("Unexpected end of file whilst parsing resource."));
+ *eof = TRUE;
+ return FALSE;
+ }
+
+ if (strcmp(wxResourceBuffer, "char") != 0)
+ {
+ wxLogWarning(_("Expected 'char' whilst parsing resource."));
+ return FALSE;
+ }
+
+ // *name
+ if (!wxGetResourceToken(fd))
+ {
+ wxLogWarning(_("Unexpected end of file whilst parsing resource."));
+ *eof = TRUE;
+ return FALSE;
+ }
+
+ if (wxResourceBuffer[0] != '*')
+ {
+ wxLogWarning(_("Expected '*' whilst parsing resource."));
+ return FALSE;
+ }
+ wxChar nameBuf[100];
+ wxMB2WX(nameBuf, wxResourceBuffer+1, 99);
+ nameBuf[99] = 0;
+
+ // =
+ if (!wxGetResourceToken(fd))
+ {
+ wxLogWarning(_("Unexpected end of file whilst parsing resource."));
+ *eof = TRUE;
+ return FALSE;
+ }
+
+ if (strcmp(wxResourceBuffer, "=") != 0)
+ {
+ wxLogWarning(_("Expected '=' whilst parsing resource."));
+ return FALSE;
+ }
+
+ // String
+ if (!wxGetResourceToken(fd))
+ {
+ wxLogWarning(_("Unexpected end of file whilst parsing resource."));
+ *eof = TRUE;
+ return FALSE;
}
else
{
- char buf[300];
- sprintf(buf, "#define %s must be an integer.", name);
- wxWarning(buf);
- delete[] name;
- delete[] value;
- return FALSE;
+ if (!db.ReadPrologFromString(wxResourceBuffer))
+ {
+ wxLogWarning(_("%s: ill-formed resource file syntax."), nameBuf);
+ return FALSE;
+ }
}
- delete[] name;
- delete[] value;
-
- return TRUE;
- }
- else if (strcmp(wxResourceBuffer, "#include") == 0)
- {
- wxGetResourceToken(fd);
- char *name = copystring(wxResourceBuffer);
- char *actualName = name;
- if (name[0] == '"')
- actualName = name + 1;
- int len = strlen(name);
- if ((len > 0) && (name[len-1] == '"'))
- name[len-1] = 0;
- if (!wxResourceParseIncludeFile(actualName, table))
+ // Semicolon
+ if (!wxGetResourceToken(fd))
{
- char buf[400];
- sprintf(buf, "Could not find resource include file %s.", actualName);
- wxWarning(buf);
+ *eof = TRUE;
}
- delete[] name;
return TRUE;
- }
- else if (strcmp(wxResourceBuffer, "static") != 0)
- {
- char buf[300];
- strcpy(buf, "Found ");
- strncat(buf, wxResourceBuffer, 30);
- strcat(buf, ", expected static, #include or #define\nwhilst parsing resource.");
- wxWarning(buf);
- return FALSE;
- }
+}
- // char
- if (!wxGetResourceToken(fd))
- {
- wxWarning("Unexpected end of file whilst parsing resource.");
- *eof = TRUE;
- return FALSE;
- }
+bool wxResourceReadOneResource(wxInputStream *fd, wxExprDatabase& db, bool *eof, wxResourceTable *table)
+{
+ if (!table)
+ table = wxDefaultResourceTable;
- if (strcmp(wxResourceBuffer, "char") != 0)
- {
- wxWarning("Expected 'char' whilst parsing resource.");
- return FALSE;
- }
-
- // *name
- if (!wxGetResourceToken(fd))
- {
- wxWarning("Unexpected end of file whilst parsing resource.");
- *eof = TRUE;
- return FALSE;
- }
+ // static or #define
+ if (!wxGetResourceToken(fd))
+ {
+ *eof = TRUE;
+ return FALSE;
+ }
- if (wxResourceBuffer[0] != '*')
- {
- wxWarning("Expected '*' whilst parsing resource.");
- return FALSE;
- }
- char nameBuf[100];
- strncpy(nameBuf, wxResourceBuffer+1, 99);
-
- // =
- if (!wxGetResourceToken(fd))
- {
- wxWarning("Unexpected end of file whilst parsing resource.");
- *eof = TRUE;
- return FALSE;
- }
+ if (strcmp(wxResourceBuffer, "#define") == 0)
+ {
+ wxGetResourceToken(fd);
+ wxChar *name = copystring(wxConvLibc.cMB2WX(wxResourceBuffer));
+ wxGetResourceToken(fd);
+ wxChar *value = copystring(wxConvLibc.cMB2WX(wxResourceBuffer));
+ if (wxIsalpha(value[0]))
+ {
+ int val = (int)wxAtol(value);
+ wxResourceAddIdentifier(name, val, table);
+ }
+ else
+ {
+ wxLogWarning(_("#define %s must be an integer."), name);
+ delete[] name;
+ delete[] value;
+ return FALSE;
+ }
+ delete[] name;
+ delete[] value;
- if (strcmp(wxResourceBuffer, "=") != 0)
- {
- wxWarning("Expected '=' whilst parsing resource.");
- return FALSE;
- }
+ return TRUE;
+ }
+ else if (strcmp(wxResourceBuffer, "#include") == 0)
+ {
+ wxGetResourceToken(fd);
+ wxChar *name = copystring(wxConvLibc.cMB2WX(wxResourceBuffer));
+ wxChar *actualName = name;
+ if (name[0] == wxT('"'))
+ actualName = name + 1;
+ int len = wxStrlen(name);
+ if ((len > 0) && (name[len-1] == wxT('"')))
+ name[len-1] = 0;
+ if (!wxResourceParseIncludeFile(actualName, table))
+ {
+ wxLogWarning(_("Could not find resource include file %s."), actualName);
+ }
+ delete[] name;
+ return TRUE;
+ }
+ else if (strcmp(wxResourceBuffer, "static") != 0)
+ {
+ wxChar buf[300];
+ wxStrcpy(buf, _("Found "));
+ wxStrncat(buf, wxConvLibc.cMB2WX(wxResourceBuffer), 30);
+ wxStrcat(buf, _(", expected static, #include or #define\nwhilst parsing resource."));
+ wxLogWarning(buf);
+ return FALSE;
+ }
- // String
- if (!wxGetResourceToken(fd))
- {
- wxWarning("Unexpected end of file whilst parsing resource.");
- *eof = TRUE;
- return FALSE;
- }
- else
- {
- if (!db.ReadPrologFromString(wxResourceBuffer))
+ // char
+ if (!wxGetResourceToken(fd))
{
- char buf[300];
- sprintf(buf, "%s: ill-formed resource file syntax.", nameBuf);
- wxWarning(buf);
- return FALSE;
+ wxLogWarning(_("Unexpected end of file whilst parsing resource."));
+ *eof = TRUE;
+ return FALSE;
}
- }
- // Semicolon
- if (!wxGetResourceToken(fd))
- {
- *eof = TRUE;
- }
- return TRUE;
+
+ if (strcmp(wxResourceBuffer, "char") != 0)
+ {
+ wxLogWarning(_("Expected 'char' whilst parsing resource."));
+ return FALSE;
+ }
+
+ // *name
+ if (!wxGetResourceToken(fd))
+ {
+ wxLogWarning(_("Unexpected end of file whilst parsing resource."));
+ *eof = TRUE;
+ return FALSE;
+ }
+
+ if (wxResourceBuffer[0] != '*')
+ {
+ wxLogWarning(_("Expected '*' whilst parsing resource."));
+ return FALSE;
+ }
+ char nameBuf[100];
+ strncpy(nameBuf, wxResourceBuffer+1, 99);
+
+ // =
+ if (!wxGetResourceToken(fd))
+ {
+ wxLogWarning(_("Unexpected end of file whilst parsing resource."));
+ *eof = TRUE;
+ return FALSE;
+ }
+
+ if (strcmp(wxResourceBuffer, "=") != 0)
+ {
+ wxLogWarning(_("Expected '=' whilst parsing resource."));
+ return FALSE;
+ }
+
+ // String
+ if (!wxGetResourceToken(fd))
+ {
+ wxLogWarning(_("Unexpected end of file whilst parsing resource."));
+ *eof = TRUE;
+ return FALSE;
+ }
+ else
+ {
+ if (!db.ReadPrologFromString(wxResourceBuffer))
+ {
+ wxLogWarning(_("%s: ill-formed resource file syntax."), nameBuf);
+ return FALSE;
+ }
+ }
+ // Semicolon
+ if (!wxGetResourceToken(fd))
+ {
+ *eof = TRUE;
+ }
+ return TRUE;
}
/*
- * Parses string window style into integer window style
- */
-
+* Parses string window style into integer window style
+*/
+
/*
- * Style flag parsing, e.g.
- * "wxSYSTEM_MENU | wxBORDER" -> integer
- */
+* Style flag parsing, e.g.
+* "wxSYSTEM_MENU | wxBORDER" -> integer
+*/
-char *wxResourceParseWord(char *s, int *i)
+wxChar* wxResourceParseWord(wxChar*s, int *i)
{
- if (!s)
- return NULL;
-
- static char buf[150];
- int len = strlen(s);
- int j = 0;
- int ii = *i;
- while ((ii < len) && (isalpha(s[ii]) || (s[ii] == '_')))
- {
- buf[j] = s[ii];
- j ++;
- ii ++;
- }
- buf[j] = 0;
+ if (!s)
+ return (wxChar*) NULL;
+
+ static wxChar buf[150];
+ int len = wxStrlen(s);
+ int j = 0;
+ int ii = *i;
+ while ((ii < len) && (wxIsalpha(s[ii]) || (s[ii] == wxT('_'))))
+ {
+ buf[j] = s[ii];
+ j ++;
+ ii ++;
+ }
+ buf[j] = 0;
- // Eat whitespace and conjunction characters
- while ((ii < len) &&
- ((s[ii] == ' ') || (s[ii] == '|') || (s[ii] == ',')))
- {
- ii ++;
- }
- *i = ii;
- if (j == 0)
- return NULL;
- else
- return buf;
+ // Eat whitespace and conjunction characters
+ while ((ii < len) &&
+ ((s[ii] == wxT(' ')) || (s[ii] == wxT('|')) || (s[ii] == wxT(','))))
+ {
+ ii ++;
+ }
+ *i = ii;
+ if (j == 0)
+ return (wxChar*) NULL;
+ else
+ return buf;
}
struct wxResourceBitListStruct
{
- char *word;
- long bits;
+ wxChar *word;
+ long bits;
};
static wxResourceBitListStruct wxResourceBitListTable[] =
{
- /* wxListBox */
- { "wxSINGLE", wxLB_SINGLE },
- { "wxMULTIPLE", wxLB_MULTIPLE },
- { "wxEXTENDED", wxLB_EXTENDED },
- { "wxLB_SINGLE", wxLB_SINGLE },
- { "wxLB_MULTIPLE", wxLB_MULTIPLE },
- { "wxLB_EXTENDED", wxLB_EXTENDED },
- { "wxNEEDED_SB", wxNEEDED_SB },
- { "wxALWAYS_SB", wxALWAYS_SB },
- { "wxLB_NEEDED_SB", wxLB_NEEDED_SB },
- { "wxLB_ALWAYS_SB", wxLB_ALWAYS_SB },
- { "wxLB_SORT", wxLB_SORT },
-
- /* wxComboxBox */
- { "wxCB_SIMPLE", wxCB_SIMPLE },
- { "wxCB_DROPDOWN", wxCB_DROPDOWN },
- { "wxCB_SORT", wxCB_SORT },
-
- /* wxGauge */
- { "wxGA_PROGRESSBAR", wxGA_PROGRESSBAR },
-
- /* wxTextCtrl */
- { "wxPASSWORD", wxPASSWORD},
- { "wxPROCESS_ENTER", wxPROCESS_ENTER},
- { "wxTE_PASSWORD", wxTE_PASSWORD},
- { "wxTE_READONLY", wxTE_READONLY},
- { "wxTE_PROCESS_ENTER", wxTE_PROCESS_ENTER},
-
- /* wxRadioButton */
- { "wxRB_GROUP", wxRB_GROUP },
-
- /* wxItem */
- { "wxFIXED_LENGTH", wxFIXED_LENGTH},
- { "wxALIGN_LEFT", wxALIGN_LEFT},
- { "wxALIGN_CENTER", wxALIGN_CENTER},
- { "wxALIGN_CENTRE", wxALIGN_CENTRE},
- { "wxALIGN_RIGHT", wxALIGN_RIGHT},
-
- /* wxToolBar */
- { "wxTB_3DBUTTONS", wxTB_3DBUTTONS},
-
- /* Generic */
- { "wxVSCROLL", wxVSCROLL },
- { "wxHSCROLL", wxHSCROLL },
- { "wxCAPTION", wxCAPTION },
- { "wxSTAY_ON_TOP", wxSTAY_ON_TOP},
- { "wxICONIZE", wxICONIZE},
- { "wxMINIMIZE", wxICONIZE},
- { "wxMAXIMIZE", wxMAXIMIZE},
- { "wxSDI", 0},
- { "wxMDI_PARENT", 0},
- { "wxMDI_CHILD", 0},
- { "wxTHICK_FRAME", wxTHICK_FRAME},
- { "wxRESIZE_BORDER", wxRESIZE_BORDER},
- { "wxSYSTEM_MENU", wxSYSTEM_MENU},
- { "wxMINIMIZE_BOX", wxMINIMIZE_BOX},
- { "wxMAXIMIZE_BOX", wxMAXIMIZE_BOX},
- { "wxRESIZE_BOX", wxRESIZE_BOX},
- { "wxDEFAULT_FRAME", wxDEFAULT_FRAME},
- { "wxDEFAULT_DIALOG_STYLE", wxDEFAULT_DIALOG_STYLE},
- { "wxBORDER", wxBORDER},
- { "wxRETAINED", wxRETAINED},
- { "wxEDITABLE", wxEDITABLE},
- { "wxREADONLY", wxREADONLY},
- { "wxNATIVE_IMPL", 0},
- { "wxEXTENDED_IMPL", 0},
- { "wxBACKINGSTORE", wxBACKINGSTORE},
-// { "wxFLAT", wxFLAT},
-// { "wxMOTIF_RESIZE", wxMOTIF_RESIZE},
- { "wxFIXED_LENGTH", wxFIXED_LENGTH},
-
-#if USE_ENHANCED_DIALOG
- // Enhanced dialog
- { "wxBOTTOM_COMMANDS", wxBOTTOM_COMMANDS},
- { "wxRIGHT_COMMANDS", wxRIGHT_COMMANDS},
- { "wxSTATUS_FOOTER", wxSTATUS_FOOTER},
- { "wxNO_STATUS_FOOTER", wxNO_STATUS_FOOTER},
- { "wxNO_CANCEL_BUTTON", wxNO_CANCEL_BUTTON},
- { "wxCANCEL_BUTTON_FIRST", wxCANCEL_BUTTON_FIRST},
- { "wxCANCEL_BUTTON_SECOND", wxCANCEL_BUTTON_SECOND},
- { "wxCANCEL_BUTTON_LAST", wxCANCEL_BUTTON_LAST},
- { "wxENH_DEFAULT", wxENH_DEFAULT},
-#endif
-
- { "wxCOLOURED", wxCOLOURED},
- { "wxTINY_CAPTION_HORIZ", wxTINY_CAPTION_HORIZ},
- { "wxTINY_CAPTION_VERT", wxTINY_CAPTION_VERT},
-
- // Text font families
- { "wxDEFAULT", wxDEFAULT},
- { "wxDECORATIVE", wxDECORATIVE},
- { "wxROMAN", wxROMAN},
- { "wxSCRIPT", wxSCRIPT},
- { "wxSWISS", wxSWISS},
- { "wxMODERN", wxMODERN},
- { "wxTELETYPE", wxTELETYPE},
- { "wxVARIABLE", wxVARIABLE},
- { "wxFIXED", wxFIXED},
- { "wxNORMAL", wxNORMAL},
- { "wxLIGHT", wxLIGHT},
- { "wxBOLD", wxBOLD},
- { "wxITALIC", wxITALIC},
- { "wxSLANT", wxSLANT},
- { "wxSOLID", wxSOLID},
- { "wxDOT", wxDOT},
- { "wxLONG_DASH", wxLONG_DASH},
- { "wxSHORT_DASH", wxSHORT_DASH},
- { "wxDOT_DASH", wxDOT_DASH},
- { "wxUSER_DASH", wxUSER_DASH},
- { "wxTRANSPARENT", wxTRANSPARENT},
- { "wxSTIPPLE", wxSTIPPLE},
- { "wxBDIAGONAL_HATCH", wxBDIAGONAL_HATCH},
- { "wxCROSSDIAG_HATCH", wxCROSSDIAG_HATCH},
- { "wxFDIAGONAL_HATCH", wxFDIAGONAL_HATCH},
- { "wxCROSS_HATCH", wxCROSS_HATCH},
- { "wxHORIZONTAL_HATCH", wxHORIZONTAL_HATCH},
- { "wxVERTICAL_HATCH", wxVERTICAL_HATCH},
- { "wxJOIN_BEVEL", wxJOIN_BEVEL},
- { "wxJOIN_MITER", wxJOIN_MITER},
- { "wxJOIN_ROUND", wxJOIN_ROUND},
- { "wxCAP_ROUND", wxCAP_ROUND},
- { "wxCAP_PROJECTING", wxCAP_PROJECTING},
- { "wxCAP_BUTT", wxCAP_BUTT},
-
- // Logical ops
- { "wxCLEAR", wxCLEAR},
- { "wxXOR", wxXOR},
- { "wxINVERT", wxINVERT},
- { "wxOR_REVERSE", wxOR_REVERSE},
- { "wxAND_REVERSE", wxAND_REVERSE},
- { "wxCOPY", wxCOPY},
- { "wxAND", wxAND},
- { "wxAND_INVERT", wxAND_INVERT},
- { "wxNO_OP", wxNO_OP},
- { "wxNOR", wxNOR},
- { "wxEQUIV", wxEQUIV},
- { "wxSRC_INVERT", wxSRC_INVERT},
- { "wxOR_INVERT", wxOR_INVERT},
- { "wxNAND", wxNAND},
- { "wxOR", wxOR},
- { "wxSET", wxSET},
-
- { "wxFLOOD_SURFACE", wxFLOOD_SURFACE},
- { "wxFLOOD_BORDER", wxFLOOD_BORDER},
- { "wxODDEVEN_RULE", wxODDEVEN_RULE},
- { "wxWINDING_RULE", wxWINDING_RULE},
- { "wxHORIZONTAL", wxHORIZONTAL},
- { "wxVERTICAL", wxVERTICAL},
- { "wxBOTH", wxBOTH},
- { "wxCENTER_FRAME", wxCENTER_FRAME},
- { "wxOK", wxOK},
- { "wxYES_NO", wxYES_NO},
- { "wxCANCEL", wxCANCEL},
- { "wxYES", wxYES},
- { "wxNO", wxNO},
- { "wxICON_EXCLAMATION", wxICON_EXCLAMATION},
- { "wxICON_HAND", wxICON_HAND},
- { "wxICON_QUESTION", wxICON_QUESTION},
- { "wxICON_INFORMATION", wxICON_INFORMATION},
- { "wxICON_STOP", wxICON_STOP},
- { "wxICON_ASTERISK", wxICON_ASTERISK},
- { "wxICON_MASK", wxICON_MASK},
- { "wxCENTRE", wxCENTRE},
- { "wxCENTER", wxCENTRE},
- { "wxUSER_COLOURS", wxUSER_COLOURS},
- { "wxVERTICAL_LABEL", 0},
- { "wxHORIZONTAL_LABEL", 0},
-
- // Bitmap types (not strictly styles)
- { "wxBITMAP_TYPE_XPM", wxBITMAP_TYPE_XPM},
- { "wxBITMAP_TYPE_XBM", wxBITMAP_TYPE_XBM},
- { "wxBITMAP_TYPE_BMP", wxBITMAP_TYPE_BMP},
- { "wxBITMAP_TYPE_RESOURCE", wxBITMAP_TYPE_BMP_RESOURCE},
- { "wxBITMAP_TYPE_BMP_RESOURCE", wxBITMAP_TYPE_BMP_RESOURCE},
- { "wxBITMAP_TYPE_GIF", wxBITMAP_TYPE_GIF},
- { "wxBITMAP_TYPE_TIF", wxBITMAP_TYPE_TIF},
- { "wxBITMAP_TYPE_ICO", wxBITMAP_TYPE_ICO},
- { "wxBITMAP_TYPE_ICO_RESOURCE", wxBITMAP_TYPE_ICO_RESOURCE},
- { "wxBITMAP_TYPE_CUR", wxBITMAP_TYPE_CUR},
- { "wxBITMAP_TYPE_CUR_RESOURCE", wxBITMAP_TYPE_CUR_RESOURCE},
- { "wxBITMAP_TYPE_XBM_DATA", wxBITMAP_TYPE_XBM_DATA},
- { "wxBITMAP_TYPE_XPM_DATA", wxBITMAP_TYPE_XPM_DATA},
- { "wxBITMAP_TYPE_ANY", wxBITMAP_TYPE_ANY}
+ /* wxListBox */
+ { wxT("wxSINGLE"), wxLB_SINGLE },
+ { wxT("wxMULTIPLE"), wxLB_MULTIPLE },
+ { wxT("wxEXTENDED"), wxLB_EXTENDED },
+ { wxT("wxLB_SINGLE"), wxLB_SINGLE },
+ { wxT("wxLB_MULTIPLE"), wxLB_MULTIPLE },
+ { wxT("wxLB_EXTENDED"), wxLB_EXTENDED },
+ { wxT("wxLB_NEEDED_SB"), wxLB_NEEDED_SB },
+ { wxT("wxLB_ALWAYS_SB"), wxLB_ALWAYS_SB },
+ { wxT("wxLB_SORT"), wxLB_SORT },
+ { wxT("wxLB_OWNERDRAW"), wxLB_OWNERDRAW },
+ { wxT("wxLB_HSCROLL"), wxLB_HSCROLL },
+
+ /* wxComboxBox */
+ { wxT("wxCB_SIMPLE"), wxCB_SIMPLE },
+ { wxT("wxCB_DROPDOWN"), wxCB_DROPDOWN },
+ { wxT("wxCB_READONLY"), wxCB_READONLY },
+ { wxT("wxCB_SORT"), wxCB_SORT },
+
+ /* wxGauge */
+ { wxT("wxGA_PROGRESSBAR"), wxGA_PROGRESSBAR },
+ { wxT("wxGA_HORIZONTAL"), wxGA_HORIZONTAL },
+ { wxT("wxGA_VERTICAL"), wxGA_VERTICAL },
+
+ /* wxTextCtrl */
+ { wxT("wxPASSWORD"), wxPASSWORD},
+ { wxT("wxPROCESS_ENTER"), wxPROCESS_ENTER},
+ { wxT("wxTE_PASSWORD"), wxTE_PASSWORD},
+ { wxT("wxTE_READONLY"), wxTE_READONLY},
+ { wxT("wxTE_PROCESS_ENTER"), wxTE_PROCESS_ENTER},
+ { wxT("wxTE_MULTILINE"), wxTE_MULTILINE},
+ { wxT("wxTE_NO_VSCROLL"), wxTE_NO_VSCROLL},
+
+ /* wxRadioBox/wxRadioButton */
+ { wxT("wxRB_GROUP"), wxRB_GROUP },
+ { wxT("wxRA_SPECIFY_COLS"), wxRA_SPECIFY_COLS },
+ { wxT("wxRA_SPECIFY_ROWS"), wxRA_SPECIFY_ROWS },
+ { wxT("wxRA_HORIZONTAL"), wxRA_HORIZONTAL },
+ { wxT("wxRA_VERTICAL"), wxRA_VERTICAL },
+
+ /* wxSlider */
+ { wxT("wxSL_HORIZONTAL"), wxSL_HORIZONTAL },
+ { wxT("wxSL_VERTICAL"), wxSL_VERTICAL },
+ { wxT("wxSL_AUTOTICKS"), wxSL_AUTOTICKS },
+ { wxT("wxSL_LABELS"), wxSL_LABELS },
+ { wxT("wxSL_LEFT"), wxSL_LEFT },
+ { wxT("wxSL_TOP"), wxSL_TOP },
+ { wxT("wxSL_RIGHT"), wxSL_RIGHT },
+ { wxT("wxSL_BOTTOM"), wxSL_BOTTOM },
+ { wxT("wxSL_BOTH"), wxSL_BOTH },
+ { wxT("wxSL_SELRANGE"), wxSL_SELRANGE },
+
+ /* wxScrollBar */
+ { wxT("wxSB_HORIZONTAL"), wxSB_HORIZONTAL },
+ { wxT("wxSB_VERTICAL"), wxSB_VERTICAL },
+
+ /* wxButton */
+ { wxT("wxBU_AUTODRAW"), wxBU_AUTODRAW },
+ { wxT("wxBU_NOAUTODRAW"), wxBU_NOAUTODRAW },
+
+ /* wxTreeCtrl */
+ { wxT("wxTR_HAS_BUTTONS"), wxTR_HAS_BUTTONS },
+ { wxT("wxTR_EDIT_LABELS"), wxTR_EDIT_LABELS },
+ { wxT("wxTR_LINES_AT_ROOT"), wxTR_LINES_AT_ROOT },
+
+ /* wxListCtrl */
+ { wxT("wxLC_ICON"), wxLC_ICON },
+ { wxT("wxLC_SMALL_ICON"), wxLC_SMALL_ICON },
+ { wxT("wxLC_LIST"), wxLC_LIST },
+ { wxT("wxLC_REPORT"), wxLC_REPORT },
+ { wxT("wxLC_ALIGN_TOP"), wxLC_ALIGN_TOP },
+ { wxT("wxLC_ALIGN_LEFT"), wxLC_ALIGN_LEFT },
+ { wxT("wxLC_AUTOARRANGE"), wxLC_AUTOARRANGE },
+ { wxT("wxLC_USER_TEXT"), wxLC_USER_TEXT },
+ { wxT("wxLC_EDIT_LABELS"), wxLC_EDIT_LABELS },
+ { wxT("wxLC_NO_HEADER"), wxLC_NO_HEADER },
+ { wxT("wxLC_NO_SORT_HEADER"), wxLC_NO_SORT_HEADER },
+ { wxT("wxLC_SINGLE_SEL"), wxLC_SINGLE_SEL },
+ { wxT("wxLC_SORT_ASCENDING"), wxLC_SORT_ASCENDING },
+ { wxT("wxLC_SORT_DESCENDING"), wxLC_SORT_DESCENDING },
+
+ /* wxSpinButton */
+ { wxT("wxSP_VERTICAL"), wxSP_VERTICAL},
+ { wxT("wxSP_HORIZONTAL"), wxSP_HORIZONTAL},
+ { wxT("wxSP_ARROW_KEYS"), wxSP_ARROW_KEYS},
+ { wxT("wxSP_WRAP"), wxSP_WRAP},
+
+ /* wxSplitterWnd */
+ { wxT("wxSP_NOBORDER"), wxSP_NOBORDER},
+ { wxT("wxSP_3D"), wxSP_3D},
+ { wxT("wxSP_BORDER"), wxSP_BORDER},
+
+ /* wxTabCtrl */
+ { wxT("wxTC_MULTILINE"), wxTC_MULTILINE},
+ { wxT("wxTC_RIGHTJUSTIFY"), wxTC_RIGHTJUSTIFY},
+ { wxT("wxTC_FIXEDWIDTH"), wxTC_FIXEDWIDTH},
+ { wxT("wxTC_OWNERDRAW"), wxTC_OWNERDRAW},
+
+ /* wxStatusBar95 */
+ { wxT("wxST_SIZEGRIP"), wxST_SIZEGRIP},
+
+ /* wxControl */
+ { wxT("wxFIXED_LENGTH"), wxFIXED_LENGTH},
+ { wxT("wxALIGN_LEFT"), wxALIGN_LEFT},
+ { wxT("wxALIGN_CENTER"), wxALIGN_CENTER},
+ { wxT("wxALIGN_CENTRE"), wxALIGN_CENTRE},
+ { wxT("wxALIGN_RIGHT"), wxALIGN_RIGHT},
+ { wxT("wxCOLOURED"), wxCOLOURED},
+
+ /* wxToolBar */
+ { wxT("wxTB_3DBUTTONS"), wxTB_3DBUTTONS},
+ { wxT("wxTB_HORIZONTAL"), wxTB_HORIZONTAL},
+ { wxT("wxTB_VERTICAL"), wxTB_VERTICAL},
+ { wxT("wxTB_FLAT"), wxTB_FLAT},
+
+ /* wxDialog */
+ { wxT("wxDIALOG_MODAL"), wxDIALOG_MODAL },
+
+ /* Generic */
+ { wxT("wxVSCROLL"), wxVSCROLL },
+ { wxT("wxHSCROLL"), wxHSCROLL },
+ { wxT("wxCAPTION"), wxCAPTION },
+ { wxT("wxSTAY_ON_TOP"), wxSTAY_ON_TOP},
+ { wxT("wxICONIZE"), wxICONIZE},
+ { wxT("wxMINIMIZE"), wxICONIZE},
+ { wxT("wxMAXIMIZE"), wxMAXIMIZE},
+ { wxT("wxSDI"), 0},
+ { wxT("wxMDI_PARENT"), 0},
+ { wxT("wxMDI_CHILD"), 0},
+ { wxT("wxTHICK_FRAME"), wxTHICK_FRAME},
+ { wxT("wxRESIZE_BORDER"), wxRESIZE_BORDER},
+ { wxT("wxSYSTEM_MENU"), wxSYSTEM_MENU},
+ { wxT("wxMINIMIZE_BOX"), wxMINIMIZE_BOX},
+ { wxT("wxMAXIMIZE_BOX"), wxMAXIMIZE_BOX},
+ { wxT("wxRESIZE_BOX"), wxRESIZE_BOX},
+ { wxT("wxDEFAULT_FRAME_STYLE"), wxDEFAULT_FRAME_STYLE},
+ { wxT("wxDEFAULT_FRAME"), wxDEFAULT_FRAME_STYLE},
+ { wxT("wxDEFAULT_DIALOG_STYLE"), wxDEFAULT_DIALOG_STYLE},
+ { wxT("wxBORDER"), wxBORDER},
+ { wxT("wxRETAINED"), wxRETAINED},
+ { wxT("wxNATIVE_IMPL"), 0},
+ { wxT("wxEXTENDED_IMPL"), 0},
+ { wxT("wxBACKINGSTORE"), wxBACKINGSTORE},
+ // { wxT("wxFLAT"), wxFLAT},
+ // { wxT("wxMOTIF_RESIZE"), wxMOTIF_RESIZE},
+ { wxT("wxFIXED_LENGTH"), 0},
+ { wxT("wxDOUBLE_BORDER"), wxDOUBLE_BORDER},
+ { wxT("wxSUNKEN_BORDER"), wxSUNKEN_BORDER},
+ { wxT("wxRAISED_BORDER"), wxRAISED_BORDER},
+ { wxT("wxSIMPLE_BORDER"), wxSIMPLE_BORDER},
+ { wxT("wxSTATIC_BORDER"), wxSTATIC_BORDER},
+ { wxT("wxTRANSPARENT_WINDOW"), wxTRANSPARENT_WINDOW},
+ { wxT("wxNO_BORDER"), wxNO_BORDER},
+ { wxT("wxCLIP_CHILDREN"), wxCLIP_CHILDREN},
+ { wxT("wxCLIP_SIBLINGS"), wxCLIP_SIBLINGS},
+ { wxT("wxTAB_TRAVERSAL"), 0}, // Compatibility only
+
+ { wxT("wxTINY_CAPTION_HORIZ"), wxTINY_CAPTION_HORIZ},
+ { wxT("wxTINY_CAPTION_VERT"), wxTINY_CAPTION_VERT},
+
+ // Text font families
+ { wxT("wxDEFAULT"), wxDEFAULT},
+ { wxT("wxDECORATIVE"), wxDECORATIVE},
+ { wxT("wxROMAN"), wxROMAN},
+ { wxT("wxSCRIPT"), wxSCRIPT},
+ { wxT("wxSWISS"), wxSWISS},
+ { wxT("wxMODERN"), wxMODERN},
+ { wxT("wxTELETYPE"), wxTELETYPE},
+ { wxT("wxVARIABLE"), wxVARIABLE},
+ { wxT("wxFIXED"), wxFIXED},
+ { wxT("wxNORMAL"), wxNORMAL},
+ { wxT("wxLIGHT"), wxLIGHT},
+ { wxT("wxBOLD"), wxBOLD},
+ { wxT("wxITALIC"), wxITALIC},
+ { wxT("wxSLANT"), wxSLANT},
+ { wxT("wxSOLID"), wxSOLID},
+ { wxT("wxDOT"), wxDOT},
+ { wxT("wxLONG_DASH"), wxLONG_DASH},
+ { wxT("wxSHORT_DASH"), wxSHORT_DASH},
+ { wxT("wxDOT_DASH"), wxDOT_DASH},
+ { wxT("wxUSER_DASH"), wxUSER_DASH},
+ { wxT("wxTRANSPARENT"), wxTRANSPARENT},
+ { wxT("wxSTIPPLE"), wxSTIPPLE},
+ { wxT("wxBDIAGONAL_HATCH"), wxBDIAGONAL_HATCH},
+ { wxT("wxCROSSDIAG_HATCH"), wxCROSSDIAG_HATCH},
+ { wxT("wxFDIAGONAL_HATCH"), wxFDIAGONAL_HATCH},
+ { wxT("wxCROSS_HATCH"), wxCROSS_HATCH},
+ { wxT("wxHORIZONTAL_HATCH"), wxHORIZONTAL_HATCH},
+ { wxT("wxVERTICAL_HATCH"), wxVERTICAL_HATCH},
+ { wxT("wxJOIN_BEVEL"), wxJOIN_BEVEL},
+ { wxT("wxJOIN_MITER"), wxJOIN_MITER},
+ { wxT("wxJOIN_ROUND"), wxJOIN_ROUND},
+ { wxT("wxCAP_ROUND"), wxCAP_ROUND},
+ { wxT("wxCAP_PROJECTING"), wxCAP_PROJECTING},
+ { wxT("wxCAP_BUTT"), wxCAP_BUTT},
+
+ // Logical ops
+ { wxT("wxCLEAR"), wxCLEAR},
+ { wxT("wxXOR"), wxXOR},
+ { wxT("wxINVERT"), wxINVERT},
+ { wxT("wxOR_REVERSE"), wxOR_REVERSE},
+ { wxT("wxAND_REVERSE"), wxAND_REVERSE},
+ { wxT("wxCOPY"), wxCOPY},
+ { wxT("wxAND"), wxAND},
+ { wxT("wxAND_INVERT"), wxAND_INVERT},
+ { wxT("wxNO_OP"), wxNO_OP},
+ { wxT("wxNOR"), wxNOR},
+ { wxT("wxEQUIV"), wxEQUIV},
+ { wxT("wxSRC_INVERT"), wxSRC_INVERT},
+ { wxT("wxOR_INVERT"), wxOR_INVERT},
+ { wxT("wxNAND"), wxNAND},
+ { wxT("wxOR"), wxOR},
+ { wxT("wxSET"), wxSET},
+
+ { wxT("wxFLOOD_SURFACE"), wxFLOOD_SURFACE},
+ { wxT("wxFLOOD_BORDER"), wxFLOOD_BORDER},
+ { wxT("wxODDEVEN_RULE"), wxODDEVEN_RULE},
+ { wxT("wxWINDING_RULE"), wxWINDING_RULE},
+ { wxT("wxHORIZONTAL"), wxHORIZONTAL},
+ { wxT("wxVERTICAL"), wxVERTICAL},
+ { wxT("wxBOTH"), wxBOTH},
+ { wxT("wxCENTER_FRAME"), wxCENTER_FRAME},
+ { wxT("wxOK"), wxOK},
+ { wxT("wxYES_NO"), wxYES_NO},
+ { wxT("wxCANCEL"), wxCANCEL},
+ { wxT("wxYES"), wxYES},
+ { wxT("wxNO"), wxNO},
+ { wxT("wxICON_EXCLAMATION"), wxICON_EXCLAMATION},
+ { wxT("wxICON_HAND"), wxICON_HAND},
+ { wxT("wxICON_QUESTION"), wxICON_QUESTION},
+ { wxT("wxICON_INFORMATION"), wxICON_INFORMATION},
+ { wxT("wxICON_STOP"), wxICON_STOP},
+ { wxT("wxICON_ASTERISK"), wxICON_ASTERISK},
+ { wxT("wxICON_MASK"), wxICON_MASK},
+ { wxT("wxCENTRE"), wxCENTRE},
+ { wxT("wxCENTER"), wxCENTRE},
+ { wxT("wxUSER_COLOURS"), wxUSER_COLOURS},
+ { wxT("wxVERTICAL_LABEL"), 0},
+ { wxT("wxHORIZONTAL_LABEL"), 0},
+
+ // Bitmap types (not strictly styles)
+ { wxT("wxBITMAP_TYPE_XPM"), wxBITMAP_TYPE_XPM},
+ { wxT("wxBITMAP_TYPE_XBM"), wxBITMAP_TYPE_XBM},
+ { wxT("wxBITMAP_TYPE_BMP"), wxBITMAP_TYPE_BMP},
+ { wxT("wxBITMAP_TYPE_RESOURCE"), wxBITMAP_TYPE_BMP_RESOURCE},
+ { wxT("wxBITMAP_TYPE_BMP_RESOURCE"), wxBITMAP_TYPE_BMP_RESOURCE},
+ { wxT("wxBITMAP_TYPE_GIF"), wxBITMAP_TYPE_GIF},
+ { wxT("wxBITMAP_TYPE_TIF"), wxBITMAP_TYPE_TIF},
+ { wxT("wxBITMAP_TYPE_ICO"), wxBITMAP_TYPE_ICO},
+ { wxT("wxBITMAP_TYPE_ICO_RESOURCE"), wxBITMAP_TYPE_ICO_RESOURCE},
+ { wxT("wxBITMAP_TYPE_CUR"), wxBITMAP_TYPE_CUR},
+ { wxT("wxBITMAP_TYPE_CUR_RESOURCE"), wxBITMAP_TYPE_CUR_RESOURCE},
+ { wxT("wxBITMAP_TYPE_XBM_DATA"), wxBITMAP_TYPE_XBM_DATA},
+ { wxT("wxBITMAP_TYPE_XPM_DATA"), wxBITMAP_TYPE_XPM_DATA},
+ { wxT("wxBITMAP_TYPE_ANY"), wxBITMAP_TYPE_ANY}
};
static int wxResourceBitListCount = (sizeof(wxResourceBitListTable)/sizeof(wxResourceBitListStruct));
-long wxParseWindowStyle(char *bitListString)
+long wxParseWindowStyle(const wxString& bitListString)
{
- int i = 0;
- char *word;
- long bitList = 0;
- while ((word = wxResourceParseWord(bitListString, &i)))
- {
- bool found = FALSE;
- int j;
- for (j = 0; j < wxResourceBitListCount; j++)
- if (strcmp(wxResourceBitListTable[j].word, word) == 0)
- {
- bitList |= wxResourceBitListTable[j].bits;
- found = TRUE;
- break;
- }
- if (!found)
- {
- char buf[200];
- sprintf(buf, "Unrecognized style %s whilst parsing resource.", word);
- wxWarning(buf);
- return 0;
- }
- }
- return bitList;
-}
-
-/*
- * Load a bitmap from a wxWindows resource, choosing an optimum
- * depth and appropriate type.
- */
-
-wxBitmap *wxResourceCreateBitmap(char *resource, wxResourceTable *table)
-{
- if (!table)
- table = wxDefaultResourceTable;
-
- wxItemResource *item = table->FindResource(resource);
- if (item)
- {
- if (!item->GetType() || strcmp(item->GetType(), "wxBitmap") != 0)
+ int i = 0;
+ wxChar *word;
+ long bitList = 0;
+ word = wxResourceParseWord(WXSTRINGCAST bitListString, &i);
+ while (word != NULL)
{
- char buf[300];
- sprintf(buf, "%s not a bitmap resource specification.", resource);
- wxWarning(buf);
- return NULL;
+ bool found = FALSE;
+ int j;
+ for (j = 0; j < wxResourceBitListCount; j++)
+ if (wxStrcmp(wxResourceBitListTable[j].word, word) == 0)
+ {
+ bitList |= wxResourceBitListTable[j].bits;
+ found = TRUE;
+ break;
+ }
+ if (!found)
+ {
+ wxLogWarning(_("Unrecognized style %s whilst parsing resource."), word);
+ return 0;
+ }
+ word = wxResourceParseWord(WXSTRINGCAST bitListString, &i);
}
- int thisDepth = wxDisplayDepth();
- long thisNoColours = (long)pow(2.0, (double)thisDepth);
+ return bitList;
+}
- wxItemResource *optResource = NULL;
-
- // Try to find optimum bitmap for this platform/colour depth
- wxNode *node = item->GetChildren().First();
- while (node)
- {
- wxItemResource *child = (wxItemResource *)node->Data();
- int platform = (int)child->GetValue2();
- int noColours = (int)child->GetValue3();
/*
- char *name = child->GetName();
- int bitmapType = (int)child->GetValue1();
- int xRes = child->GetWidth();
- int yRes = child->GetHeight();
+* Load a bitmap from a wxWindows resource, choosing an optimum
+* depth and appropriate type.
*/
- switch (platform)
- {
- case RESOURCE_PLATFORM_ANY:
+wxBitmap wxResourceCreateBitmap(const wxString& resource, wxResourceTable *table)
+{
+ if (!table)
+ table = wxDefaultResourceTable;
+
+ wxItemResource *item = table->FindResource(resource);
+ if (item)
+ {
+ if ((item->GetType() == wxT("")) || (item->GetType() != wxT("wxBitmap")))
{
- if (!optResource && ((noColours == 0) || (noColours <= thisNoColours)))
- optResource = child;
- else
- {
- // Maximise the number of colours.
- // If noColours is zero (unspecified), then assume this
- // is the right one.
- if ((noColours == 0) || ((noColours <= thisNoColours) && (noColours > optResource->GetValue3())))
- optResource = child;
- }
- break;
+ wxLogWarning(_("%s not a bitmap resource specification."), (const wxChar*) resource);
+ return wxNullBitmap;
}
-#ifdef __WINDOWS__
- case RESOURCE_PLATFORM_WINDOWS:
+ int thisDepth = wxDisplayDepth();
+ long thisNoColours = (long)pow(2.0, (double)thisDepth);
+
+ wxItemResource *optResource = (wxItemResource *) NULL;
+
+ // Try to find optimum bitmap for this platform/colour depth
+ wxNode *node = item->GetChildren().First();
+ while (node)
{
- if (!optResource && ((noColours == 0) || (noColours <= thisNoColours)))
- optResource = child;
- else
- {
- // Maximise the number of colours
- if ((noColours > 0) || ((noColours <= thisNoColours) && (noColours > optResource->GetValue3())))
- optResource = child;
- }
- break;
- }
+ wxItemResource *child = (wxItemResource *)node->Data();
+ int platform = (int)child->GetValue2();
+ int noColours = (int)child->GetValue3();
+ /*
+ char *name = child->GetName();
+ int bitmapType = (int)child->GetValue1();
+ int xRes = child->GetWidth();
+ int yRes = child->GetHeight();
+ */
+
+ switch (platform)
+ {
+ case RESOURCE_PLATFORM_ANY:
+ {
+ if (!optResource && ((noColours == 0) || (noColours <= thisNoColours)))
+ optResource = child;
+ else
+ {
+ // Maximise the number of colours.
+ // If noColours is zero (unspecified), then assume this
+ // is the right one.
+ if ((noColours == 0) || ((noColours <= thisNoColours) && (noColours > optResource->GetValue3())))
+ optResource = child;
+ }
+ break;
+ }
+#ifdef __WXMSW__
+ case RESOURCE_PLATFORM_WINDOWS:
+ {
+ if (!optResource && ((noColours == 0) || (noColours <= thisNoColours)))
+ optResource = child;
+ else
+ {
+ // Maximise the number of colours
+ if ((noColours > 0) || ((noColours <= thisNoColours) && (noColours > optResource->GetValue3())))
+ optResource = child;
+ }
+ break;
+ }
#endif
-#ifdef __X__
- case RESOURCE_PLATFORM_X:
- {
- if (!optResource && ((noColours == 0) || (noColours <= thisNoColours)))
- optResource = child;
- else
- {
- // Maximise the number of colours
- if ((noColours == 0) || ((noColours <= thisNoColours) && (noColours > optResource->GetValue3())))
- optResource = child;
- }
- break;
- }
+#ifdef __WXGTK__
+ case RESOURCE_PLATFORM_X:
+ {
+ if (!optResource && ((noColours == 0) || (noColours <= thisNoColours)))
+ optResource = child;
+ else
+ {
+ // Maximise the number of colours
+ if ((noColours == 0) || ((noColours <= thisNoColours) && (noColours > optResource->GetValue3())))
+ optResource = child;
+ }
+ break;
+ }
#endif
#ifdef wx_max
- case RESOURCE_PLATFORM_MAC:
- {
- if (!optResource && ((noColours == 0) || (noColours <= thisNoColours)))
- optResource = child;
- else
- {
- // Maximise the number of colours
- if ((noColours == 0) || ((noColours <= thisNoColours) && (noColours > optResource->GetValue3())))
- optResource = child;
- }
- break;
- }
+ case RESOURCE_PLATFORM_MAC:
+ {
+ if (!optResource && ((noColours == 0) || (noColours <= thisNoColours)))
+ optResource = child;
+ else
+ {
+ // Maximise the number of colours
+ if ((noColours == 0) || ((noColours <= thisNoColours) && (noColours > optResource->GetValue3())))
+ optResource = child;
+ }
+ break;
+ }
#endif
- default:
- break;
- }
- node = node->Next();
- }
- // If no matching resource, fail.
- if (!optResource)
- return NULL;
-
- char *name = optResource->GetName();
- int bitmapType = (int)optResource->GetValue1();
- wxBitmap *bitmap = NULL;
- switch (bitmapType)
- {
- case wxBITMAP_TYPE_XBM_DATA:
- {
-#ifdef __X__
- wxItemResource *item = table->FindResource(name);
- if (!item)
- {
- char buf[400];
- sprintf(buf, "Failed to find XBM resource %s.\nForgot to use wxResourceLoadBitmapData?", name);
- wxWarning(buf);
- return NULL;
+ default:
+ break;
+ }
+ node = node->Next();
}
- bitmap = new wxBitmap((char *)item->GetValue1(), (int)item->GetValue2(), (int)item->GetValue3());
+ // If no matching resource, fail.
+ if (!optResource)
+ return wxNullBitmap;
+
+ wxString name = optResource->GetName();
+ int bitmapType = (int)optResource->GetValue1();
+ switch (bitmapType)
+ {
+ case wxBITMAP_TYPE_XBM_DATA:
+ {
+#ifdef __WXGTK__
+ wxItemResource *item = table->FindResource(name);
+ if (!item)
+ {
+ wxLogWarning(_("Failed to find XBM resource %s.\n"
+ "Forgot to use wxResourceLoadBitmapData?"), (const wxChar*) name);
+ return wxNullBitmap;
+ }
+ return wxBitmap(item->GetValue1(), (int)item->GetValue2(), (int)item->GetValue3()) ;
#else
- wxWarning("No XBM facility available!");
+ wxLogWarning(_("No XBM facility available!"));
+ break;
#endif
- break;
- }
- case wxBITMAP_TYPE_XPM_DATA:
- {
-#if (defined(__X__) && USE_XPM_IN_X) || (defined(__WINDOWS__) && USE_XPM_IN_MSW)
- wxItemResource *item = table->FindResource(name);
- if (!item)
- {
- char buf[400];
- sprintf(buf, "Failed to find XPM resource %s.\nForgot to use wxResourceLoadBitmapData?", name);
- wxWarning(buf);
- return NULL;
- }
- bitmap = new wxBitmap((char **)item->GetValue1());
+ }
+ case wxBITMAP_TYPE_XPM_DATA:
+ {
+#if (defined(__WXGTK__)) || (defined(__WXMSW__) && wxUSE_XPM_IN_MSW)
+ wxItemResource *item = table->FindResource(name);
+ if (!item)
+ {
+ wxLogWarning(_("Failed to find XPM resource %s.\nForgot to use wxResourceLoadBitmapData?"), (const wxChar*) name);
+ return wxNullBitmap;
+ }
+ return wxBitmap((char **)item->GetValue1());
#else
- wxWarning("No XPM facility available!");
+ wxLogWarning(_("No XPM facility available!"));
+ break;
+#endif
+ }
+ default:
+ {
+ return wxBitmap(name, (wxBitmapType)bitmapType);
+ }
+ }
+#ifndef __WXGTK__
+ return wxNullBitmap;
#endif
- break;
- }
- default:
- {
- bitmap = new wxBitmap(name, bitmapType);
- break;
- }
- }
- if (!bitmap)
- return NULL;
-
- if (bitmap->Ok())
- {
- return bitmap;
- }
- else
- {
- delete bitmap;
- return NULL;
- }
}
else
{
- char buf[300];
- sprintf(buf, "Bitmap resource specification %s not found.", resource);
- wxWarning(buf);
- return NULL;
+ wxLogWarning(_("Bitmap resource specification %s not found."), (const wxChar*) resource);
+ return wxNullBitmap;
}
}
/*
- * Load an icon from a wxWindows resource, choosing an optimum
- * depth and appropriate type.
- */
-
-wxIcon *wxResourceCreateIcon(char *resource, wxResourceTable *table)
-{
- if (!table)
- table = wxDefaultResourceTable;
-
- wxItemResource *item = table->FindResource(resource);
- if (item)
- {
- if (!item->GetType() || strcmp(item->GetType(), "wxIcon") != 0)
- {
- char buf[300];
- sprintf(buf, "%s not an icon resource specification.", resource);
- wxWarning(buf);
- return NULL;
- }
- int thisDepth = wxDisplayDepth();
- long thisNoColours = (long)pow(2.0, (double)thisDepth);
-
- wxItemResource *optResource = NULL;
-
- // Try to find optimum icon for this platform/colour depth
- wxNode *node = item->GetChildren().First();
- while (node)
- {
- wxItemResource *child = (wxItemResource *)node->Data();
- int platform = (int)child->GetValue2();
- int noColours = (int)child->GetValue3();
-/*
- char *name = child->GetName();
- int bitmapType = (int)child->GetValue1();
- int xRes = child->GetWidth();
- int yRes = child->GetHeight();
+* Load an icon from a wxWindows resource, choosing an optimum
+* depth and appropriate type.
*/
- switch (platform)
- {
- case RESOURCE_PLATFORM_ANY:
+wxIcon wxResourceCreateIcon(const wxString& resource, wxResourceTable *table)
+{
+ if (!table)
+ table = wxDefaultResourceTable;
+
+ wxItemResource *item = table->FindResource(resource);
+ if (item)
+ {
+ if ((item->GetType() == wxT("")) || wxStrcmp(item->GetType(), wxT("wxIcon")) != 0)
{
- if (!optResource && ((noColours == 0) || (noColours <= thisNoColours)))
- optResource = child;
- else
- {
- // Maximise the number of colours.
- // If noColours is zero (unspecified), then assume this
- // is the right one.
- if ((noColours == 0) || ((noColours <= thisNoColours) && (noColours > optResource->GetValue3())))
- optResource = child;
- }
- break;
+ wxLogWarning(_("%s not an icon resource specification."), (const wxChar*) resource);
+ return wxNullIcon;
}
-#ifdef __WINDOWS__
- case RESOURCE_PLATFORM_WINDOWS:
+ int thisDepth = wxDisplayDepth();
+ long thisNoColours = (long)pow(2.0, (double)thisDepth);
+
+ wxItemResource *optResource = (wxItemResource *) NULL;
+
+ // Try to find optimum icon for this platform/colour depth
+ wxNode *node = item->GetChildren().First();
+ while (node)
{
- if (!optResource && ((noColours == 0) || (noColours <= thisNoColours)))
- optResource = child;
- else
- {
- // Maximise the number of colours
- if ((noColours > 0) || ((noColours <= thisNoColours) && (noColours > optResource->GetValue3())))
- optResource = child;
- }
- break;
- }
+ wxItemResource *child = (wxItemResource *)node->Data();
+ int platform = (int)child->GetValue2();
+ int noColours = (int)child->GetValue3();
+ /*
+ char *name = child->GetName();
+ int bitmapType = (int)child->GetValue1();
+ int xRes = child->GetWidth();
+ int yRes = child->GetHeight();
+ */
+
+ switch (platform)
+ {
+ case RESOURCE_PLATFORM_ANY:
+ {
+ if (!optResource && ((noColours == 0) || (noColours <= thisNoColours)))
+ optResource = child;
+ else
+ {
+ // Maximise the number of colours.
+ // If noColours is zero (unspecified), then assume this
+ // is the right one.
+ if ((noColours == 0) || ((noColours <= thisNoColours) && (noColours > optResource->GetValue3())))
+ optResource = child;
+ }
+ break;
+ }
+#ifdef __WXMSW__
+ case RESOURCE_PLATFORM_WINDOWS:
+ {
+ if (!optResource && ((noColours == 0) || (noColours <= thisNoColours)))
+ optResource = child;
+ else
+ {
+ // Maximise the number of colours
+ if ((noColours > 0) || ((noColours <= thisNoColours) && (noColours > optResource->GetValue3())))
+ optResource = child;
+ }
+ break;
+ }
#endif
-#ifdef __X__
- case RESOURCE_PLATFORM_X:
- {
- if (!optResource && ((noColours == 0) || (noColours <= thisNoColours)))
- optResource = child;
- else
- {
- // Maximise the number of colours
- if ((noColours == 0) || ((noColours <= thisNoColours) && (noColours > optResource->GetValue3())))
- optResource = child;
- }
- break;
- }
+#ifdef __WXGTK__
+ case RESOURCE_PLATFORM_X:
+ {
+ if (!optResource && ((noColours == 0) || (noColours <= thisNoColours)))
+ optResource = child;
+ else
+ {
+ // Maximise the number of colours
+ if ((noColours == 0) || ((noColours <= thisNoColours) && (noColours > optResource->GetValue3())))
+ optResource = child;
+ }
+ break;
+ }
#endif
#ifdef wx_max
- case RESOURCE_PLATFORM_MAC:
- {
- if (!optResource && ((noColours == 0) || (noColours <= thisNoColours)))
- optResource = child;
- else
- {
- // Maximise the number of colours
- if ((noColours == 0) || ((noColours <= thisNoColours) && (noColours > optResource->GetValue3())))
- optResource = child;
- }
- break;
- }
+ case RESOURCE_PLATFORM_MAC:
+ {
+ if (!optResource && ((noColours == 0) || (noColours <= thisNoColours)))
+ optResource = child;
+ else
+ {
+ // Maximise the number of colours
+ if ((noColours == 0) || ((noColours <= thisNoColours) && (noColours > optResource->GetValue3())))
+ optResource = child;
+ }
+ break;
+ }
#endif
- default:
- break;
- }
- node = node->Next();
- }
- // If no matching resource, fail.
- if (!optResource)
- return NULL;
-
- char *name = optResource->GetName();
- int bitmapType = (int)optResource->GetValue1();
- wxIcon *icon = NULL;
- switch (bitmapType)
- {
- case wxBITMAP_TYPE_XBM_DATA:
- {
-#ifdef __X__
- wxItemResource *item = table->FindResource(name);
- if (!item)
- {
- char buf[400];
- sprintf(buf, "Failed to find XBM resource %s.\nForgot to use wxResourceLoadIconData?", name);
- wxWarning(buf);
- return NULL;
+ default:
+ break;
+ }
+ node = node->Next();
}
- icon = new wxIcon((char *)item->GetValue1(), (int)item->GetValue2(), (int)item->GetValue3());
+ // If no matching resource, fail.
+ if (!optResource)
+ return wxNullIcon;
+
+ wxString name = optResource->GetName();
+ int bitmapType = (int)optResource->GetValue1();
+ switch (bitmapType)
+ {
+ case wxBITMAP_TYPE_XBM_DATA:
+ {
+#ifdef __WXGTK__
+ wxItemResource *item = table->FindResource(name);
+ if (!item)
+ {
+ wxLogWarning(_("Failed to find XBM resource %s.\n"
+ "Forgot to use wxResourceLoadIconData?"), (const wxChar*) name);
+ return wxNullIcon;
+ }
+ return wxIcon((const char **)item->GetValue1(), (int)item->GetValue2(), (int)item->GetValue3());
#else
- wxWarning("No XBM facility available!");
+ wxLogWarning(_("No XBM facility available!"));
+ break;
#endif
- break;
- }
- case wxBITMAP_TYPE_XPM_DATA:
- {
- // *** XPM ICON NOT YET IMPLEMENTED IN WXWINDOWS ***
-/*
-#if (defined(__X__) && USE_XPM_IN_X) || (defined(__WINDOWS__) && USE_XPM_IN_MSW)
- wxItemResource *item = table->FindResource(name);
- if (!item)
- {
- char buf[400];
- sprintf(buf, "Failed to find XPM resource %s.\nForgot to use wxResourceLoadIconData?", name);
- wxWarning(buf);
- return NULL;
- }
- icon = new wxIcon((char **)item->GetValue1());
+ }
+ case wxBITMAP_TYPE_XPM_DATA:
+ {
+ // *** XPM ICON NOT YET IMPLEMENTED IN WXWINDOWS ***
+ /*
+ #if (defined(__WXGTK__)) || (defined(__WXMSW__) && wxUSE_XPM_IN_MSW)
+ wxItemResource *item = table->FindResource(name);
+ if (!item)
+ {
+ char buf[400];
+ sprintf(buf, _("Failed to find XPM resource %s.\nForgot to use wxResourceLoadIconData?"), name);
+ wxLogWarning(buf);
+ return NULL;
+ }
+ return wxIcon((char **)item->GetValue1());
+ #else
+ wxLogWarning(_("No XPM facility available!"));
+ #endif
+ */
+ wxLogWarning(_("No XPM icon facility available!"));
+ break;
+ }
+ default:
+ {
+#ifdef __WXGTK__
+ wxLogWarning(_("Icon resource specification %s not found."), (const wxChar*) resource);
+ break;
#else
- wxWarning("No XPM facility available!");
+ return wxIcon(name, bitmapType);
#endif
-*/
- wxWarning("No XPM icon facility available!");
- break;
- }
- default:
- {
- icon = new wxIcon(name, bitmapType);
- break;
- }
- }
- if (!icon)
- return NULL;
-
- if (icon->Ok())
- {
- return icon;
- }
- else
- {
- delete icon;
- return NULL;
- }
+ }
+ }
+ return wxNullIcon;
}
else
{
- char buf[300];
- sprintf(buf, "Icon resource specification %s not found.", resource);
- wxWarning(buf);
- return NULL;
+ wxLogWarning(_("Icon resource specification %s not found."), (const wxChar*) resource);
+ return wxNullIcon;
}
}
wxMenu *wxResourceCreateMenu(wxItemResource *item)
{
- wxMenu *menu = new wxMenu;
- wxNode *node = item->GetChildren().First();
- while (node)
- {
- wxItemResource *child = (wxItemResource *)node->Data();
- if (child->GetType() && strcmp(child->GetType(), "wxMenuSeparator") == 0)
- menu->AppendSeparator();
- else if (child->GetChildren().Number() > 0)
- {
- wxMenu *subMenu = wxResourceCreateMenu(child);
- if (subMenu)
- menu->Append((int)child->GetValue1(), child->GetTitle(), subMenu, child->GetValue4());
- }
- else
+ wxMenu *menu = new wxMenu;
+ wxNode *node = item->GetChildren().First();
+ while (node)
{
- menu->Append((int)child->GetValue1(), child->GetTitle(), child->GetValue4(), (child->GetValue2() != 0));
+ wxItemResource *child = (wxItemResource *)node->Data();
+ if ((child->GetType() != wxT("")) && (child->GetType() == wxT("wxMenuSeparator")))
+ menu->AppendSeparator();
+ else if (child->GetChildren().Number() > 0)
+ {
+ wxMenu *subMenu = wxResourceCreateMenu(child);
+ if (subMenu)
+ menu->Append((int)child->GetValue1(), child->GetTitle(), subMenu, child->GetValue4());
+ }
+ else
+ {
+ menu->Append((int)child->GetValue1(), child->GetTitle(), child->GetValue4(), (child->GetValue2() != 0));
+ }
+ node = node->Next();
}
- node = node->Next();
- }
- return menu;
+ return menu;
}
-wxMenuBar *wxResourceCreateMenuBar(char *resource, wxResourceTable *table, wxMenuBar *menuBar)
+wxMenuBar *wxResourceCreateMenuBar(const wxString& resource, wxResourceTable *table, wxMenuBar *menuBar)
{
- if (!table)
- table = wxDefaultResourceTable;
-
- wxItemResource *menuResource = table->FindResource(resource);
- if (menuResource && menuResource->GetType() && strcmp(menuResource->GetType(), "wxMenu") == 0)
- {
- if (!menuBar)
- menuBar = new wxMenuBar;
- wxNode *node = menuResource->GetChildren().First();
- while (node)
+ if (!table)
+ table = wxDefaultResourceTable;
+
+ wxItemResource *menuResource = table->FindResource(resource);
+ if (menuResource && (menuResource->GetType() != wxT("")) && (menuResource->GetType() == wxT("wxMenu")))
{
- wxItemResource *child = (wxItemResource *)node->Data();
- wxMenu *menu = wxResourceCreateMenu(child);
- if (menu)
- menuBar->Append(menu, child->GetTitle());
- node = node->Next();
+ if (!menuBar)
+ menuBar = new wxMenuBar;
+ wxNode *node = menuResource->GetChildren().First();
+ while (node)
+ {
+ wxItemResource *child = (wxItemResource *)node->Data();
+ wxMenu *menu = wxResourceCreateMenu(child);
+ if (menu)
+ menuBar->Append(menu, child->GetTitle());
+ node = node->Next();
+ }
+ return menuBar;
}
- return menuBar;
- }
- return NULL;
+ return (wxMenuBar *) NULL;
}
-wxMenu *wxResourceCreateMenu(char *resource, wxResourceTable *table)
+wxMenu *wxResourceCreateMenu(const wxString& resource, wxResourceTable *table)
{
- if (!table)
- table = wxDefaultResourceTable;
-
- wxItemResource *menuResource = table->FindResource(resource);
- if (menuResource && menuResource->GetType() && strcmp(menuResource->GetType(), "wxMenu") == 0)
-// if (menuResource && (menuResource->GetType() == wxTYPE_MENU))
- return wxResourceCreateMenu(menuResource);
- return NULL;
+ if (!table)
+ table = wxDefaultResourceTable;
+
+ wxItemResource *menuResource = table->FindResource(resource);
+ if (menuResource && (menuResource->GetType() != wxT("")) && (menuResource->GetType() == wxT("wxMenu")))
+ // if (menuResource && (menuResource->GetType() == wxTYPE_MENU))
+ return wxResourceCreateMenu(menuResource);
+ return (wxMenu *) NULL;
}
// Global equivalents (so don't have to refer to default table explicitly)
-bool wxResourceParseData(char *resource, wxResourceTable *table)
+bool wxResourceParseData(const wxString& resource, wxResourceTable *table)
{
- if (!table)
- table = wxDefaultResourceTable;
-
- return table->ParseResourceData(resource);
+ if (!table)
+ table = wxDefaultResourceTable;
+
+ return table->ParseResourceData(resource);
}
-bool wxResourceParseFile(char *filename, wxResourceTable *table)
+bool wxResourceParseFile(const wxString& filename, wxResourceTable *table)
{
- if (!table)
- table = wxDefaultResourceTable;
-
- return table->ParseResourceFile(filename);
+ if (!table)
+ table = wxDefaultResourceTable;
+
+ return table->ParseResourceFile(filename);
}
// Register XBM/XPM data
-bool wxResourceRegisterBitmapData(char *name, char bits[], int width, int height, wxResourceTable *table)
+bool wxResourceRegisterBitmapData(const wxString& name, char bits[], int width, int height, wxResourceTable *table)
{
- if (!table)
- table = wxDefaultResourceTable;
-
- return table->RegisterResourceBitmapData(name, bits, width, height);
+ if (!table)
+ table = wxDefaultResourceTable;
+
+ return table->RegisterResourceBitmapData(name, bits, width, height);
}
-bool wxResourceRegisterBitmapData(char *name, char **data, wxResourceTable *table)
+bool wxResourceRegisterBitmapData(const wxString& name, char **data, wxResourceTable *table)
{
- if (!table)
- table = wxDefaultResourceTable;
+ if (!table)
+ table = wxDefaultResourceTable;
- return table->RegisterResourceBitmapData(name, data);
+ return table->RegisterResourceBitmapData(name, data);
}
void wxResourceClear(wxResourceTable *table)
{
- if (!table)
- table = wxDefaultResourceTable;
+ if (!table)
+ table = wxDefaultResourceTable;
- table->ClearTable();
+ table->ClearTable();
}
/*
- * Identifiers
- */
+* Identifiers
+*/
-bool wxResourceAddIdentifier(char *name, int value, wxResourceTable *table)
+bool wxResourceAddIdentifier(const wxString& name, int value, wxResourceTable *table)
{
- if (!table)
- table = wxDefaultResourceTable;
-
- table->identifiers.Put(name, (wxObject *)value);
- return TRUE;
+ if (!table)
+ table = wxDefaultResourceTable;
+
+ table->identifiers.Put(name, (wxObject *)(long)value);
+ return TRUE;
}
-int wxResourceGetIdentifier(char *name, wxResourceTable *table)
+int wxResourceGetIdentifier(const wxString& name, wxResourceTable *table)
{
- if (!table)
- table = wxDefaultResourceTable;
-
- return (int)table->identifiers.Get(name);
+ if (!table)
+ table = wxDefaultResourceTable;
+
+ return (int)(long)table->identifiers.Get(name);
}
/*
- * Parse #include file for #defines (only)
- */
+* Parse #include file for #defines (only)
+*/
-bool wxResourceParseIncludeFile(char *f, wxResourceTable *table)
+bool wxResourceParseIncludeFile(const wxString& f, wxResourceTable *table)
{
- if (!table)
- table = wxDefaultResourceTable;
-
- FILE *fd = fopen(f, "r");
- if (!fd)
- {
- return FALSE;
- }
- while (wxGetResourceToken(fd))
- {
- if (strcmp(wxResourceBuffer, "#define") == 0)
+ if (!table)
+ table = wxDefaultResourceTable;
+
+ FILE *fd = wxFopen(f, _T("r"));
+ if (!fd)
{
- wxGetResourceToken(fd);
- char *name = copystring(wxResourceBuffer);
- wxGetResourceToken(fd);
- char *value = copystring(wxResourceBuffer);
- if (isdigit(value[0]))
- {
- int val = (int)atol(value);
- wxResourceAddIdentifier(name, val, table);
- }
- delete[] name;
- delete[] value;
+ return FALSE;
}
- }
- fclose(fd);
- return TRUE;
+ while (wxGetResourceToken(fd))
+ {
+ if (strcmp(wxResourceBuffer, "#define") == 0)
+ {
+ wxGetResourceToken(fd);
+ wxChar *name = copystring(wxConvCurrent->cMB2WX(wxResourceBuffer));
+ wxGetResourceToken(fd);
+ wxChar *value = copystring(wxConvCurrent->cMB2WX(wxResourceBuffer));
+ if (wxIsdigit(value[0]))
+ {
+ int val = (int)wxAtol(value);
+ wxResourceAddIdentifier(name, val, table);
+ }
+ delete[] name;
+ delete[] value;
+ }
+ }
+ fclose(fd);
+ return TRUE;
}
/*
- * Reading strings as if they were .wxr files
- */
+* Reading strings as if they were .wxr files
+*/
static int getc_string(char *s)
{
- int ch = s[wxResourceStringPtr];
- if (ch == 0)
- return EOF;
- else
- {
- wxResourceStringPtr ++;
- return ch;
- }
+ int ch = s[wxResourceStringPtr];
+ if (ch == 0)
+ return EOF;
+ else
+ {
+ wxResourceStringPtr ++;
+ return ch;
+ }
}
-static int ungetc_string(void)
+static int ungetc_string()
{
- wxResourceStringPtr --;
- return 0;
+ wxResourceStringPtr --;
+ return 0;
}
bool wxEatWhiteSpaceString(char *s)
{
- int ch = getc_string(s);
- if (ch == EOF)
- return TRUE;
-
- if ((ch != ' ') && (ch != '/') && (ch != ' ') && (ch != 10) && (ch != 13) && (ch != 9))
- {
- ungetc_string();
- return TRUE;
- }
+ int ch = 0;
- // Eat whitespace
- while (ch == ' ' || ch == 10 || ch == 13 || ch == 9)
- ch = getc_string(s);
- // Check for comment
- if (ch == '/')
- {
- ch = getc_string(s);
- if (ch == '*')
+ while ((ch = getc_string(s)) != EOF)
{
- bool finished = FALSE;
- while (!finished)
- {
- ch = getc_string(s);
- if (ch == EOF)
- return FALSE;
- if (ch == '*')
+ switch (ch)
{
- int newCh = getc_string(s);
- if (newCh == '/')
- finished = TRUE;
- else
- {
+ case ' ':
+ case 0x0a:
+ case 0x0d:
+ case 0x09:
+ break;
+ case '/':
+ {
+ int prev_ch = ch;
+ ch = getc_string(s);
+ if (ch == EOF)
+ {
+ ungetc_string();
+ return TRUE;
+ }
+
+ if (ch == '*')
+ {
+ // Eat C comment
+ prev_ch = 0;
+ while ((ch = getc_string(s)) != EOF)
+ {
+ if (ch == '/' && prev_ch == '*')
+ break;
+ prev_ch = ch;
+ }
+ }
+ else
+ {
+ ungetc_string();
+ ungetc_string();
+ return TRUE;
+ }
+ }
+ break;
+ default:
ungetc_string();
- }
+ return TRUE;
+
}
- }
}
- else // False alarm
- return FALSE;
- }
- else if (ch != EOF)
- ungetc_string();
- return wxEatWhiteSpaceString(s);
+ return FALSE;
}
bool wxGetResourceTokenString(char *s)
{
- if (!wxResourceBuffer)
- wxReallocateResourceBuffer();
- wxResourceBuffer[0] = 0;
- wxEatWhiteSpaceString(s);
+ if (!wxResourceBuffer)
+ wxReallocateResourceBuffer();
+ wxResourceBuffer[0] = 0;
+ wxEatWhiteSpaceString(s);
- int ch = getc_string(s);
- if (ch == '"')
- {
- // Get string
- wxResourceBufferCount = 0;
- ch = getc_string(s);
- while (ch != '"')
- {
- int actualCh = ch;
- if (ch == EOF)
- {
- wxResourceBuffer[wxResourceBufferCount] = 0;
- return FALSE;
- }
- // Escaped characters
- else if (ch == '\\')
- {
- int newCh = getc_string(s);
- if (newCh == '"')
- actualCh = '"';
- else if (newCh == 10)
- actualCh = 10;
- else
+ int ch = getc_string(s);
+ if (ch == '"')
+ {
+ // Get string
+ wxResourceBufferCount = 0;
+ ch = getc_string(s);
+ while (ch != '"')
{
- ungetc_string();
+ int actualCh = ch;
+ if (ch == EOF)
+ {
+ wxResourceBuffer[wxResourceBufferCount] = 0;
+ return FALSE;
+ }
+ // Escaped characters
+ else if (ch == '\\')
+ {
+ int newCh = getc_string(s);
+ if (newCh == '"')
+ actualCh = '"';
+ else if (newCh == 10)
+ actualCh = 10;
+ else
+ {
+ ungetc_string();
+ }
+ }
+
+ if (wxResourceBufferCount >= wxResourceBufferSize-1)
+ wxReallocateResourceBuffer();
+ wxResourceBuffer[wxResourceBufferCount] = (char)actualCh;
+ wxResourceBufferCount ++;
+ ch = getc_string(s);
}
- }
-
- if (wxResourceBufferCount >= wxResourceBufferSize-1)
- wxReallocateResourceBuffer();
- wxResourceBuffer[wxResourceBufferCount] = (char)actualCh;
- wxResourceBufferCount ++;
- ch = getc_string(s);
+ wxResourceBuffer[wxResourceBufferCount] = 0;
}
- wxResourceBuffer[wxResourceBufferCount] = 0;
- }
- else
- {
- wxResourceBufferCount = 0;
- // Any other token
- while (ch != ' ' && ch != EOF && ch != ' ' && ch != 13 && ch != 9 && ch != 10)
+ else
{
- if (wxResourceBufferCount >= wxResourceBufferSize-1)
- wxReallocateResourceBuffer();
- wxResourceBuffer[wxResourceBufferCount] = (char)ch;
- wxResourceBufferCount ++;
-
- ch = getc_string(s);
- }
- wxResourceBuffer[wxResourceBufferCount] = 0;
- if (ch == EOF)
- return FALSE;
- }
- return TRUE;
+ wxResourceBufferCount = 0;
+ // Any other token
+ while (ch != ' ' && ch != EOF && ch != ' ' && ch != 13 && ch != 9 && ch != 10)
+ {
+ if (wxResourceBufferCount >= wxResourceBufferSize-1)
+ wxReallocateResourceBuffer();
+ wxResourceBuffer[wxResourceBufferCount] = (char)ch;
+ wxResourceBufferCount ++;
+
+ ch = getc_string(s);
+ }
+ wxResourceBuffer[wxResourceBufferCount] = 0;
+ if (ch == EOF)
+ return FALSE;
+ }
+ return TRUE;
}
/*
- * Files are in form:
- static char *name = "....";
- with possible comments.
- */
-
-bool wxResourceReadOneResourceString(char *s, PrologDatabase& db, bool *eof, wxResourceTable *table)
-{
- if (!table)
- table = wxDefaultResourceTable;
-
- // static or #define
- if (!wxGetResourceTokenString(s))
- {
- *eof = TRUE;
- return FALSE;
- }
+* Files are in form:
+static char *name = "....";
+with possible comments.
+*/
- if (strcmp(wxResourceBuffer, "#define") == 0)
- {
- wxGetResourceTokenString(s);
- char *name = copystring(wxResourceBuffer);
- wxGetResourceTokenString(s);
- char *value = copystring(wxResourceBuffer);
- if (isalpha(value[0]))
+bool wxResourceReadOneResourceString(char *s, wxExprDatabase& db, bool *eof, wxResourceTable *table)
+{
+ if (!table)
+ table = wxDefaultResourceTable;
+
+ // static or #define
+ if (!wxGetResourceTokenString(s))
{
- int val = (int)atol(value);
- wxResourceAddIdentifier(name, val, table);
+ *eof = TRUE;
+ return FALSE;
}
- else
+
+ if (strcmp(wxResourceBuffer, "#define") == 0)
{
- char buf[300];
- sprintf(buf, "#define %s must be an integer.", name);
- wxWarning(buf);
- delete[] name;
- delete[] value;
- return FALSE;
+ wxGetResourceTokenString(s);
+ wxChar *name = copystring(wxConvCurrent->cMB2WX(wxResourceBuffer));
+ wxGetResourceTokenString(s);
+ wxChar *value = copystring(wxConvCurrent->cMB2WX(wxResourceBuffer));
+ if (wxIsdigit(value[0]))
+ {
+ int val = (int)wxAtol(value);
+ wxResourceAddIdentifier(name, val, table);
+ }
+ else
+ {
+ wxLogWarning(_("#define %s must be an integer."), name);
+ delete[] name;
+ delete[] value;
+ return FALSE;
+ }
+ delete[] name;
+ delete[] value;
+
+ return TRUE;
}
- delete[] name;
- delete[] value;
-
- return TRUE;
- }
-/*
- else if (strcmp(wxResourceBuffer, "#include") == 0)
- {
+ /*
+ else if (strcmp(wxResourceBuffer, "#include") == 0)
+ {
wxGetResourceTokenString(s);
char *name = copystring(wxResourceBuffer);
char *actualName = name;
if (name[0] == '"')
- actualName = name + 1;
+ actualName = name + 1;
int len = strlen(name);
if ((len > 0) && (name[len-1] == '"'))
- name[len-1] = 0;
+ name[len-1] = 0;
if (!wxResourceParseIncludeFile(actualName, table))
{
- char buf[400];
- sprintf(buf, "Could not find resource include file %s.", actualName);
- wxWarning(buf);
+ char buf[400];
+ sprintf(buf, _("Could not find resource include file %s."), actualName);
+ wxLogWarning(buf);
}
delete[] name;
return TRUE;
- }
-*/
- else if (strcmp(wxResourceBuffer, "static") != 0)
- {
- char buf[300];
- strcpy(buf, "Found ");
- strncat(buf, wxResourceBuffer, 30);
- strcat(buf, ", expected static, #include or #define\nwhilst parsing resource.");
- wxWarning(buf);
- return FALSE;
- }
+ }
+ */
+ else if (strcmp(wxResourceBuffer, "static") != 0)
+ {
+ wxChar buf[300];
+ wxStrcpy(buf, _("Found "));
+ wxStrncat(buf, wxConvCurrent->cMB2WX(wxResourceBuffer), 30);
+ wxStrcat(buf, _(", expected static, #include or #define\nwhilst parsing resource."));
+ wxLogWarning(buf);
+ return FALSE;
+ }
- // char
- if (!wxGetResourceTokenString(s))
- {
- wxWarning("Unexpected end of file whilst parsing resource.");
- *eof = TRUE;
- return FALSE;
- }
+ // char
+ if (!wxGetResourceTokenString(s))
+ {
+ wxLogWarning(_("Unexpected end of file whilst parsing resource."));
+ *eof = TRUE;
+ return FALSE;
+ }
- if (strcmp(wxResourceBuffer, "char") != 0)
- {
- wxWarning("Expected 'char' whilst parsing resource.");
- return FALSE;
- }
-
- // *name
- if (!wxGetResourceTokenString(s))
- {
- wxWarning("Unexpected end of file whilst parsing resource.");
- *eof = TRUE;
- return FALSE;
- }
+ if (strcmp(wxResourceBuffer, "char") != 0)
+ {
+ wxLogWarning(_("Expected 'char' whilst parsing resource."));
+ return FALSE;
+ }
- if (wxResourceBuffer[0] != '*')
- {
- wxWarning("Expected '*' whilst parsing resource.");
- return FALSE;
- }
- char nameBuf[100];
- strncpy(nameBuf, wxResourceBuffer+1, 99);
-
- // =
- if (!wxGetResourceTokenString(s))
- {
- wxWarning("Unexpected end of file whilst parsing resource.");
- *eof = TRUE;
- return FALSE;
- }
+ // *name
+ if (!wxGetResourceTokenString(s))
+ {
+ wxLogWarning(_("Unexpected end of file whilst parsing resource."));
+ *eof = TRUE;
+ return FALSE;
+ }
- if (strcmp(wxResourceBuffer, "=") != 0)
- {
- wxWarning("Expected '=' whilst parsing resource.");
- return FALSE;
- }
+ if (wxResourceBuffer[0] != '*')
+ {
+ wxLogWarning(_("Expected '*' whilst parsing resource."));
+ return FALSE;
+ }
+ wxChar nameBuf[100];
+ wxMB2WX(nameBuf, wxResourceBuffer+1, 99);
+ nameBuf[99] = 0;
- // String
- if (!wxGetResourceTokenString(s))
- {
- wxWarning("Unexpected end of file whilst parsing resource.");
- *eof = TRUE;
- return FALSE;
- }
- else
- {
- if (!db.ReadPrologFromString(wxResourceBuffer))
+ // =
+ if (!wxGetResourceTokenString(s))
{
- char buf[300];
- sprintf(buf, "%s: ill-formed resource file syntax.", nameBuf);
- wxWarning(buf);
- return FALSE;
+ wxLogWarning(_("Unexpected end of file whilst parsing resource."));
+ *eof = TRUE;
+ return FALSE;
}
- }
- // Semicolon
- if (!wxGetResourceTokenString(s))
- {
- *eof = TRUE;
- }
- return TRUE;
+
+ if (strcmp(wxResourceBuffer, "=") != 0)
+ {
+ wxLogWarning(_("Expected '=' whilst parsing resource."));
+ return FALSE;
+ }
+
+ // String
+ if (!wxGetResourceTokenString(s))
+ {
+ wxLogWarning(_("Unexpected end of file whilst parsing resource."));
+ *eof = TRUE;
+ return FALSE;
+ }
+ else
+ {
+ if (!db.ReadPrologFromString(wxResourceBuffer))
+ {
+ wxLogWarning(_("%s: ill-formed resource file syntax."), nameBuf);
+ return FALSE;
+ }
+ }
+ // Semicolon
+ if (!wxGetResourceTokenString(s))
+ {
+ *eof = TRUE;
+ }
+ return TRUE;
}
bool wxResourceParseString(char *s, wxResourceTable *table)
{
- if (!table)
- table = wxDefaultResourceTable;
-
- if (!s)
- return FALSE;
-
- // Turn backslashes into spaces
- if (s)
- {
- int len = strlen(s);
- int i;
- for (i = 0; i < len; i++)
- if (s[i] == 92 && s[i+1] == 13)
- {
- s[i] = ' ';
- s[i+1] = ' ';
- }
- }
+ if (!table)
+ table = wxDefaultResourceTable;
- PrologDatabase db;
- wxResourceStringPtr = 0;
+ if (!s)
+ return FALSE;
- bool eof = FALSE;
- while (wxResourceReadOneResourceString(s, db, &eof, table) && !eof)
- {
- // Loop
- }
- return wxResourceInterpretResources(*table, db);
+ // Turn backslashes into spaces
+ if (s)
+ {
+ int len = strlen(s);
+ int i;
+ for (i = 0; i < len; i++)
+ if (s[i] == 92 && s[i+1] == 13)
+ {
+ s[i] = ' ';
+ s[i+1] = ' ';
+ }
+ }
+
+ wxExprDatabase db;
+ wxResourceStringPtr = 0;
+
+ bool eof = FALSE;
+ while (wxResourceReadOneResourceString(s, db, &eof, table) && !eof)
+ {
+ // Loop
+ }
+ return wxResourceInterpretResources(*table, db);
}
/*
- * resource loading facility
- */
-
-bool wxWindow::LoadFromResource(wxWindow *parent, const wxString& resourceName, const wxResourceTable *table)
-{
- if (!table)
- table = wxDefaultResourceTable;
-
- wxItemResource *resource = table->FindResource((const char *)resourceName);
-// if (!resource || (resource->GetType() != wxTYPE_DIALOG_BOX))
- if (!resource || !resource->GetType() ||
- ! ((strcmp(resource->GetType(), "wxDialog") == 0) || (strcmp(resource->GetType(), "wxPanel") == 0)))
- return FALSE;
+* resource loading facility
+*/
- char *title = resource->GetTitle();
- long theWindowStyle = resource->GetStyle();
- bool isModal = (resource->GetValue1() != 0);
- int x = resource->GetX();
- int y = resource->GetY();
- int width = resource->GetWidth();
- int height = resource->GetHeight();
- char *name = resource->GetName();
+bool wxWindowBase::LoadFromResource(wxWindow *parent, const wxString& resourceName, const wxResourceTable *table)
+{
+ if (!table)
+ table = wxDefaultResourceTable;
- wxFont *theFont = resource->GetFont();
+ wxItemResource *resource = table->FindResource((const wxChar *)resourceName);
+ // if (!resource || (resource->GetType() != wxTYPE_DIALOG_BOX))
+ if (!resource || (resource->GetType() == wxT("")) ||
+ ! ((resource->GetType() == wxT("wxDialog")) || (resource->GetType() == wxT("wxPanel"))))
+ return FALSE;
- if (IsKindOf(CLASSINFO(wxDialog)))
- {
- wxDialog *dialogBox = (wxDialog *)this;
- long modalStyle = isModal ? wxDIALOG_MODAL : 0;
- if (!dialogBox->Create(parent, -1, title, wxPoint(x, y), wxSize(width, height), theWindowStyle|modalStyle, name))
- return FALSE;
- }
- else
- {
- if (!((wxWindow *)this)->Create(parent, -1, wxPoint(x, y), wxSize(width, height), theWindowStyle, name))
- return FALSE;
- }
+ wxString title(resource->GetTitle());
+ long theWindowStyle = resource->GetStyle();
+ bool isModal = (resource->GetValue1() != 0) ;
+ int x = resource->GetX();
+ int y = resource->GetY();
+ int width = resource->GetWidth();
+ int height = resource->GetHeight();
+ wxString name = resource->GetName();
- if (theFont)
- SetFont(*theFont);
-
- if (resource->GetBackgroundColour())
- SetBackgroundColour(*resource->GetBackgroundColour());
-
- // TODO
- if (resource->GetLabelColour())
- SetForegroundColour(*resource->GetLabelColour());
- else if (resource->GetButtonColour())
- SetForegroundColour(*resource->GetButtonColour());
-
- // Now create children
- wxNode *node = resource->GetChildren().First();
- while (node)
- {
- wxItemResource *childResource = (wxItemResource *)node->Data();
-
- (void) CreateItem(childResource, table);
+ if (IsKindOf(CLASSINFO(wxDialog)))
+ {
+ wxDialog *dialogBox = (wxDialog *)this;
+ long modalStyle = isModal ? wxDIALOG_MODAL : 0;
+ if (!dialogBox->Create(parent, -1, title, wxPoint(x, y), wxSize(width, height), theWindowStyle|modalStyle, name))
+ return FALSE;
+
+ // Only reset the client size if we know we're not going to do it again below.
+ if ((resource->GetResourceStyle() & wxRESOURCE_DIALOG_UNITS) == 0)
+ dialogBox->SetClientSize(width, height);
+ }
+ else if (IsKindOf(CLASSINFO(wxPanel)))
+ {
+ wxPanel* panel = (wxPanel *)this;
+ if (!panel->Create(parent, -1, wxPoint(x, y), wxSize(width, height), theWindowStyle | wxTAB_TRAVERSAL, name))
+ return FALSE;
+ }
+ else
+ {
+ if (!((wxWindow *)this)->Create(parent, -1, wxPoint(x, y), wxSize(width, height), theWindowStyle, name))
+ return FALSE;
+ }
- node = node->Next();
- }
- return TRUE;
+ if ((resource->GetResourceStyle() & wxRESOURCE_USE_DEFAULTS) != 0)
+ {
+ // No need to do this since it's done in wxPanel or wxDialog constructor.
+ // SetFont(wxSystemSettings::GetSystemFont(wxSYS_DEFAULT_GUI_FONT));
+ }
+ else
+ {
+ if (resource->GetFont().Ok())
+ SetFont(resource->GetFont());
+ if (resource->GetBackgroundColour().Ok())
+ SetBackgroundColour(resource->GetBackgroundColour());
+ }
+
+ // Should have some kind of font at this point
+ if (!GetFont().Ok())
+ SetFont(wxSystemSettings::GetSystemFont(wxSYS_DEFAULT_GUI_FONT));
+ if (!GetBackgroundColour().Ok())
+ SetBackgroundColour(wxSystemSettings::GetSystemColour(wxSYS_COLOUR_3DFACE));
+
+ // Only when we've created the window and set the font can we set the correct size,
+ // if based on dialog units.
+ if ((resource->GetResourceStyle() & wxRESOURCE_DIALOG_UNITS) != 0)
+ {
+ wxSize sz = ConvertDialogToPixels(wxSize(width, height));
+ SetClientSize(sz.x, sz.y);
+
+ wxPoint pt = ConvertDialogToPixels(wxPoint(x, y));
+ Move(pt.x, pt.y);
+ }
+
+ // Now create children
+ wxNode *node = resource->GetChildren().First();
+ while (node)
+ {
+ wxItemResource *childResource = (wxItemResource *)node->Data();
+
+ (void) CreateItem(childResource, resource, table);
+
+ node = node->Next();
+ }
+ return TRUE;
}
-wxControl *wxWindow::CreateItem(const wxItemResource *resource, const wxResourceTable *table)
+wxControl *wxWindowBase::CreateItem(const wxItemResource *resource, const wxItemResource* parentResource, const wxResourceTable *table)
{
- if (!table)
- table = wxDefaultResourceTable;
- return table->CreateItem((wxWindow *)this, (wxItemResource *)resource);
+ if (!table)
+ table = wxDefaultResourceTable;
+ return table->CreateItem((wxWindow *)this, resource, parentResource);
}
-#endif // USE_WX_RESOURCES
+#ifdef __VISUALC__
+#pragma warning(default:4706) // assignment within conditional expression
+#endif // VC++
+
+#endif
+// BC++/Win16
+
+#endif // wxUSE_WX_RESOURCES