X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/bc151e848625bde6b087175bb0861b980d249ed0..cc681534ede3ac66dc37f5ebece648514ad88359:/utils/wxrc/wxrc.cpp diff --git a/utils/wxrc/wxrc.cpp b/utils/wxrc/wxrc.cpp index 22177386af..aa5e0476a1 100644 --- a/utils/wxrc/wxrc.cpp +++ b/utils/wxrc/wxrc.cpp @@ -19,6 +19,7 @@ #ifndef WX_PRECOMP #include "wx/app.h" #include "wx/log.h" + #include "wx/wxcrtvararg.h" #endif #include "wx/cmdline.h" @@ -27,7 +28,10 @@ #include "wx/filename.h" #include "wx/wfstream.h" #include "wx/utils.h" +#include "wx/hashset.h" +#include "wx/mimetype.h" +WX_DECLARE_HASH_SET(wxString, wxStringHash, wxStringEqual, StringSet); class XRCWidgetData { @@ -50,6 +54,7 @@ class XRCWndClassData private: wxString m_className; wxString m_parentClassName; + StringSet m_ancestorClassNames; ArrayOfXRCWidgetData m_wdata; void BrowseXmlNode(wxXmlNode* node) @@ -60,8 +65,8 @@ private: while (node) { if (node->GetName() == _T("object") - && node->GetPropVal(_T("class"),&classValue) - && node->GetPropVal(_T("name"),&nameValue)) + && node->GetAttribute(_T("class"),&classValue) + && node->GetAttribute(_T("name"),&nameValue)) { m_wdata.Add(XRCWidgetData(nameValue,classValue)); } @@ -73,9 +78,31 @@ private: } public: - XRCWndClassData(const wxString& className,const wxString& parentClassName, const wxXmlNode* node) : + XRCWndClassData(const wxString& className, + const wxString& parentClassName, + const wxXmlNode* node) : m_className(className) , m_parentClassName(parentClassName) { + if ( className == _T("wxMenu") ) + { + m_ancestorClassNames.insert(_T("wxMenu")); + m_ancestorClassNames.insert(_T("wxMenuBar")); + } + else if ( className == _T("wxMDIChildFrame") ) + { + m_ancestorClassNames.insert(_T("wxMDIParentFrame")); + } + else if( className == _T("wxMenuBar") || + className == _T("wxStatusBar") || + className == _T("wxToolBar") ) + { + m_ancestorClassNames.insert(_T("wxFrame")); + } + else + { + m_ancestorClassNames.insert(_T("wxWindow")); + } + BrowseXmlNode(node->GetChildren()); } @@ -84,14 +111,17 @@ public: return m_wdata; } - bool IsRealClass(const wxString& name) + bool CanBeUsedWithXRCCTRL(const wxString& name) { if (name == _T("tool") || + name == _T("data") || name == _T("unknown") || name == _T("notebookpage") || name == _T("separator") || name == _T("sizeritem") || - name == _T("wxMenuItem")) + name == _T("wxMenuBar") || + name == _T("wxMenuItem") || + name == _T("wxStaticBoxSizer") ) { return false; } @@ -104,25 +134,25 @@ public: file.Write(_T("class ") + m_className + _T(" : public ") + m_parentClassName + _T(" {\nprotected:\n")); size_t i; - for(i=0;iLoadObject(this,NULL,_T(\"") + file.Write(_T("\nprivate:\n void InitWidgetsFromXRC(wxWindow *parent){\n") + _T(" wxXmlResource::Get()->LoadObject(this,parent,_T(\"") + m_className + _T("\"), _T(\"") + m_parentClassName + _T("\"));\n")); - for(i=0;iGetName() == _T("object") - && node->GetPropVal(_T("class"),&classValue) - && node->GetPropVal(_T("name"),&nameValue)){ + && node->GetAttribute(_T("class"),&classValue) + && node->GetAttribute(_T("name"),&nameValue)){ aXRCWndClassData.Add( XRCWndClassData(nameValue,classValue,node) @@ -390,27 +441,35 @@ static bool NodeContainsFilename(wxXmlNode *node) if ( name == _T("icon") ) return true; - // URLs in wxHtmlWindow: - if ( name == _T("url") ) - return true; - // wxBitmapButton: wxXmlNode *parent = node->GetParent(); if (parent != NULL && - parent->GetPropVal(_T("class"), _T("")) == _T("wxBitmapButton") && + parent->GetAttribute(_T("class"), _T("")) == _T("wxBitmapButton") && (name == _T("focus") || name == _T("disabled") || + name == _T("hover") || name == _T("selected"))) return true; // wxBitmap or wxIcon toplevel resources: if ( name == _T("object") ) { - wxString klass = node->GetPropVal(_T("class"), wxEmptyString); - if (klass == _T("wxBitmap") || klass == _T("wxIcon")) + wxString klass = node->GetAttribute(_T("class"), wxEmptyString); + if (klass == _T("wxBitmap") || + klass == _T("wxIcon") || + klass == _T("data") ) return true; } + // URLs in wxHtmlWindow: + if ( name == _T("url") && + parent != NULL && + parent->GetAttribute(_T("class"), _T("")) == _T("wxHtmlWindow") ) + { + // FIXME: this is wrong for e.g. http:// URLs + return true; + } + return false; } @@ -462,7 +521,7 @@ void XmlResApp::FindFilesInXML(wxXmlNode *node, wxArrayString& flist, const wxSt void XmlResApp::DeleteTempFiles(const wxArrayString& flist) { - for (size_t i = 0; i < flist.Count(); i++) + for (size_t i = 0; i < flist.GetCount(); i++) wxRemoveFile(parOutputPath + wxFILE_SEP_PATH + flist[i]); } @@ -472,7 +531,7 @@ void XmlResApp::MakePackageZIP(const wxArrayString& flist) { wxString files; - for (size_t i = 0; i < flist.Count(); i++) + for (size_t i = 0; i < flist.GetCount(); i++) files += flist[i] + _T(" "); files.RemoveLast(); @@ -546,57 +605,78 @@ void XmlResApp::MakePackageCPP(const wxArrayString& flist) if (flagVerbose) wxPrintf(_T("creating C++ source file ") + parOutput + _T("...\n")); - file.Write(_T("") -_T("//\n") -_T("// This file was automatically generated by wxrc, do not edit by hand.\n") -_T("//\n\n") -_T("#include \n") -_T("\n") -_T("#ifdef __BORLANDC__\n") -_T(" #pragma hdrstop\n") -_T("#endif\n") -_T("\n") -_T("") -_T("#include \n") -_T("#include \n") -_T("#include \n") -_T("#include \n") -_T("\n")); - - for (i = 0; i < flist.Count(); i++) + file.Write("" +"//\n" +"// This file was automatically generated by wxrc, do not edit by hand.\n" +"//\n\n" +"#include \n" +"\n" +"#ifdef __BORLANDC__\n" +" #pragma hdrstop\n" +"#endif\n" +"\n" +"" +"#include \n" +"#include \n" +"#include \n" +"#include \n" +"\n" +"#if wxCHECK_VERSION(2,8,5) && wxABI_VERSION >= 20805\n" +" #define XRC_ADD_FILE(name, data, size, mime) \\\n" +" wxMemoryFSHandler::AddFileWithMimeType(name, data, size, mime)\n" +"#else\n" +" #define XRC_ADD_FILE(name, data, size, mime) \\\n" +" wxMemoryFSHandler::AddFile(name, data, size)\n" +"#endif\n" +"\n"); + + for (i = 0; i < flist.GetCount(); i++) file.Write( FileToCppArray(parOutputPath + wxFILE_SEP_PATH + flist[i], i)); - file.Write(_T("") -_T("void ") + parFuncname + wxT("()\n") -_T("{\n") -_T("\n") -_T(" // Check for memory FS. If not present, load the handler:\n") -_T(" {\n") -_T(" wxMemoryFSHandler::AddFile(wxT(\"XRC_resource/dummy_file\"), wxT(\"dummy one\"));\n") -_T(" wxFileSystem fsys;\n") -_T(" wxFSFile *f = fsys.OpenFile(wxT(\"memory:XRC_resource/dummy_file\"));\n") -_T(" wxMemoryFSHandler::RemoveFile(wxT(\"XRC_resource/dummy_file\"));\n") -_T(" if (f) delete f;\n") -_T(" else wxFileSystem::AddHandler(new wxMemoryFSHandler);\n") -_T(" }\n") -_T("\n")); - - for (i = 0; i < flist.Count(); i++) + file.Write("" +"void " + parFuncname + "()\n" +"{\n" +"\n" +" // Check for memory FS. If not present, load the handler:\n" +" {\n" +" wxMemoryFSHandler::AddFile(wxT(\"XRC_resource/dummy_file\"), wxT(\"dummy one\"));\n" +" wxFileSystem fsys;\n" +" wxFSFile *f = fsys.OpenFile(wxT(\"memory:XRC_resource/dummy_file\"));\n" +" wxMemoryFSHandler::RemoveFile(wxT(\"XRC_resource/dummy_file\"));\n" +" if (f) delete f;\n" +" else wxFileSystem::AddHandler(new wxMemoryFSHandler);\n" +" }\n" +"\n"); + + for (i = 0; i < flist.GetCount(); i++) { wxString s; - s.Printf(_T(" wxMemoryFSHandler::AddFile(wxT(\"XRC_resource/") + flist[i] + - _T("\"), xml_res_file_%i, xml_res_size_%i);\n"), i, i); + + wxString mime; + wxString ext = wxFileName(flist[i]).GetExt(); + if ( ext.Lower() == _T("xrc") ) + mime = _T("text/xml"); + else + { + wxFileType *ft = wxTheMimeTypesManager->GetFileTypeFromExtension(ext); + if ( ft ) + ft->GetMimeType(&mime); + } + + s.Printf(" XRC_ADD_FILE(wxT(\"XRC_resource/" + flist[i] + + "\"), xml_res_file_%i, xml_res_size_%i, _T(\"%s\"));\n", + i, i, mime.c_str()); file.Write(s); } - for (i = 0; i < parFiles.Count(); i++) + for (i = 0; i < parFiles.GetCount(); i++) { - file.Write(_T(" wxXmlResource::Get()->Load(wxT(\"memory:XRC_resource/") + - GetInternalFileName(parFiles[i], flist) + _T("\"));\n")); + file.Write(" wxXmlResource::Get()->Load(wxT(\"memory:XRC_resource/" + + GetInternalFileName(parFiles[i], flist) + "\"));\n"); } - file.Write(_T("}\n")); + file.Write("}\n"); } @@ -608,19 +688,19 @@ void XmlResApp::GenCPPHeader() wxFFile file(heaFileName, wxT("wt")); file.Write( -_T("//\n") -_T("// This file was automatically generated by wxrc, do not edit by hand.\n") -_T("//\n\n") -_T("#ifndef __") + fileSpec + _T("_h__\n") -_T("#define __") + fileSpec + _T("_h__\n") +"//\n" +"// This file was automatically generated by wxrc, do not edit by hand.\n" +"//\n\n" +"#ifndef __" + fileSpec + "_h__\n" +"#define __" + fileSpec + "_h__\n" ); - for(size_t i=0;iGetPropVal(_T("translate"), _T("1")) != _T("0")) + node->GetAttribute(_T("translate"), _T("1")) != _T("0")) { arr.Add(ConvertText(n->GetContent())); }