X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/88d42654d76be0098f6a1fa12b83af97f5b6235a..65baafba0e8cd74f2264b7e2f7625ff5bea84864:/contrib/utils/convertrc/rc2xml.cpp diff --git a/contrib/utils/convertrc/rc2xml.cpp b/contrib/utils/convertrc/rc2xml.cpp index 2518c9d8c8..84550e0205 100644 --- a/contrib/utils/convertrc/rc2xml.cpp +++ b/contrib/utils/convertrc/rc2xml.cpp @@ -1,1072 +1,1425 @@ -// rc2xml.cpp: implementation of the wxRC2XML class. -// -////////////////////////////////////////////////////////////////////// +// rc2xml.cpp: implementation of the rc2xml class. +//Author: Brian Gavin 9/24/00 +//License: wxWindows License +/* +How to use: +#include "rc2xml.h" +... +rc2xml trans; +trans->Convert("Myfile.rc","Myfile.xml"); +*/ +/* TODO +1. Figure how to fix memory leaks in all wxLists in this class +2. Find a way to rename MS Windows fonts so that they work +cross platform (wxGTK,etc) +3. Be able to abort incorrectly formated files without crashing +*/ + // For compilers that support precompilation, includes "wx/wx.h". #include "wx/wxprec.h" +#ifdef __BORLANDC__ +#pragma hdrstop +#endif + +// for all others, include the necessary headers (this file is usually all you +// need because it includes almost all "standard" wxWidgets headers +#ifndef WX_PRECOMP +#include "wx/wx.h" +#endif + + #include "rc2xml.h" #include "wx/image.h" -#include "wx/resource.h" +#include "wx/deprecated/setup.h" +#include "wx/deprecated/resource.h" +#include "wx/textfile.h" +#include "wx/tokenzr.h" + + + ////////////////////////////////////////////////////////////////////// // Construction/Destruction ////////////////////////////////////////////////////////////////////// -wxRC2XML::wxRC2XML() +rc2xml::rc2xml() { -m_done=FALSE; -m_bitmaplist=new wxList(wxKEY_STRING); -m_stringtable=new wxList(wxKEY_STRING); -m_iconlist = new wxList(wxKEY_STRING); + m_done=false; + m_bitmaplist=new wxList(wxKEY_STRING); + m_stringtable=new wxList(wxKEY_STRING); + m_iconlist = new wxList(wxKEY_STRING); + m_resourcelist =new wxList(wxKEY_INTEGER); } -wxRC2XML::~wxRC2XML() +rc2xml::~rc2xml() { -delete m_bitmaplist; -delete m_stringtable; -delete m_iconlist; + delete m_bitmaplist; + delete m_stringtable; + delete m_iconlist; + delete m_resourcelist; } -bool wxRC2XML::Convert(wxString rcfile, wxString xmlfile) +bool rc2xml::Convert(wxString rcfile, wxString xmlfile) { -m_rc.Open(rcfile.c_str()); -m_filesize=m_rc.Length(); + m_rc.Open(rcfile.c_str()); + m_filesize=m_rc.Length(); + + + m_workingpath=wxPathOnly(rcfile); + + m_targetpath=wxPathOnly(xmlfile) + _T("\\"); + + + + wxSetWorkingDirectory(m_workingpath); + + + bool result; + result=m_xmlfile.Open(xmlfile.c_str(),_T("w+t")); + wxASSERT_MSG(result,_T("Couldn't create XML file")); + if (!result) + return false; -bool result; -result=m_xmlfile.Open(xmlfile.c_str(),"w+t"); -wxASSERT_MSG(result,"Couldn't create XML file"); -if (!result) - return FALSE; - /* Write Basic header for XML file */ -m_xmlfile.Write("\n"); -m_xmlfile.Write("\n"); + m_xmlfile.Write(_T("\n")); + m_xmlfile.Write(_T("\n")); +//Read resource.h + ParseResourceHeader(); //Gather all the resource we need for toolbars,menus, and etc -FirstPass(); -m_done=FALSE; -m_rc.Seek(0); + FirstPass(); + m_done=false; + m_rc.Seek(0); //Read in dialogs, toolbars,menus -SecondPass(); + SecondPass(); -m_xmlfile.Write("\n"); -m_xmlfile.Close(); -m_rc.Close(); + m_xmlfile.Write(_T("\n")); + m_xmlfile.Close(); + m_rc.Close(); + wxMessageBox(_("Conversion complete."), _("Done"), + wxOK | wxICON_INFORMATION); -return TRUE; +return true; } -void wxRC2XML::ParseDialog(wxString dlgname) +void rc2xml::ParseDialog(wxString dlgname) { - wxString token; - static int dlgid=999; - dlgid++; - /* Make sure that this really is a dialog - microsoft reuses the keyword DIALOG for other things - */ - token=PeekToken(); - //Microsoft notation? - if (token=="DISCARDABLE") - { - token=GetToken(); - token=PeekToken(); - } - //Error isn't a Dialog resource eject eject - if (!token.IsNumber()) - return; + wxString token; + static int dlgid=999; + dlgid++; +/* Make sure that this really is a dialog +microsoft reuses the keyword DIALOG for other things +*/ + token=PeekToken(); +//Microsoft notation? + while ((token==_T("DISCARDABLE")) + ||(token==_T("LOADONCALL"))||(token==_T("MOVEABLE"))) + { + token=GetToken(); + token=PeekToken(); + } +//Error isn't a Dialog resource eject eject + if (!token.IsNumber()) + return; //Record x,y,width,height -int x,y,width,height; -ReadRect(x,y,width,height); + int x,y,width,height; + ReadRect(x,y,width,height); //Get Title -token=GetToken(); -wxString title; + token=GetToken(); + wxString title; + wxString ptsize,face; + + m_xmlfile.Write(_T("\t\n")); + m_xmlfile.Write(_T("\t\t\t")+ptsize+_T("\n")); + m_xmlfile.Write(_T("\t\t\t")+face+_T("\n")); + m_xmlfile.Write(_T("\t\t\n")); + } -while ((token!="BEGIN")&(token!="{")) -{ -if (token=="CAPTION") - { - title=GetQuoteField(); - } -token=GetToken(); -} -m_xmlfile.Write(" \n"); -ParseControls(); -m_xmlfile.Write(" \n"); -m_xmlfile.Write(" \n"); + token=GetToken(); + } + + ParseControls(); + m_xmlfile.Write(_T("\t\n")); } /* BEGIN - EDITTEXT IDC_BANDS,36,83,22,14,ES_AUTOHSCROLL | ES_NUMBER | NOT + EDITTEXT IDC_BANDS,36,83,22,14,ES_AUTOHSCROLL | ES_NUMBER | NOT WS_TABSTOP LTEXT "Bands",IDC_STATIC,11,86,21,8 EDITTEXT IDC_NAME,10,3,75,14,ES_AUTOHSCROLL END */ -void wxRC2XML::ParseControls() +void rc2xml::ParseControls() { -wxString token; - -token=GetToken(); -while ((token!="END")&(token!="}")) - { - if (token=="LTEXT") - ParseStaticText(); - else if (token=="EDITTEXT") - ParseTextCtrl(); - else if (token=="PUSHBUTTON") - ParsePushButton(); - else if (token=="DEFPUSHBUTTON") - ParsePushButton(); - else if (token=="GROUPBOX") - ParseGroupBox(); - else if (token=="COMBOBOX") - ParseComboBox(); - else if (token=="CONTROL") - ParseControlMS(); - else if (token=="LISTBOX") - ParseListBox(); - else if (token=="ICON") - ParseIconStatic(); - else if (token=="SCROLLBAR") - ParseScrollBar(); - token=GetToken(); - } + wxString token; + wxString label,varname; + + token=GetToken(); + while ((token!=_T("END"))&(token!=_T("}"))) + { + if (token==_T("AUTOCHECKBOX")) + { + label=GetQuoteField(); + varname=GetToken(); + ParseCheckBox(label,varname); + } + else + if (token==_T("AUTORADIOBUTTON")) + { + label=GetQuoteField(); + varname=GetToken(); + ParseRadioButton(label,varname); + } + else + if (token==_T("LTEXT")) + { + label=GetQuoteField(); + varname=GetToken(); + ParseStaticText(label,varname); + } + else if (token==_T("EDITTEXT")) + { + varname=GetToken(); + ParseTextCtrl(varname); + } + else if ((token==_T("PUSHBUTTON"))||(token==_T("DEFPUSHBUTTON"))) + { + label=GetQuoteField(); + varname=GetToken(); + ParsePushButton(label,varname); + } + else if (token==_T("GROUPBOX")) + { + label=GetQuoteField(); + varname=GetToken(); + ParseGroupBox(label,varname); + } + else if (token==_T("COMBOBOX")) + { + varname=GetToken(); + ParseComboBox(varname); + } + else if (token==_T("CONTROL")) + ParseControlMS(); + else if (token==_T("LISTBOX")) + { + varname=GetToken(); + ParseListBox(varname); + } + else if (token==_T("ICON")) + ParseIconStatic(); + else if (token==_T("SCROLLBAR")) + ParseScrollBar(); + token=GetToken(); + } } //LTEXT "Radius",IDC_STATIC,9,67,23,8 -void wxRC2XML::ParseStaticText() +void rc2xml::ParseStaticText(wxString phrase, wxString varname) { -wxString token; -wxString phrase,varname; -phrase=GetQuoteField(); -varname=GetToken(); -int x,y,width,height; -ReadRect(x,y,width,height); - -m_xmlfile.Write(" \n"); + wxString token; + token=PeekToken(); + while (!token.IsNumber()) + { + token=GetToken(); + token=PeekToken(); + } + int x,y,width,height; + ReadRect(x,y,width,height); + + m_xmlfile.Write(_T("\t\t\n")); } //EDITTEXT IDC_RADIUS,36,65,40,14,ES_AUTOHSCROLL -void wxRC2XML::ParseTextCtrl() +void rc2xml::ParseTextCtrl(wxString varname) { -wxString token; -wxString varname,style; -varname=GetToken(); -int x,y,width,height; -ReadRect(x,y,width,height); + wxString token; + wxString style; + token=PeekToken(); + while (!token.IsNumber()) + { + token=GetToken(); + token=PeekToken(); + } + int x,y,width,height; + ReadRect(x,y,width,height); //TODO //style=GetToken(); - -m_xmlfile.Write(" \n"); + m_xmlfile.Write(_T("\t\t\n")); } -//PUSHBUTTON "Create/Update",IDC_CREATE,15,25,53,13,NOT WS_TABSTOP -void wxRC2XML::ParsePushButton() +//AUTOCHECKBOX "&log.", ID_XLOG, 25, 24, 21, 12 +void rc2xml::ParseCheckBox(wxString phrase, wxString varname) { -wxString token; -wxString phrase,varname; -phrase=GetQuoteField(); -varname=GetToken(); - - -int x,y,width,height; -ReadRect(x,y,width,height); - -m_xmlfile.Write(" \n"); + wxString token; + token=PeekToken(); + while (!token.IsNumber()) + { + token=GetToken(); + token=PeekToken(); + } + int x,y,width,height; + ReadRect(x,y,width,height); + + m_xmlfile.Write(_T("\t\t\n")); } - - -bool wxRC2XML::Seperator(int ch) +//AUTORADIOBUTTON "&text", ID_SW10, 13, 12, 68, 10, BS_AUTORADIOBUTTON | WS_GROUP +void rc2xml::ParseRadioButton(wxString phrase, wxString varname) { -//if ((ch==' ')|(ch==',')|(ch==13)|(ch==10)|(ch=='|')|(ch=='\t')) -if ((ch==' ')|(ch==',')|(ch==13)|(ch==10)|(ch=='\t')) - return TRUE; + wxString token,style; + int x,y,width,height; + bool GotOrs; + GotOrs = ReadOrs(token); + if (ReadRect(x,y,width,height)) + if (GotOrs==false) + ReadOrs(token); + if (token.Find(_T("WS_GROUP")) != wxNOT_FOUND) + style += _T("wxRB_GROUP"); + + m_xmlfile.Write(_T("\t\t\n")); -if (ch==EOF) -{ - m_done=TRUE; - return TRUE; -} -return FALSE; } -void wxRC2XML::ParseGroupBox() +//PUSHBUTTON "Create/Update",IDC_CREATE,15,25,53,13,NOT WS_TABSTOP +void rc2xml::ParsePushButton(wxString phrase, wxString varname) { -// GROUPBOX "Rotate",IDC_STATIC,1,1,71,79 -wxString token; -wxString phrase,varname; -phrase=GetQuoteField(); -varname=GetToken(); -int x,y,width,height; -ReadRect(x,y,width,height); - -m_xmlfile.Write(" \n"); - + wxString token; + + token=PeekToken(); + while (!token.IsNumber()) + { + token=GetToken(); + token=PeekToken(); + } + int x,y,width,height; + ReadRect(x,y,width,height); + + m_xmlfile.Write(_T("\t\t\n")); } -void wxRC2XML::ReadRect(int & x, int & y, int & width, int & height) -{ -x=atoi(GetToken()); -y=atoi(GetToken()); -width=atoi(GetToken()); -height=atoi(GetToken()); - -} -wxString wxRC2XML::GetToken() +bool rc2xml::Separator(int ch) { -wxString token=""; +//if ((ch==' ')|(ch==',')|(ch==13)|(ch==10)|(ch=='|')|(ch=='\t')) + if ((ch==' ')|(ch==',')|(ch==13)|(ch==10)|(ch=='\t')) + return true; -if (m_rc.Eof()) -{ -m_done=TRUE; -return token; -} + if (ch==EOF) + { + m_done=true; + return true; + } -int ch=0; -ReadChar(ch); -if (ch==EOF) -{ -m_done=TRUE; -return token; + return false; } -while (Seperator(ch)) +void rc2xml::ParseGroupBox(wxString phrase, wxString varname) { - ReadChar(ch); - if (m_done) - return token; +// GROUPBOX "Rotate",IDC_STATIC,1,1,71,79 + wxString token; + token=PeekToken(); + while (!token.IsNumber()) + { + token=GetToken(); + token=PeekToken(); + } + int x,y,width,height; + ReadRect(x,y,width,height); + + m_xmlfile.Write(_T("\t\t\n")); } -if (ch==EOF) +bool rc2xml::ReadRect(int & x, int & y, int & width, int & height) { - m_done=TRUE; - + x=wxAtoi(GetToken()); + y=wxAtoi(GetToken()); + width=wxAtoi(GetToken()); + bool ret; + wxString tmp = GetToken(&ret); + height=wxAtoi(tmp); + return ret; // check for more parameters } - -while (!Seperator(ch)) +wxString rc2xml::GetToken(bool *listseparator) { - token+=(char)ch; - ReadChar(ch); + wxString token=wxEmptyString; + if (m_rc.Eof()) + { + m_done=true; + return token; } -if (ch==EOF) - m_done=TRUE; + int ch=0; + ReadChar(ch); + if (ch==EOF) + { + m_done=true; + return token; + } + while (Separator(ch)) + { + ReadChar(ch); + if (m_done) + return token; + } -return token; -} + if (ch==EOF) + { + m_done=true; + } -wxString wxRC2XML::GetQuoteField() -{ -wxString phrase; -//ASCII code 34 " -int ch=0; -ReadChar(ch); -while (ch!=34) - ReadChar(ch); - - ReadChar(ch); + while (!Separator(ch)) + { + token += (char)ch; + ReadChar(ch); + } -while (ch!=34) -{ - phrase+=(char)ch; - ReadChar(ch); -} -return phrase; + if (ch == EOF) + m_done = true; + + if (listseparator) + *listseparator = (ch == ','); + return token; } -void wxRC2XML::ReadChar(int &ch) +wxString rc2xml::GetQuoteField() { - int result; -result=m_rc.Tell(); - -if((result>=m_filesize)) - m_done=TRUE; + wxString phrase; + //ASCII code 34 " + int ch=0; + int ch1=0; + + ReadChar(ch); + + // !! Changed by MS, 15th/11/04. Can now read strings such as + // """Catapult"" - blah blah", ... + + while (ch!=34) + ReadChar(ch); + + // found first '"' + while (true) + { + ReadChar(ch); + if (ch == 34) + { + // another quote? + ReadChar(ch1); + if (ch1 != 34) + { + // real end of string.. + break; + } + + // add a single quote - fall through + } + phrase+=(char)ch; + } -result=m_rc.Read(&ch,1); + return phrase; +} -if((result==-1)) - m_done=TRUE; +// string in stringtable may contain embedded quotes +// escape characters retained to allow strings to be rewritten +wxString rc2xml::GetStringQuote() +{ + wxString phrase; + //ASCII code 34 " + bool done=false; + int ch=0,lastch=0; + ReadChar(ch); + + while (ch!=34) + ReadChar(ch); + + ReadChar(ch); + while (done==false) + { + if ((ch==34)&&(lastch!='\\')) + { + wxFileOffset p = m_rc.Tell(); + ReadChar(ch); + // RC supports "", for embedded quote, as well as \" + if (ch==34) + phrase+='\\'; + else + { + m_rc.Seek(p); + done = true; + } + } + if (done==true) + break; + if (ch=='\r') + ReadChar(ch); // skip + if ((ch=='\n')&&(lastch=='\\')) // lastch be this + phrase+='n'; // escape + else + phrase+=(char)ch; + + lastch=ch; + ReadChar(ch); + } -if(ch==EOF) - m_done=TRUE; + return phrase; } -void wxRC2XML::ParseComboBox() +void rc2xml::ReadChar(int &ch) { -/* COMBOBOX IDC_SCALECOMBO,10,110,48,52,CBS_DROPDOWNLIST | CBS_SORT | - WS_VSCROLL | WS_TABSTOP */ -wxString token; -wxString varname; -varname=GetToken(); -int x,y,width,height; -ReadRect(x,y,width,height); + wxFileOffset result = m_rc.Tell(); -m_xmlfile.Write(" \n"); + if((result>=m_filesize)) + m_done=true; + result = m_rc.Read(&ch,1); + if( result == wxInvalidOffset ) + m_done=true; + if(ch==EOF) + m_done=true; } -void wxRC2XML::ParseMenu(wxString varname) +void rc2xml::ParseComboBox(wxString varname) { -wxString token=""; - -//Write menubar to xml file -m_xmlfile.Write(" \n"); -m_xmlfile.Write(" \n"); +/* COMBOBOX IDC_SCALECOMBO,10,110,48,52,CBS_DROPDOWNLIST | CBS_SORT | + WS_VSCROLL | WS_TABSTOP */ + wxString token,style; + int x,y,width,height; + bool GotOrs; + GotOrs = ReadOrs(token); + if (ReadRect(x,y,width,height)) + if (GotOrs==false) + ReadOrs(token); + + m_xmlfile.Write(_T("\t\t\n")); -while ((token!="BEGIN")&(token!="{")) - token=GetToken(); +} -while ((token!="END")&(token!="}")) +void rc2xml::ParseMenu(wxString varname) { - token=GetToken(); -if (token=="POPUP") - { - ParsePopupMenu(); - } -} -m_xmlfile.Write(" \n"); -m_xmlfile.Write(" \n"); + wxString token=wxEmptyString; + + //Write menubar to xml file + m_xmlfile.Write(_T("\t\n")); + + while ((token!=_T("BEGIN"))&(token!=_T("{"))) + token=GetToken(); + + while ((token!=_T("END"))&(token!=_T("}"))) + { + token=GetToken(); + token.MakeUpper(); + + if (token==_T("POPUP")) + { + ParsePopupMenu(); + } + } + m_xmlfile.Write(_T("\t\n")); } -void wxRC2XML::ParsePopupMenu() +void rc2xml::ParsePopupMenu() { -static menucount=0; -menucount++; -wxString token,name,msg,longhelp,tip; -token=GetQuoteField(); -int spot; -//Remove /t because it causes problems + static int menucount=0; + menucount++; + wxString token,name,msg,longhelp,tip; + token=GetQuoteField(); + +//Remove \t because it causes problems -spot=token.First("\\t"); -token=token.Left(spot); +//spot=token.First("\\t"); +//token=token.Left(spot); //Write Menu item //Generate a fake name since RC menus don't have one -name<<"Menu_"<\n"); -WriteLabel(token); -m_xmlfile.Write(" \n"); - -while ((token!="BEGIN")&(token!="{")) - token=GetToken(); - -while ((token!="END")&(token!="}")) - { - token=GetToken(); - - if (token=="POPUP") - ParsePopupMenu(); - - if (token=="MENUITEM") - ParseMenuItem(); - - } -m_xmlfile.Write(" \n"); -m_xmlfile.Write(" \n"); + name << _T("Menu_") << menucount; + m_xmlfile.Write(_T("\t\t\n")); + WriteLabel(token); + + while ((token!=_T("BEGIN"))&(token!=_T("{"))) + token=GetToken(); + + while ((token!=_T("END"))&(token!=_T("}"))) + { + token=GetToken(); + token.MakeUpper(); + + if (token==_T("POPUP")) + ParsePopupMenu(); + + if (token==_T("MENUITEM")) + ParseMenuItem(); + } + m_xmlfile.Write(_T("\t\t\t\n")); } -wxString wxRC2XML::PeekToken() +wxString rc2xml::PeekToken() { -wxString token; -int p; -p=m_rc.Tell(); -token=GetToken(); + wxFileOffset p = m_rc.Tell(); + wxString token=GetToken(); -m_rc.Seek(p); -return token; + m_rc.Seek(p); + return token; } + //MS Windows pain in the butt CONTROL -void wxRC2XML::ParseControlMS() +void rc2xml::ParseControlMS() { -wxString label,varname,kindctrl,token; -token=PeekToken(); - -if (token.Contains("\"")) - ParseNormalMSControl(); -else - ParseWeirdMSControl(); + wxString token = PeekToken(); + if (token.Contains(_T("\""))) + ParseNormalMSControl(); + else + ParseWeirdMSControl(); } -/* CONTROL "Slider1",IDC_SLIDER1,"msctls_trackbar32",TBS_BOTH | +/* CONTROL "Slider1",IDC_SLIDER1,"msctls_trackbar32",TBS_BOTH | TBS_NOTICKS | WS_TABSTOP,52,73,100,15 */ -void wxRC2XML::ParseSlider(wxString label, wxString varname) +void rc2xml::ParseSlider(wxString WXUNUSED(label), wxString varname) { -wxString token; -while (ReadOrs(token)); -//TODO Handle styles -//fprintf(m_wxrfile," control = [%i,wxSlider,'','wxSL_HORIZONTAL','%s',",m_controlid,varname); -int x,y,width,height; -ReadRect(x,y,width,height); -m_xmlfile.Write(" \n"); + wxString token,style; + ReadOrs(token); + if (token.Find(_T("TBS_VERT"))!=wxNOT_FOUND) + style+=_T("wxSL_VERTICAL"); + //MFC RC Default is horizontal + else + style+=_T("wxSL_HORIZONTAL"); + + int x,y,width,height; + ReadRect(x,y,width,height); + m_xmlfile.Write(_T("\t\t\n")); } -/* +/* CONTROL "Progress1",CG_IDC_PROGDLG_PROGRESS,"msctls_progress32", WS_BORDER,15,52,154,13 */ -void wxRC2XML::ParseProgressBar(wxString label, wxString varname) +void rc2xml::ParseProgressBar(wxString WXUNUSED(label), wxString varname) { -wxString token; -while (ReadOrs(token)); -int x,y,width,height; -ReadRect(x,y,width,height); -wxString style; -//Always horizontal in MFC -style+="wxGA_HORIZONTAL"; -m_xmlfile.Write(" \n"); -} + wxString token,style; + ReadOrs(token); -/* FIXME: this function needs to be rewritten */ -bool wxRC2XML::ReadOrs(wxString & w) -{ -wxString token; -token=PeekToken(); + int x,y,width,height; + ReadRect(x,y,width,height); -if (token.IsNumber()) - return FALSE; - -w=GetToken(); -return TRUE; +//Always horizontal in MFC + m_xmlfile.Write(_T("\t\t\n")); } -//Is it a check button or a radio button -void wxRC2XML::ParseCtrlButton(wxString label, wxString varname) +bool rc2xml::ReadOrs(wxString & orstring) { -wxString token; - token=GetToken(); - int x,y,width,height; - -if (token=="BS_AUTOCHECKBOX") - { - while (ReadOrs(token)); - ReadRect(x,y,width,height); - m_xmlfile.Write(" \n"); - } - -if (token=="BS_AUTORADIOBUTTON") - { - while(ReadOrs(token)); - ReadRect(x,y,width,height); - m_xmlfile.Write(" \n"); + wxString token; + + token=PeekToken(); + if (token.IsNumber()) + return false; + orstring=GetToken(); + + while(PeekToken()==_T("|")) + { + //Grab | + orstring+=GetToken(); + //Grab next token + orstring+=GetToken(); } - - - + return true; } +//Is it a checkbutton or a radiobutton or a pushbutton or a groupbox +void rc2xml::ParseCtrlButton(wxString label, wxString varname) +{ + wxString token; + wxFileOffset p = m_rc.Tell(); + ReadOrs(token); + m_rc.Seek(p); + + if (token.Find(_T("BS_AUTOCHECKBOX"))!=wxNOT_FOUND) + ParseCheckBox(label, varname); + else if ((token.Find(_T("BS_AUTORADIOBUTTON"))!=wxNOT_FOUND)|| + (token.Find(_T("BS_RADIOBUTTON"))!=wxNOT_FOUND)) + ParseRadioButton(label, varname); + else if (token.Find(_T("BS_GROUPBOX"))!=wxNOT_FOUND) + ParseGroupBox(label, varname); + else // if ((token.Find("BS_PUSHBUTTON")!=wxNOT_FOUND)|| +// (token.Find("BS_DEFPUSHBUTTON")!=wxNOT_FOUND)) + ParsePushButton(label, varname); // make default case +} -void wxRC2XML::WriteSize(int width, int height) +void rc2xml::WriteSize(int width, int height) { -wxString msg; -msg<<" "<"; -m_xmlfile.Write(msg); + wxString msg; + msg << _T(" ") << width << _T(",") << height << _T("d"); + m_xmlfile.Write(msg); } -void wxRC2XML::WritePosition(int x, int y) +void rc2xml::WritePosition(int x, int y) { -wxString msg; -msg<<" "<"; -m_xmlfile.Write(msg); + wxString msg; + msg << _T(" ") << x << _T(",") << y << _T("d"); + m_xmlfile.Write(msg); } -void wxRC2XML::WriteTitle(wxString title) +void rc2xml::WriteTitle(wxString title) { -wxString msg; -msg=_T(" "+title+"\n"); -m_xmlfile.Write(msg); + wxString msg; + msg=_T("\t\t")+title+_T("\n"); + m_xmlfile.Write(msg); } -void wxRC2XML::WriteName(wxString name) +void rc2xml::WriteName(wxString name) { - -//Replace common MS ids with wxWindows ids + +//Try to convert any number ids into names +name=LookUpId(name); +//Replace common MS ids with wxWidgets ids //I didn't do everyone of them -if (name=="IDOK") - name="wxID_OK"; -else if (name=="IDCANCEL") - name="wxID_CANCEL"; -else if (name=="IDAPPLY") - name="wxID_APPLY"; -else if (name=="ID_FILE_OPEN") - name="wxID_OPEN"; -else if (name=="ID_FILE_CLOSE") - name="wxID_CLOSE"; -else if (name=="ID_FILE_SAVE") - name="wxID_SAVE"; -else if (name=="ID_FILE_SAVE_AS") - name="wxID_SAVEAS"; -else if (name=="ID_APP_EXIT") - name="wxID_EXIT"; -else if (name=="ID_FILE_PRINT") - name="wxID_PRINT"; -else if (name=="ID_FILE_PRINT_PREVIEW") - name="wxID_PREVIEW"; -else if (name=="ID_FILE_PRINT_SETUP") - name="wxID_PRINT_SETUP"; -else if (name=="ID_APP_ABOUT") - name="wxID_ABOUT"; -else if (name=="ID_EDIT_UNDO") - name="wxID_UNDO"; -else if (name=="ID_EDIT_CUT") - name="wxID_CUT"; -else if (name=="ID_EDIT_COPY") - name="wxID_COPY"; -else if (name=="ID_EDIT_PASTE") - name="wxID_PASTE"; - -m_xmlfile.Write(" name= \""+name+"\""); + if (name==_T("IDOK")) + name=_T("wxID_OK"); + else if (name==_T("IDCANCEL")) + name=_T("wxID_CANCEL"); + else if (name==_T("IDAPPLY")) + name=_T("wxID_APPLY"); + else if (name==_T("ID_FILE_OPEN")) + name=_T("wxID_OPEN"); + else if (name==_T("ID_FILE_CLOSE")) + name=_T("wxID_CLOSE"); + else if (name==_T("ID_FILE_SAVE")) + name=_T("wxID_SAVE"); + else if (name==_T("ID_FILE_SAVE_AS")) + name=_T("wxID_SAVEAS"); + else if (name==_T("ID_APP_EXIT")) + name=_T("wxID_EXIT"); + else if (name==_T("ID_FILE_PRINT")) + name=_T("wxID_PRINT"); + else if (name==_T("ID_FILE_PRINT_PREVIEW")) + name=_T("wxID_PREVIEW"); + else if (name==_T("ID_FILE_PRINT_SETUP")) + name=_T("wxID_PRINT_SETUP"); + else if (name==_T("ID_APP_ABOUT")) + name=_T("wxID_ABOUT"); + else if (name==_T("ID_EDIT_UNDO")) + name=_T("wxID_UNDO"); + else if (name==_T("ID_EDIT_CUT")) + name=_T("wxID_CUT"); + else if (name==_T("ID_EDIT_COPY")) + name=_T("wxID_COPY"); + else if (name==_T("ID_EDIT_PASTE")) + name=_T("wxID_PASTE"); + else if (name==_T("IDYES")) + name=_T("wxID_YES"); + else if (name==_T("IDNO")) + name=_T("wxID_NO"); + else if (name==_T("IDHELP")) + name=_T("wxID_HELP"); + + m_xmlfile.Write(_T(" name= \"")+name+_T("\"")); } -void wxRC2XML::WriteLabel(wxString label) +void rc2xml::WriteLabel(wxString label) { -label.Replace("&","$"); -m_xmlfile.Write(" \n"); + label.Replace(_T("&"),_T("$")); + // changes by MS, handle '<' '>' characters within a label. + label.Replace(_T("<"),_T("<")); + label.Replace(_T(">"),_T(">")); + m_xmlfile.Write(_T("\t\t\t\n")); } -void wxRC2XML::WriteBasicInfo(int x, int y, int width, int height, wxString name) +void rc2xml::WriteBasicInfo(int x, int y, int width, int height, wxString name) { -WriteName(name); -m_xmlfile.Write(">\n"); -m_xmlfile.Write(" "); -WritePosition(x,y); -WriteSize(width,height); -m_xmlfile.Write("\n"); - + WriteName(name); + m_xmlfile.Write(_T(">\n")); + m_xmlfile.Write(_T("\t\t\t")); + WritePosition(x,y); + WriteSize(width,height); + m_xmlfile.Write(_T("\n")); } -void wxRC2XML::WriteStyle(wxString style) +void rc2xml::WriteStyle(wxString style) { -if (style.Length()==0) - return; -m_xmlfile.Write("\n \n"); + if (style.Length()==0) + return; + m_xmlfile.Write(_T("\t\t\t\n")); } /* - LISTBOX IDC_LIST1,16,89,48,40,LBS_SORT | LBS_MULTIPLESEL | + LISTBOX IDC_LIST1,16,89,48,40,LBS_SORT | LBS_MULTIPLESEL | LBS_NOINTEGRALHEIGHT | WS_VSCROLL | WS_TABSTOP */ -void wxRC2XML::ParseListBox() +void rc2xml::ParseListBox(wxString varname) { -wxString token; -wxString varname; - -varname=GetToken(); -int x,y,width,height; -ReadRect(x,y,width,height); - -m_xmlfile.Write(" \n"); + wxString token; + token=PeekToken(); + while (!token.IsNumber()) + { + token=GetToken(); + token=PeekToken(); + } + int x,y,width,height; + ReadRect(x,y,width,height); + + m_xmlfile.Write(_T("\t\t\n")); } /* - CONTROL "",IDC_RICHEDIT1,"RICHEDIT",ES_AUTOHSCROLL | WS_BORDER | + CONTROL "",IDC_RICHEDIT1,"RICHEDIT",ES_AUTOHSCROLL | WS_BORDER | WS_TABSTOP,103,110,40,14 */ -void wxRC2XML::ParseRichEdit(wxString label, wxString varname) +void rc2xml::ParseRichEdit(wxString WXUNUSED(label), wxString varname) { -wxString token; -while (ReadOrs(token)); -int x,y,width,height; -ReadRect(x,y,width,height); -wxString style; + wxString token; + //while (ReadOrs(token)); + ReadOrs(token); + int x,y,width,height; + ReadRect(x,y,width,height); + wxString style; //Make it a rich text control -style+="wxTE_MULTILINE "; -m_xmlfile.Write(" \n"); + style+=_T("wxTE_MULTILINE "); + m_xmlfile.Write(_T("\t\t\n")); } /* CONTROL "Spin1",IDC_SPIN1,"msctls_updown32",UDS_ARROWKEYS,209,72, 19,26 */ -void wxRC2XML::ParseSpinCtrl(wxString label, wxString varname) +void rc2xml::ParseSpinCtrl(wxString WXUNUSED(label), wxString varname) { -wxString token; -while (ReadOrs(token)); -int x,y,width,height; -ReadRect(x,y,width,height); -wxString style; -m_xmlfile.Write(" \n"); - + wxString token,style; + + ReadOrs(token); + if (token.Find(_T("UDS_HORZ"))!=wxNOT_FOUND) + style=_T("wxSP_HORIZONTAL"); + //MFC default + else + style=_T("wxSP_VERTICAL"); + + int x,y,width,height; + ReadRect(x,y,width,height); + m_xmlfile.Write(_T("\t\t\n")); } -void wxRC2XML::FirstPass() +void rc2xml::FirstPass() { -wxString token,prevtok; -while (!m_done) - { - token=GetToken(); - if (token=="BITMAP") - ParseBitmap(prevtok); - else if (token=="STRINGTABLE") - ParseStringTable(prevtok); - else if (token=="ICON") - ParseIcon(prevtok); - prevtok=token; - } + wxString token,prevtok; + while (!m_done) + { + token=GetToken(); + if (token==_T("BITMAP")) + ParseBitmap(prevtok); + else if (token==_T("STRINGTABLE")) + ParseStringTable(prevtok); + else if (token==_T("ICON")) + ParseIcon(prevtok); + + prevtok=token; + } } -void wxRC2XML::ParseBitmap(wxString varname) +void rc2xml::ParseBitmap(wxString varname) { -wxString token,*bitmapfile; -bitmapfile=new wxString; -token=PeekToken(); -//Microsoft notation? -if (token=="DISCARDABLE") - { - token=GetToken(); - token=PeekToken(); - } - -*bitmapfile=GetQuoteField(); -m_bitmaplist->Append(varname,bitmapfile); + wxString token; + wxString *bitmapfile; + + token=PeekToken(); + //Microsoft notation? + if (token==_T("DISCARDABLE")) + { + token=GetToken(); + token=PeekToken(); + } + bitmapfile=new wxString; + *bitmapfile=GetQuoteField(); + m_bitmaplist->Append(varname,bitmapfile); } -void wxRC2XML::SecondPass() +void rc2xml::SecondPass() { -wxString token,prevtok; -while (!m_done) - { - token=GetToken(); - if (token=="DIALOG") - ParseDialog(prevtok); - else if (token=="MENU") - ParseMenu(prevtok); - else if (token=="TOOLBAR") - ParseToolBar(prevtok); - prevtok=token; - } + wxString token,prevtok; + while (!m_done) + { + token=GetToken(); + if ((token==_T("DIALOG"))||(token==_T("DIALOGEX"))) + ParseDialog(prevtok); + else if (token==_T("MENU")) + ParseMenu(prevtok); + else if (token==_T("TOOLBAR")) + ParseToolBar(prevtok); + + prevtok=token; + } } -void wxRC2XML::ParseToolBar(wxString varname) +void rc2xml::ParseToolBar(wxString varname) { -wxString token; -token=GetToken(); -wxASSERT_MSG(token=="DISCARDABLE","Error in toolbar parsing"); - + wxString token; + token=GetToken(); + wxASSERT_MSG(token==_T("DISCARDABLE"),_T("Error in toolbar parsing")); //Look up bitmap for toolbar and load -wxNode *node=m_bitmaplist->Find(varname); -wxString *bitmappath; -bitmappath=(wxString *)node->Data(); -wxBitmap bitmap; -if (!bitmap.LoadFile(*bitmappath,wxBITMAP_TYPE_BMP )) - wxLogError("Unable to load bitmap:"+*bitmappath); + wxNode *node=m_bitmaplist->Find(LookUpId(varname)); + wxString *bitmappath; + bitmappath=(wxString *)node->GetData(); + wxBitmap bitmap; + if (!bitmap.LoadFile(*bitmappath,wxBITMAP_TYPE_BMP )) + wxLogError(_T("Unable to load bitmap:")+*bitmappath); //Write toolbar to xml file -m_xmlfile.Write(" \n"); -wxString style; -style+="wxTB_FLAT"; -WriteStyle(style); + varname.Replace(_T("IDR_"),_T("TB_")); + WriteName(varname); + m_xmlfile.Write(_T(">\n")); + wxString style; + style+=_T("wxTB_FLAT"); + WriteStyle(style); -m_xmlfile.Write(" \n"); //Grab width and height -int width,height; -width=atoi(GetToken()); -height=atoi(GetToken()); - -int c=0; -wxString buttonname,msg,tip,longhelp; -token=GetToken(); -while ((token!="BEGIN")) - token=GetToken(); - -while ((token!="END")&(token!="}")) - { - if (token=="BUTTON") - { - buttonname=GetToken(); - m_xmlfile.Write(" \n"); - //Write tool tip if any - if (LookUpString(buttonname,msg)) - { - SplitHelp(msg,tip,longhelp); - m_xmlfile.Write(" "+tip+"\n"); - m_xmlfile.Write(" "+longhelp+"\n"); - } - //Make a bitmap file name - buttonname=CleanName(buttonname); - buttonname+=".bmp"; - m_xmlfile.Write(" "+buttonname+"\n"); - WriteToolButton(buttonname,c,width,height,bitmap); - m_xmlfile.Write(" \n"); - c++; - } - else if (token=="SEPARATOR") - { - m_xmlfile.Write(" \n"); - } - token=GetToken(); - } -m_xmlfile.Write(" \n"); -m_xmlfile.Write(" \n"); + int width,height; + width=wxAtoi(GetToken()); + height=wxAtoi(GetToken()); + + int c=0; + wxString buttonname,msg,tip,longhelp; + token=GetToken(); + while ((token!=_T("BEGIN"))&(token!=_T("{"))) + token=GetToken(); + + while ((token!=_T("END"))&(token!=_T("}"))) + { + if (token==_T("BUTTON")) + { + buttonname=GetToken(); + m_xmlfile.Write(_T("\t\t\t\n")); + //Write tool tip if any + if (LookUpString(buttonname,msg)) + { + SplitHelp(msg,tip,longhelp); + m_xmlfile.Write(_T("\t\t\t\t")+tip+_T("\n")); + m_xmlfile.Write(_T("\t\t")+longhelp+_T("\n")); + } + //Make a bitmap file name + buttonname=CleanName(buttonname); + buttonname+=_T(".bmp"); + m_xmlfile.Write(_T("\t\t\t\t")+buttonname+_T("\n")); + WriteToolButton(buttonname,c,width,height,bitmap); + m_xmlfile.Write(_T("\t\t\t\n")); + c++; + } + else if (token==_T("SEPARATOR")) + { + m_xmlfile.Write(_T("\t\t\t\n")); + } + token=GetToken(); + } + m_xmlfile.Write(_T("\t\n")); } //Extract bitmaps from larger toolbar bitmap -void wxRC2XML::WriteToolButton(wxString name,int index, int width, int height, wxBitmap bitmap) +void rc2xml::WriteToolButton(wxString name,int index, int width, int height, wxBitmap bitmap) { -int x; -x=index*width; -wxRect r(x,0,width,height); -wxBitmap little; - -little=bitmap.GetSubBitmap(r); -little.SaveFile(name,wxBITMAP_TYPE_BMP); + int x; + x=index*width; + wxRect r(x,0,width,height); + wxBitmap little; + little=bitmap.GetSubBitmap(r); + little.SaveFile(m_targetpath+name,wxBITMAP_TYPE_BMP); } -void wxRC2XML::ParseStringTable(wxString varname) +void rc2xml::ParseStringTable(wxString WXUNUSED(varname)) { -wxString token; -token=GetToken(); -while ((token!="BEGIN")) - token=GetToken(); -token=GetToken(); -wxString *msg; - -while ((token!="END")&(token!="}")) - { - msg=new wxString; - *msg=GetQuoteField(); - m_stringtable->Append(token,msg); - token=GetToken(); - } - + wxString token; + token=GetToken(); + while ((token!=_T("BEGIN"))&(token!=_T("{"))) + token=GetToken(); + token=GetToken(); + wxString *msg; + + while ((token!=_T("END"))&(token!=_T("}"))) + { + msg=new wxString; + *msg=GetStringQuote(); + m_stringtable->Append(token,msg); + token=GetToken(); + } } -bool wxRC2XML::LookUpString(wxString strid,wxString & st) +bool rc2xml::LookUpString(wxString strid,wxString & st) { -wxNode *node=m_stringtable->Find(strid); -wxString *s; -if (node==NULL) - return FALSE; + wxNode *node=m_stringtable->Find(strid); + wxString *s; + if (node==NULL) + return false; -s=(wxString *)node->Data(); -st=*s; + s=(wxString *)node->GetData(); + st=*s; -return TRUE; + return true; } -bool wxRC2XML::SplitHelp(wxString msg, wxString &shorthelp, wxString &longhelp) +bool rc2xml::SplitHelp(wxString msg, wxString &shorthelp, wxString &longhelp) { -int spot; -spot=msg.Find("\\n"); -if (spot==-1) - { - shorthelp=msg; - longhelp=msg; - } - -longhelp=msg.Left(spot); -spot=msg.Length()-spot-2; -shorthelp=msg.Right(spot); -return TRUE; + int spot; + spot=msg.Find(_T("\\n")); + if (spot==wxNOT_FOUND) + { + shorthelp=msg; + longhelp=msg; + } + + longhelp=msg.Left(spot); + spot=msg.Length()-spot-2; + shorthelp=msg.Right(spot); + return true; } -void wxRC2XML::ParseMenuItem() +void rc2xml::ParseMenuItem() { -wxString token,name,msg,tip,longhelp; -int spot; -if (PeekToken()=="SEPARATOR") - { - m_xmlfile.Write(" \n"); - return; - } - -token=GetQuoteField(); -name=GetToken(); -//Remove /t because it causes problems -spot=token.First("\\t"); -token=token.Left(spot); -m_xmlfile.Write(" \n"); -WriteLabel(token); + wxString token,name,msg,tip,longhelp; +//int spot; + if (PeekToken()==_T("SEPARATOR")) + { + m_xmlfile.Write(_T("\t\t\t\n")); + return; + } + + token=GetQuoteField(); + name=GetToken(); +//Remove \t because it causes problems +//spot=token.First("\\t"); +//token=token.Left(spot); + m_xmlfile.Write(_T("\t\t\t\n")); + WriteLabel(token); //Look up help if any listed in stringtable -if (LookUpString(name,msg)) - { - SplitHelp(msg,tip,longhelp); - m_xmlfile.Write(" " - +longhelp+"\n"); - } +//can't assume numbers correlate, restrict to string identifiers + if ((!name.IsNumber())&&(LookUpString(name,msg))) + { + SplitHelp(msg,tip,longhelp); + m_xmlfile.Write(_T("\t\t\t") + +longhelp+_T("\n")); + } //look for extra attributes like checked and break -wxString ptoken; -ptoken=PeekToken(); -while ((ptoken!="MENUITEM")&(ptoken!="POPUP")&(ptoken!="END")) - { - token=GetToken(); - if (token=="CHECKED") - m_xmlfile.Write(" 1\n"); - else if (token=="MENUBREAK"); - //m_xmlfile.Write(" \n"); - else if (token=="GRAYED"); - else - wxLogError("Unknown Menu Item token:"+token); - ptoken=PeekToken(); - } -m_xmlfile.Write(" \n"); + wxString ptoken; + ptoken=PeekToken(); + ptoken.MakeUpper(); + while ((ptoken!=_T("MENUITEM"))&(ptoken!=_T("POPUP"))&(ptoken!=_T("END"))) + { + token=GetToken(); + ptoken.MakeUpper(); + if (token==_T("CHECKED")) + m_xmlfile.Write(_T("\t\t\t1\n")); + else if (token==_T("MENUBREAK")) + ; +//m_xmlfile.Write("\t\t\t\n"); + else if (token==_T("GRAYED")) + ; + else + wxLogError(_T("Unknown Menu Item token:")+token); + + ptoken=PeekToken(); + ptoken.MakeUpper(); + } + m_xmlfile.Write(_T("\t\t\t\n")); } //ICON IDR_MAINFRAME,IDC_STATIC,11,17,20,20 -void wxRC2XML::ParseIconStatic() +void rc2xml::ParseIconStatic() { -wxString token; -wxString varname,iconname; -iconname=GetToken(); + wxString token; + wxString varname,iconname; + token = PeekToken(); + if (token.Contains(_T("\""))) + iconname = GetQuoteField(); + else + iconname=GetToken(); //Look up icon -wxNode *node=m_iconlist->Find(iconname); -wxString *iconpath; -iconpath=(wxString *)node->Data(); -wxIcon icon; -wxBitmap bitmap; -if (!icon.LoadFile(*iconpath,wxBITMAP_TYPE_ICO )) - wxLogError("Unable to load icon:"+*iconpath); -bitmap.CopyFromIcon(icon); -varname=GetToken(); - -int x,y,width,height; -ReadRect(x,y,width,height); - -m_xmlfile.Write(" "+iconname+"\n"); -bitmap.SaveFile(iconname,wxBITMAP_TYPE_BMP); -m_xmlfile.Write(" \n"); + WriteIcon(iconname); + m_xmlfile.Write(_T("\t\t\n")); } //IDR_MAINFRAME ICON DISCARDABLE "res\\mfcexample.ico" -void wxRC2XML::ParseIcon(wxString varname) +void rc2xml::ParseIcon(wxString varname) { -wxString token,*iconfile; -iconfile=new wxString; -token=PeekToken(); + wxString token; + wxString *iconfile; + iconfile=new wxString; + token=PeekToken(); + + *iconfile=GetQuoteField(); + m_iconlist->Append(varname,iconfile); -*iconfile=GetQuoteField(); -m_iconlist->Append(varname,iconfile); } -wxString wxRC2XML::CleanName(wxString name) +wxString rc2xml::CleanName(wxString name) { -name.MakeLower(); -name.Replace("id_",""); -name.Replace("idr_",""); -name.Replace("idb_",""); -name.Replace("idc_",""); -return name; + name.MakeLower(); + name.Replace(_T("id_"),wxEmptyString); + name.Replace(_T("idr_"),wxEmptyString); + name.Replace(_T("idb_"),wxEmptyString); + name.Replace(_T("idc_"),wxEmptyString); + + name.Replace(_T(".ico"),wxEmptyString); + + name.Replace(_T(".bmp"),wxEmptyString); + return name; } // And the award for most messed up control goes to... // CONTROL IDB_FACE,IDC_STATIC,"Static",SS_BITMAP,26,62,32,30 -void wxRC2XML::ParseStaticBitmap(wxString bitmapname, wxString varname) +void rc2xml::ParseStaticBitmap(wxString bitmapname, wxString varname) { -wxString token; -//Grab SS_BITMAP -token=GetToken(); + wxString token; + //Grab SS_BITMAP + ReadOrs(token); -//Look up bitmap -wxNode *node=m_bitmaplist->Find(bitmapname); -wxString *bitmappath; -bitmappath=(wxString *)node->Data(); -wxBitmap bitmap; -if (!bitmap.LoadFile(*bitmappath,wxBITMAP_TYPE_BMP )) - wxLogError("Unable to load bitmap:"+*bitmappath); - -int x,y,width,height; -ReadRect(x,y,width,height); - -m_xmlfile.Write(" "+bitmapname+"\n"); -bitmap.SaveFile(bitmapname,wxBITMAP_TYPE_BMP); -m_xmlfile.Write(" \n"); + int x,y,width,height; + ReadRect(x,y,width,height); + + m_xmlfile.Write(_T("\t\t\n")); } -void wxRC2XML::ParseNormalMSControl() +void rc2xml::ParseNormalMSControl() { -wxString label,varname,kindctrl; - -label=GetQuoteField(); -varname=GetToken(); -kindctrl=GetQuoteField(); -kindctrl.MakeUpper(); - -if (kindctrl=="MSCTLS_UPDOWN32") - ParseSpinCtrl(label,varname); -if (kindctrl=="MSCTLS_TRACKBAR32") - ParseSlider(label,varname); -if (kindctrl=="MSCTLS_PROGRESS32") - ParseProgressBar(label,varname); -if (kindctrl=="SYSTREEVIEW32") - ParseTreeCtrl(label,varname); -if (kindctrl=="SYSMONTHCAL32") - ParseCalendar(label,varname); -if (kindctrl=="SYSLISTVIEW32") - ParseListCtrl(label,varname); -if (kindctrl=="BUTTON") - ParseCtrlButton(label,varname); -if (kindctrl=="RICHEDIT") - ParseRichEdit(label,varname); - + wxString label=GetQuoteField(); + wxString varname=GetToken(); + wxString kindctrl=GetQuoteField(); + kindctrl.MakeUpper(); + + if (kindctrl==_T("MSCTLS_UPDOWN32")) + ParseSpinCtrl(label,varname); + else if (kindctrl==_T("MSCTLS_TRACKBAR32")) + ParseSlider(label,varname); + else if (kindctrl==_T("MSCTLS_PROGRESS32")) + ParseProgressBar(label,varname); + else if (kindctrl==_T("SYSTREEVIEW32")) + ParseTreeCtrl(label,varname); + else if (kindctrl==_T("SYSMONTHCAL32")) + ParseCalendar(label,varname); + else if (kindctrl==_T("SYSLISTVIEW32")) + ParseListCtrl(label,varname); + else if (kindctrl==_T("BUTTON")) + ParseCtrlButton(label,varname); + else if (kindctrl==_T("RICHEDIT")) + ParseRichEdit(label,varname); + else if (kindctrl==_T("STATIC")) + { + wxString token; + wxFileOffset p = m_rc.Tell(); + ReadOrs(token); + m_rc.Seek(p); + if (token.Find(_T("SS_BITMAP"))!=wxNOT_FOUND) + ParseStaticBitmap(label,varname); + else + ParseStaticText(label,varname); + } + else if (kindctrl==_T("EDIT")) + ParseTextCtrl(varname); + else if (kindctrl==_T("LISTBOX")) + ParseListBox(varname); + else if (kindctrl==_T("COMBOBOX")) + ParseComboBox(varname); } -void wxRC2XML::ParseWeirdMSControl() +void rc2xml::ParseWeirdMSControl() { -wxString kindctrl; -wxString varname; -wxString id; -id=GetToken(); -varname=GetToken(); -kindctrl=GetQuoteField(); -kindctrl.MakeUpper(); + wxString id = GetToken(); + wxString varname = GetToken(); + wxString kindctrl = GetQuoteField(); + kindctrl.MakeUpper(); // CONTROL IDB_FACE,IDC_STATIC,"Static",SS_BITMAP,26,62,32,30 -if (kindctrl=="STATIC") - { - if (PeekToken()=="SS_BITMAP") - ParseStaticBitmap(id,varname); - else - wxLogError("Unknown MS Control Static token"); - } - + if (kindctrl==_T("STATIC")) + { + if (PeekToken()==_T("SS_BITMAP")) + ParseStaticBitmap(id,varname); + else + wxLogError(_T("Unknown MS Control Static token")); + } } -//SCROLLBAR IDC_SCROLLBAR1,219,56,10,40,SBS_VERT -void wxRC2XML::ParseScrollBar() +//SCROLLBAR IDC_SCROLLBAR1,219,56,10,40,SBS_VERT +void rc2xml::ParseScrollBar() { -wxString token; -wxString varname; + wxString token; + wxString varname; + + varname=GetToken(); + int x,y,width,height; + ReadRect(x,y,width,height); + wxString style; -varname=GetToken(); -int x,y,width,height; -ReadRect(x,y,width,height); -wxString style; + ReadOrs(token); + +if (token.Find(_T("SBS_VERT"))!=wxNOT_FOUND) + style=_T("wxSB_VERTICAL"); //Default MFC style is horizontal -style=_T("wxSB_HORIZONTAL"); -/* -while (ReadOrs(token)) -{ -if (token=="SBS_VERT") - style=_T("wxSB_VERTICAL"); -} -*/ -m_xmlfile.Write(" \n"); + else + style=_T("wxSB_HORIZONTAL"); + m_xmlfile.Write(_T("\t\t\n")); } // CONTROL "Tree1",IDC_TREE1,"SysTreeView32",WS_BORDER | WS_TABSTOP, // 7,7,66,61 -void wxRC2XML::ParseTreeCtrl(wxString label, wxString varname) +void rc2xml::ParseTreeCtrl(wxString WXUNUSED(label), wxString varname) { -wxString token; -while (ReadOrs(token)); -int x,y,width,height; -ReadRect(x,y,width,height); -m_xmlfile.Write(" \n"); + wxString token; +//while (ReadOrs(token)); + ReadOrs(token); + int x,y,width,height; + ReadRect(x,y,width,height); + m_xmlfile.Write(_T("\t\t\n")); } // CONTROL "MonthCalendar1",IDC_MONTHCALENDAR1,"SysMonthCal32", //MCS_NOTODAY | WS_TABSTOP,105,71,129,89 -void wxRC2XML::ParseCalendar(wxString label, wxString varname) +void rc2xml::ParseCalendar(wxString WXUNUSED(label), wxString varname) { -wxString token; -while (ReadOrs(token)); -int x,y,width,height; -ReadRect(x,y,width,height); -m_xmlfile.Write(" \n"); + wxString token; +//while (ReadOrs(token)); + ReadOrs(token); + int x,y,width,height; + ReadRect(x,y,width,height); + m_xmlfile.Write(_T("\t\t\n")); } // CONTROL "List1",IDC_LIST1,"SysListView32",WS_BORDER | WS_TABSTOP, // 7,89,68,71 -void wxRC2XML::ParseListCtrl(wxString label, wxString varname) +void rc2xml::ParseListCtrl(wxString WXUNUSED(label), wxString varname) { -wxString token; -while (ReadOrs(token)); -int x,y,width,height; -ReadRect(x,y,width,height); -m_xmlfile.Write(" \n"); + wxString token; + //while (ReadOrs(token)); + ReadOrs(token); + int x,y,width,height; + ReadRect(x,y,width,height); + m_xmlfile.Write(_T("\t\t\n")); } + +void rc2xml::WriteBitmap(wxString bitmapname) +{ +//Look up bitmap + wxNode *node=m_bitmaplist->Find(LookUpId(bitmapname)); + if (node==NULL) + { + m_xmlfile.Write(_T("\t\t\tmissingfile\n")); + wxLogError(_T("Unable to find bitmap:")+bitmapname); + return; + } + + wxString *bitmappath; + bitmappath=(wxString *)node->GetData(); + + bitmapname=wxFileNameFromPath(*bitmappath); + wxBitmap bitmap; + if (!bitmap.LoadFile(*bitmappath,wxBITMAP_TYPE_BMP )) + wxLogError(_T("Unable to load bitmap:")+*bitmappath); + + //Make a bitmap file name + bitmapname=CleanName(bitmapname); + bitmapname+=_T(".bmp"); + m_xmlfile.Write(_T("\t\t\t")+bitmapname+_T("\n")); + bitmap.SaveFile(m_targetpath+bitmapname,wxBITMAP_TYPE_BMP); +} + +void rc2xml::WriteIcon(wxString iconname) +{ +wxNode *node=m_iconlist->Find(iconname); + if (node==NULL) + { + m_xmlfile.Write(_T("\t\t\tmissing_file\n")); + wxLogError(_T("Unable to find icon:")+iconname); + } + wxString *iconpath; + iconpath=(wxString *)node->GetData(); + wxIcon icon; + wxBitmap bitmap; + if (!icon.LoadFile(*iconpath,wxBITMAP_TYPE_ICO )) + wxLogError(_T("Unable to load icon:")+*iconpath); +#ifdef __WXMSW__ + bitmap.CopyFromIcon(icon); +#else + bitmap = icon; +#endif + iconname=wxFileNameFromPath(*iconpath); + //Make a bitmap file name + iconname=CleanName(iconname); + iconname+=_T(".bmp"); + m_xmlfile.Write(_T("\t\t\t")+iconname+_T("\n")); + bitmap.SaveFile(m_targetpath+iconname,wxBITMAP_TYPE_BMP); + + +} +/*Unfortunately sometimes the great MSVC Resource editor decides +to use numbers instead of the word id. I have no idea why they +do this, but that is the way it is. +*/ +/* this is a quick and dirty way to parse the resource.h file +it will not recognize #ifdef so it can be easily fooled +*/ +void rc2xml::ParseResourceHeader() +{ +wxTextFile r; +//Attempt to load resource.h in current path + if (!r.Open(_T("resource.h"))) + { + wxLogError(_T("Warining Unable to load resource.h file")); + return; + } + + wxString str; + wxString id,v; + wxStringTokenizer tok; + wxString *varname; + + + long n; + +//Read through entire file + for ( str = r.GetFirstLine(); !r.Eof(); str = r.GetNextLine() ) + { + if (str.Find(_T("#define"))!=wxNOT_FOUND) + { + tok.SetString(str); + //Just ignore #define token + tok.GetNextToken(); + v=tok.GetNextToken(); + id=tok.GetNextToken(); + if (id.IsNumber()) + { + varname=new wxString; + id.ToLong(&n); + *varname=v; + m_resourcelist->Append(n,varname); + } + } + } + + + +} + + +wxString rc2xml::LookUpId(wxString id) +{ +wxString st; + +if (!id.IsNumber()) + return id; +long n; +id.ToLong(&n); +wxNode *node=m_resourcelist->Find(n); + wxString *s; + if (node==NULL) + return id; + + s=(wxString *)node->GetData(); + st=*s; +return st; +}