]> git.saurik.com Git - wxWidgets.git/blobdiff - contrib/utils/convertrc/rc2wxr.cpp
added chart icon for non-MSW ports too
[wxWidgets.git] / contrib / utils / convertrc / rc2wxr.cpp
index 3c91b14a617a572b2bf9c6358b252d61be30e14a..4a44fb84c8e72573b472b28e2a88b7a04fb5ceb1 100644 (file)
-// RC2WXR.cpp: implementation of the wxRC2WXR class.
+// rc2wxr.cpp: implementation of the rc2wxr class.
 //
 //////////////////////////////////////////////////////////////////////
+//Author:  Brian Gavin 9/24/00
+//License: wxWindows License
+/*
+WARNING- I know this code has some bugs to work out but
+I don't plan to fix them since I feel that wxr files will
+not be used much longer.
+This code was used as a starting point for my rc2xml converter
+*/
+
 // For compilers that support precompilation, includes "wx/wx.h".
 #include "wx/wxprec.h"
 
-#include "rc2wxr.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 "wx/image.h"
-#include "wx/resource.h"
+#include "wx/deprecated/setup.h"
+#include "wx/deprecated/resource.h"
+
+#include "rc2wxr.h"
+
 //////////////////////////////////////////////////////////////////////
 // Construction/Destruction
 //////////////////////////////////////////////////////////////////////
 
-wxRC2WXR::wxRC2WXR()
+rc2wxr::rc2wxr()
 {
-m_done=FALSE;
-m_controlid=6000;
+    m_done=false;
+    m_controlid=6000;
 }
 
-wxRC2WXR::~wxRC2WXR()
+rc2wxr::~rc2wxr()
 {
-
 }
 
-void wxRC2WXR::Open(wxString wxrfile, wxString rcfile)
+void rc2wxr::Convert(wxString wxrfile, wxString rcfile)
 {
-    wxFileProgressDlg fileprog;
-
+    m_rc.Open(rcfile);
+    m_filesize=m_rc.Length();
+    if( (m_wxr  = wxFopen( wxrfile, _T("wt") )) == NULL )
+    {
+        return;
+    }
 
-       m_rc.Open(rcfile);
-       m_filesize=m_rc.Length();
-if( (m_wxr  = fopen( wxrfile, "wt" )) == NULL )
-{
-         return;
-}
+    wxString tok,prevtok;
 
-fileprog.Show(TRUE);
+    while (!m_done)
+    {
+        tok=GetToken();
 
-wxString tok,prevtok;
+        if (tok==_T("DIALOG"))
+        {
+            ParseDialog(prevtok);
+        }
 
+        if (tok==_T("MENU"))
+        {
+            ParseMenu(prevtok);
+        }
 
-while (!m_done)
-{
+        prevtok=tok;
+    }
 
-tok=GetToken();
+    fclose(m_wxr);
 
-if (tok=="DIALOG")
-{
-       ParseDialog(prevtok);
-       fileprog.UpdateProgress(&m_rc);
+    m_rc.Close();
 }
-       
 
-if (tok=="MENU")
-{
-       ParseMenu(prevtok);
-       fileprog.UpdateProgress(&m_rc);
-}      
 
-prevtok=tok;
-}
-fileprog.UpdateProgress(&m_rc);
-fclose(m_wxr);
-//fclose(m_rc);  
-m_rc.Close();
-
-fileprog.Show(FALSE);
-}
+/*
 
+Example .rc
 
-/*
-Example .rc 
 Microsoft style as of v5.0
+
 IDD_ABOUTBOX DIALOG DISCARDABLE  0, 0, 217, 55
+
 STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU
+
 CAPTION "About Funimator"
+
 FONT 8, "MS Sans Serif"
 
   Borland 4.5 style rc
+
 IDD_DIBATTR DIALOG 7, 16, 172, 119
+
 STYLE DS_MODALFRAME | WS_POPUP | WS_VISIBLE | WS_CAPTION | WS_SYSMENU
+
 CAPTION "DIB Attributes"
+
 FONT 8, "MS Sans Serif"
+
 {
+
  DEFPUSHBUTTON "Ok", IDOK, 114, 8, 50, 14
+
  PUSHBUTTON "Cancel", IDCANCEL, 114, 28, 50, 14
 
+*/
+
+void rc2wxr::ParseDialog(wxString dlgname)
+
+{
+
+wxString tok;
+
+static int dlgid=999;
+
+dlgid++;
+
+/* Make sure that this really is a dialog
 
+microsoft reuses the keyword DIALOG for other things
 
 */
-void wxRC2WXR::ParseDialog(wxString dlgname)
-{
-       wxString tok;
-       static int dlgid=999;
-       dlgid++;
-       /* Make sure that this really is a dialog 
-       microsoft reuses the keyword DIALOG for other things
-       */
-       tok=PeekToken();
-       //Microsoft notation?
-       if (tok=="DISCARDABLE")
-       {
-               tok=GetToken();
-               tok=PeekToken();
-       }
-       //This isn't a Dialog resource eject eject
-       if (!tok.IsNumber())
-               return;
+
+tok=PeekToken();
+
+//Microsoft notation?
+
+if (tok==_T("DISCARDABLE"))
+
+{
+
+tok=GetToken();
+
+tok=PeekToken();
+
+}
+
+//This isn't a Dialog resource eject eject
+
+if (!tok.IsNumber())
+
+    return;
+
 //Generate Dialog text
-fprintf(m_wxr,"static char *dialog%i = \"dialog(name = '%s',\\\n",dlgid,dlgname);
+
+wxFprintf(m_wxr,_T("static char *dialog%i = \"dialog(name = '%s',\\\n"),dlgid,dlgname.c_str());
+
 //be lazy about style for now. add it later
-fprintf(m_wxr,"style = 'wxRAISED_BORDER | wxCAPTION | wxTHICK_FRAME | wxSYSTEM_MENU',\\\n");
 
-fprintf(m_wxr,"id = %i,\\\n",dlgid);
+wxFprintf(m_wxr,_T("style = 'wxRAISED_BORDER | wxCAPTION | wxRESIZE_BORDER | wxSYSTEM_MENU',\\\n"));
+wxFprintf(m_wxr,_T("id = %i,\\\n"),dlgid);
 
 //Record x,y,width,height
+
 int x,y,width,height;
+
 ReadRect(x,y,width,height);
-fprintf(m_wxr,"x = %i, y = %i, width = %i, height = %i,\\\n",x,y,width,height);
+
+wxFprintf(m_wxr,_T("x = %i, y = %i, width = %i, height = %i,\\\n"),x,y,width,height);
 
 
 //CAPTION "About Funimator"
+
 //Get Title
+
 tok=GetToken();
+
 wxString title;
 
-while ((tok!="BEGIN")&(tok!="{"))
+
+
+while ((tok!=_T("BEGIN"))&(tok!=_T("{")))
+
 {
-if (tok=="CAPTION")
-       {
-       title=GetQuoteField();
-       fprintf(m_wxr,"title = '%s',\\\n",title);
-       }
+
+if (tok==_T("CAPTION"))
+
+{
+
+title=GetQuoteField();
+
+wxFprintf(m_wxr,_T("title = '%s',\\\n"),title.c_str());
+
+}
+
 tok=GetToken();
+
 }
-fprintf(m_wxr,"use_dialog_units = 1,\\\n");
-fprintf(m_wxr,"use_system_defaults = 0,\\\n");
 
-fprintf(m_wxr,"font = [8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif'],\\\n");
+wxFprintf(m_wxr,_T("use_dialog_units = 1,\\\n"));
+
+wxFprintf(m_wxr,_T("use_system_defaults = 0,\\\n"));
+
+
+
+wxFprintf(m_wxr,_T("font = [8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif'],\\\n"));
+
 ParseControls();
-fprintf(m_wxr,").\";\n\n");
+
+wxFprintf(m_wxr,_T(").\";\n\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 wxRC2WXR::ParseControls()
+
+void rc2wxr::ParseControls()
+
 {
+
 wxString tok;
 
+
+
 tok=GetToken();
-while ((tok!="END")&(tok!="}"))
+
+while ((tok!=_T("END"))&(tok!=_T("}")))
+
 {
-if (tok=="LTEXT")
+
+if (tok==_T("LTEXT"))
+
     ParseStaticText();
-if (tok=="EDITTEXT")
+
+if (tok==_T("EDITTEXT"))
+
     ParseTextCtrl();
-if (tok=="PUSHBUTTON")
+
+if (tok==_T("PUSHBUTTON"))
+
     ParsePushButton();
-if (tok=="DEFPUSHBUTTON")
+
+if (tok==_T("DEFPUSHBUTTON"))
+
     ParsePushButton();
-if (tok=="GROUPBOX")
+
+if (tok==_T("GROUPBOX"))
+
     ParseGroupBox();
-if (tok=="COMBOBOX")
+
+if (tok==_T("COMBOBOX"))
+
     ParseComboBox();
-if (tok=="CONTROL")
+
+if (tok==_T("CONTROL"))
+
     ParseControlMS();
 
+
+
 tok=GetToken();
+
 }
 
+
+
 }
+
 //LTEXT           "Radius",IDC_STATIC,9,67,23,8
-void wxRC2WXR::ParseStaticText()
+
+void rc2wxr::ParseStaticText()
+
 {
+
 wxString tok;
+
 wxString phrase,varname;
+
 phrase=GetQuoteField();
+
 varname=GetToken();
+
 m_controlid++;
+
 int x,y,width,height;
+
 ReadRect(x,y,width,height);
-fprintf(m_wxr,"  control = [%i,wxStaticText,'%s','0','%s',",m_controlid,phrase,varname);
-fprintf(m_wxr,"%i,%i,%i,%i,'',\\\n",x,y,width,height);
-fprintf(m_wxr,"[8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif']],\\\n");
+
+wxFprintf(m_wxr,_T("  control = [%i,wxStaticText,'%s','0','%s',"),m_controlid,phrase.c_str(),varname.c_str());
+
+wxFprintf(m_wxr,_T("%i,%i,%i,%i,'',\\\n"),x,y,width,height);
+
+wxFprintf(m_wxr,_T("[8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif']],\\\n"));
+
 }
+
 //EDITTEXT        IDC_RADIUS,36,65,40,14,ES_AUTOHSCROLL
-void wxRC2WXR::ParseTextCtrl()
+
+void rc2wxr::ParseTextCtrl()
+
 {
+
 wxString tok;
+
 wxString varname;
+
 varname=GetToken();
+
 m_controlid++;
+
 int x,y,width,height;
+
 ReadRect(x,y,width,height);
-fprintf(m_wxr,"  control = [%i,wxTextCtrl,'','0','%s',",m_controlid,varname);
-fprintf(m_wxr,"%i,%i,%i,%i,'',\\\n",x,y,width,height);
-fprintf(m_wxr,"[8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif']],\\\n");
+
+wxFprintf(m_wxr,_T("  control = [%i,wxTextCtrl,'','0','%s',"),m_controlid,varname.c_str());
+
+wxFprintf(m_wxr,_T("%i,%i,%i,%i,'',\\\n"),x,y,width,height);
+
+wxFprintf(m_wxr,_T("[8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif']],\\\n"));
+
+
 
 }
+
 //PUSHBUTTON      "Create/Update",IDC_CREATE,15,25,53,13,NOT WS_TABSTOP
-void wxRC2WXR::ParsePushButton()
+
+void rc2wxr::ParsePushButton()
+
 {
+
 wxString tok;
+
 wxString phrase,varname;
+
 phrase=GetQuoteField();
+
 varname=GetToken();
+
 int c;
+
 m_controlid++;
+
 c=m_controlid;
-if (varname=="IDOK")
+
+if (varname==_T("IDOK"))
+
 c=wxID_OK;
 
-if (varname=="IDCANCEL")
+
+
+if (varname==_T("IDCANCEL"))
+
 c=wxID_CANCEL;
 
-if (varname=="IDAPPLY")
+
+
+if (varname==_T("IDAPPLY"))
+
 c=wxID_APPLY;
 
+
+
 int x,y,width,height;
+
 ReadRect(x,y,width,height);
-fprintf(m_wxr,"  control = [%i,wxButton,'%s','0','%s',",c,phrase,varname);
-fprintf(m_wxr,"%i,%i,%i,%i,'',\\\n",x,y,width,height);
-fprintf(m_wxr,"[8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif']],\\\n");
+
+wxFprintf(m_wxr,_T("  control = [%i,wxButton,'%s','0','%s',"),c,phrase.c_str(),varname.c_str());
+
+wxFprintf(m_wxr,_T("%i,%i,%i,%i,'',\\\n"),x,y,width,height);
+
+wxFprintf(m_wxr,_T("[8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif']],\\\n"));
+
+
 
 }
 
 
-bool wxRC2WXR::Seperator(int ch)
+
+
+
+bool rc2wxr::Separator(int ch)
+
 {
+
 if ((ch==' ')|(ch==',')|(ch==13)|(ch==10)|(ch=='|'))
-   return TRUE;
+
+   return true;
+
+
 
 if (ch==EOF)
+
 {
-       m_done=TRUE;
-       return TRUE;
+
+m_done=true;
+
+return true;
+
 }
-return FALSE;
+
+return false;
+
 }
 
-void wxRC2WXR::ParseGroupBox()
+
+
+void rc2wxr::ParseGroupBox()
+
 {
+
 //    GROUPBOX        "Rotate",IDC_STATIC,1,1,71,79
+
 wxString tok;
+
 wxString phrase,varname;
+
 phrase=GetQuoteField();
+
 varname=GetToken();
+
 m_controlid++;
+
 int x,y,width,height;
+
 ReadRect(x,y,width,height);
-fprintf(m_wxr,"  control = [%i,wxStaticBox,'%s','0','%s',",m_controlid,phrase,varname);
-fprintf(m_wxr,"%i,%i,%i,%i,'',\\\n",x,y,width,height);
-fprintf(m_wxr,"[8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif']],\\\n");
+
+wxFprintf(m_wxr,_T("  control = [%i,wxStaticBox,'%s','0','%s',"),m_controlid,phrase.c_str(),varname.c_str());
+
+wxFprintf(m_wxr,_T("%i,%i,%i,%i,'',\\\n"),x,y,width,height);
+
+wxFprintf(m_wxr,_T("[8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif']],\\\n"));
+
+
+
 
 
 }
 
-void wxRC2WXR::ReadRect(int & x, int & y, int & width, int & height)
+
+
+void rc2wxr::ReadRect(int & x, int & y, int & width, int & height)
+
 {
-x=atoi(GetToken());
-y=atoi(GetToken());
-width=atoi(GetToken());
-height=atoi(GetToken());
+
+x=wxAtoi(GetToken());
+
+y=wxAtoi(GetToken());
+
+width=wxAtoi(GetToken());
+
+height=wxAtoi(GetToken());
+
+
 
 }
 
-wxString wxRC2WXR::GetToken()
+
+
+wxString rc2wxr::GetToken()
+
 {
-wxString tok="";
+
+wxString tok=wxEmptyString;
+
+
 
 if (m_rc.Eof())
+
 {
-m_done=TRUE;
+
+m_done=true;
+
 return tok;
+
 }
 
+
+
 int ch=0;
+
 ReadChar(ch);
+
 if (ch==EOF)
+
 {
-m_done=TRUE;
+
+m_done=true;
+
 return tok;
+
 }
 
-while (Seperator(ch))
+
+
+while (Separator(ch))
+
 {
+
   ReadChar(ch);
+
   if (m_done)
-         return tok;
+
+  return tok;
+
 }
 
+
+
 if (ch==EOF)
+
 {
-       m_done=TRUE;
 
-}
-  
+m_done=true;
+
 
-while (!Seperator(ch))
-{
-       tok+=(char)ch;
-       ReadChar(ch);
 
 }
 
-if (ch==EOF)
-   m_done=TRUE;
 
 
-return tok;
-}
 
-wxString wxRC2WXR::GetQuoteField()
+
+while (!Separator(ch))
+
 {
-wxString phrase;
-//ASCII code 34 "
-int ch=0;
+
+tok+=(char)ch;
+
 ReadChar(ch);
 
-while (ch!=34)
-  ReadChar(ch);
-  
-  ReadChar(ch);
 
-while (ch!=34)
-{
-  phrase+=(char)ch;
-  ReadChar(ch);
-}
-return phrase;
+
 }
 
-void wxRC2WXR::ReadChar(int &ch)
-{
-       int result;
-result=m_rc.Tell();
 
-if((result>=m_filesize))
-    m_done=TRUE;
 
-result=m_rc.Read(&ch,1);
+if (ch==EOF)
+
+   m_done=true;
 
-if((result==-1))
-   m_done=TRUE;
 
-if(ch==EOF)
-   m_done=TRUE;
-}
 
-void wxRC2WXR::ParseComboBox()
-{
-/* COMBOBOX        IDC_SCALECOMBO,10,110,48,52,CBS_DROPDOWNLIST | CBS_SORT | 
-                    WS_VSCROLL | WS_TABSTOP */
-wxString tok;
-wxString varname;
-varname=GetToken();
-m_controlid++;
-int x,y,width,height;
-ReadRect(x,y,width,height);
 
-fprintf(m_wxr,"  control = [%i,wxChoice,'','0','%s',",m_controlid,varname);
-fprintf(m_wxr,"%i,%i,%i,%i,[],\\\n",x,y,width,height);
-fprintf(m_wxr,"[8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif']],\\\n");
 
+return tok;
 
 }
 
-void wxRC2WXR::ParseMenu(wxString name)
-{
-wxString tok="";
-static int menuid=0;
-menuid++;
-fprintf(m_wxr,"static char *MenuBar%i = \"menu(name = '%s',\\\n",menuid,name);  
-fprintf(m_wxr,"menu = \\\n");
-fprintf(m_wxr,"[\\\n");
 
-while ((tok!="BEGIN")&(tok!="{"))
-   tok=GetToken();
 
-while ((tok!="END")&(tok!="}"))
+wxString rc2wxr::GetQuoteField()
 {
-   tok=GetToken();
-if (tok=="POPUP")
-       {
-    ParsePopupMenu();
-       fprintf(m_wxr,"  ],\\\n");
-       }
-}
+    wxString phrase;
 
-fprintf(m_wxr,"]).\";\n\n");
-}
+    //ASCII code 34 "
+    int ch=0;
+    ReadChar(ch);
 
-void wxRC2WXR::ParsePopupMenu()
-{
-static int menuitem=99;
-menuitem++;
+    while (ch!=34)
+        ReadChar(ch);
 
-wxString tok;
-tok=GetQuoteField();
-int spot;
-//Remove /t because it causes problems
-spot=tok.First("\\t");
-tok=tok.Left(spot);
-fprintf(m_wxr,"  ['%s',%i,'',\\\n",tok,menuitem);
-while ((tok!="BEGIN")&(tok!="{"))
-   tok=GetToken();
+    ReadChar(ch);
 
-while ((tok!="END")&(tok!="}"))
-{
-   tok=GetToken();
-if (tok=="MENUITEM")
-       {
-       if (PeekToken()=="SEPARATOR")
-               fprintf(m_wxr,"      [],\\\n");
-       else
-       {
-       tok=GetQuoteField();
-       //Remove /t because it causes problems
-       spot=tok.First("\\t");
-       tok=tok.Left(spot);
-       menuitem++;
-    fprintf(m_wxr,"      ['%s',%i,''],\\\n",tok,menuitem);
-       }
-       }
+    while (ch!=34)
+    {
+        phrase+=(char)ch;
+        ReadChar(ch);
+    }
 
+    return phrase;
 }
 
-    
-}
 
-wxString wxRC2WXR::PeekToken()
-{
-wxString tok;
-int p;
-p=m_rc.Tell();
-tok=GetToken();
 
-m_rc.Seek(p);
-return tok;
-}
-//Windows pain in the butt CONTROL
-void wxRC2WXR::ParseControlMS()
+void rc2wxr::ReadChar(int &ch)
 {
-wxString label,varname,kindctrl,tok;
-label=GetQuoteField();
-varname=GetToken();
-kindctrl=GetQuoteField();
-kindctrl.MakeUpper();
+    wxFileOffset result = m_rc.Tell();
 
+    if ( result >= m_filesize )
+        m_done=true;
 
-if (kindctrl=="MSCTLS_TRACKBAR32")
-   ParseSlider(label,varname);
-if (kindctrl=="MSCTLS_PROGRESS32")
-   ParseProgressBar(label,varname);
-if (kindctrl=="BUTTON")
-   ParseCtrlButton(label,varname);
-}
-/*    CONTROL         "Slider1",IDC_SLIDER1,"msctls_trackbar32",TBS_BOTH | 
-                    TBS_NOTICKS | WS_TABSTOP,52,73,100,15
-*/
+    result = m_rc.Read(&ch,1);
 
-void wxRC2WXR::ParseSlider(wxString label, wxString varname)
-{
-       wxString tok;
-       while (ReadOrs(tok));
-fprintf(m_wxr,"  control = [%i,wxSlider,'','wxSL_HORIZONTAL','%s',",m_controlid,varname);  
-int x,y,width,height;
-ReadRect(x,y,width,height);
-fprintf(m_wxr,"%i,%i,%i,%i,",x,y,width,height);
-fprintf(m_wxr," 1, 1, 10,\\\n");
-fprintf(m_wxr,"[8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif']],\\\n");
-}
-/*    
-CONTROL         "Progress1",CG_IDC_PROGDLG_PROGRESS,"msctls_progress32",
-                    WS_BORDER,15,52,154,13
-*/
-void wxRC2WXR::ParseProgressBar(wxString label, wxString varname)
-{
-wxString tok;
-while (ReadOrs(tok));
-fprintf(m_wxr,"  control = [%i,wxGauge,'','wxGA_HORIZONTAL','%s',",m_controlid,varname);  
-int x,y,width,height;
-ReadRect(x,y,width,height);
-fprintf(m_wxr,"%i,%i,%i,%i,",x,y,width,height);
-fprintf(m_wxr," 0, 10,\\\n");
-fprintf(m_wxr,"[8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif']],\\\n");
-}
+    if ( result==wxInvalidOffset )
+        m_done=true;
 
-bool wxRC2WXR::ReadOrs(wxString & w)
-{
-wxString tok;
-tok=PeekToken();
-if (tok.IsNumber())
-   return false;
-w=GetToken();
-return TRUE;
+    if(ch==EOF)
+        m_done=true;
 }
 
-//Is it a check button or a radio button
-void wxRC2WXR::ParseCtrlButton(wxString label, wxString varname)
+
+/* COMBOBOX        IDC_SCALECOMBO,10,110,48,52,CBS_DROPDOWNLIST | CBS_SORT |
+                    WS_VSCROLL | WS_TABSTOP */
+void rc2wxr::ParseComboBox()
 {
-wxString tok;
-       tok=GetToken();
+    int x,y,width,height;
+    wxString tok;
+    wxString varname = GetToken();
 
-m_controlid++;
-       int x,y,width,height;
+    m_controlid++;
 
-if (tok=="BS_AUTOCHECKBOX")
-{
-    fprintf(m_wxr,"  control = [%i,wxCheckBox,'%s','0','%s',",m_controlid,label,varname);    
-    while (ReadOrs(tok));      
-       ReadRect(x,y,width,height);
-    fprintf(m_wxr,"%i,%i,%i,%i,0,\\\n",x,y,width,height);
-    fprintf(m_wxr,"[8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif']],\\\n");
+    ReadRect(x,y,width,height);
+    wxFprintf(m_wxr,_T("  control = [%i,wxChoice,'','0','%s',"),m_controlid,varname.c_str());
+    wxFprintf(m_wxr,_T("%i,%i,%i,%i,[],\\\n"),x,y,width,height);
+    wxFprintf(m_wxr,_T("[8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif']],\\\n"));
 }
 
-if (tok=="BS_AUTORADIOBUTTON")
+
+void rc2wxr::ParseMenu(wxString name)
 {
-    fprintf(m_wxr,"  control = [%i,wxRadioButton,'%s','0','%s',",m_controlid,label,varname);    
-    while(ReadOrs(tok));       
-       ReadRect(x,y,width,height);
-    fprintf(m_wxr,"%i,%i,%i,%i,0,\\\n",x,y,width,height);
-    fprintf(m_wxr,"[8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif']],\\\n");
-}
+    wxString tok;
+    static int menuid=0;
+    menuid++;
+    wxFprintf(m_wxr,_T("static char *MenuBar%i = \"menu(name = '%s',\\\n"),menuid,name.c_str());
+    wxFprintf(m_wxr,_T("menu = \\\n"));
+    wxFprintf(m_wxr,_T("[\\\n"));
 
+    while ((tok!=_T("BEGIN"))&(tok!=_T("{")))
+        tok=GetToken();
 
+    while ((tok!=_T("END"))&(tok!=_T("}")))
+    {
+        tok=GetToken();
 
+        if (tok==_T("POPUP"))
+        {
+            ParsePopupMenu();
+            wxFprintf(m_wxr,_T("  ],\\\n"));
+        }
+    }
+
+    wxFprintf(m_wxr,_T("]).\";\n\n"));
 }
 
-BEGIN_EVENT_TABLE(wxFileProgressDlg,wxDialog)
-END_EVENT_TABLE()
 
-wxFileProgressDlg::wxFileProgressDlg()
-{
-wxPoint pos;
-wxSize size;
-pos = ConvertDialogToPixels(wxPoint(10,10));
-size = ConvertDialogToPixels(wxSize(170,31));
-Create(GetParent(),100,"Parsing RC File",pos,size,603985920);
-SetClientSize(size);
-Move(pos);
-//wxGauge Control
-pos = ConvertDialogToPixels(wxPoint(16,16));
-size = ConvertDialogToPixels(wxSize(136,6));
-m_pProgress = new wxGauge(this,101,100,pos,size);
-//wxStaticText Control
-pos = ConvertDialogToPixels(wxPoint(72,4));
-size = ConvertDialogToPixels(wxSize(18,6));
-m_pCompleteLabel= new wxStaticText(this,102,"0",pos,size,0);
-}
-wxFileProgressDlg::~wxFileProgressDlg()
+void rc2wxr::ParsePopupMenu()
 {
+    static int menuitem=99;
 
-}
+    menuitem++;
 
-void wxFileProgressDlg::UpdateProgress(wxFile * f)
-{
-int p;
-p=(int)((float)f->Tell()/(float)f->Length()*100.0);
-m_pProgress->SetValue(p);
-wxString t;
-t.sprintf("%i%%",p);
-m_pCompleteLabel->SetLabel(t);
-Refresh();
-}
+    wxString tok = GetQuoteField();
+    int spot;
 
+    //Remove /t because it causes problems
+    spot=tok.First(_T("\\t"));
+    tok=tok.Left(spot);
 
+    wxFprintf(m_wxr,_T("  ['%s',%i,'',\\\n"),tok.c_str(),menuitem);
 
-//////////////////////////////////////////////////////////////////////
-// GenerateBitmapSrc Class
-//////////////////////////////////////////////////////////////////////
+    while ((tok!=_T("BEGIN"))&(tok!=_T("{")))
+        tok=GetToken();
 
-//////////////////////////////////////////////////////////////////////
-// Construction/Destruction
-//////////////////////////////////////////////////////////////////////
+    while ((tok!=_T("END"))&(tok!=_T("}")))
+    {
+        tok=GetToken();
+
+        if (tok==_T("MENUITEM"))
+        {
+            if (PeekToken()==_T("SEPARATOR"))
+            {
+                wxFprintf(m_wxr,_T("      [],\\\n"));
+            }
+            else
+            {
+                tok=GetQuoteField();
+                //Remove /t because it causes problems
+                spot=tok.First(_T("\\t"));
+                tok=tok.Left(spot);
+                menuitem++;
+                wxFprintf(m_wxr,_T("      ['%s',%i,''],\\\n"),tok.c_str(),menuitem);
+            }
+        }
+    }
+}
 
-GenerateBitmapSrc::GenerateBitmapSrc()
-{
 
+
+wxString rc2wxr::PeekToken()
+{
+    wxFileOffset p = m_rc.Tell();
+    wxString tok = GetToken();
+    m_rc.Seek(p);
+    return tok;
 }
 
-GenerateBitmapSrc::~GenerateBitmapSrc()
+//Windows pain in the butt CONTROL
+void rc2wxr::ParseControlMS()
 {
+    wxString tok;
+    wxString label=GetQuoteField();
+    wxString varname=GetToken();
+    wxString kindctrl=GetQuoteField();
 
+    kindctrl.MakeUpper();
+    if (kindctrl==_T("MSCTLS_TRACKBAR32"))
+        ParseSlider(label,varname);
+    if (kindctrl==_T("MSCTLS_PROGRESS32"))
+        ParseProgressBar(label,varname);
+    if (kindctrl==_T("BUTTON"))
+        ParseCtrlButton(label,varname);
 }
 
-bool GenerateBitmapSrc::Create(wxString imfile, wxString srcfile,wxString varname)
+/*    CONTROL         "Slider1",IDC_SLIDER1,"msctls_trackbar32",TBS_BOTH |
+                    TBS_NOTICKS | WS_TABSTOP,52,73,100,15
+*/
+void rc2wxr::ParseSlider(wxString WXUNUSED(label), wxString varname)
 {
+    int x,y,width,height;
+    wxString tok;
 
-wxImage img;
-FILE *src;
+    while (ReadOrs(tok))
+        ;
+    wxFprintf(m_wxr,_T("  control = [%i,wxSlider,'','wxSL_HORIZONTAL','%s',"),m_controlid,varname.c_str());
+    ReadRect(x,y,width,height);
+    wxFprintf(m_wxr,_T("%i,%i,%i,%i,"),x,y,width,height);
+    wxFprintf(m_wxr,_T(" 1, 1, 10,\\\n"));
+    wxFprintf(m_wxr,_T("[8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif']],\\\n"));
+}
 
-int h,w;
+/*
+CONTROL         "Progress1",CG_IDC_PROGDLG_PROGRESS,"msctls_progress32",
+                    WS_BORDER,15,52,154,13
+*/
+void rc2wxr::ParseProgressBar(wxString WXUNUSED(label), wxString varname)
+{
+    int x,y,width,height;
+    wxString tok;
 
-img.LoadFile(imfile,wxBITMAP_TYPE_ANY);
-h=img.GetHeight();
-w=img.GetWidth();
+    while (ReadOrs(tok))
+        ;
+
+    wxFprintf(m_wxr,_T("  control = [%i,wxGauge,'','wxGA_HORIZONTAL','%s',"),m_controlid,varname.c_str());
+    ReadRect(x,y,width,height);
+    wxFprintf(m_wxr,_T("%i,%i,%i,%i,"),x,y,width,height);
+    wxFprintf(m_wxr,_T(" 0, 10,\\\n"));
+    wxFprintf(m_wxr,_T("[8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif']],\\\n"));
+}
 
-if( (src  = fopen( srcfile, "at" )) == NULL )
-      return FALSE;
-fprintf(src,"#if !defined(IMG_%s)\n",varname);
-fprintf(src,"#define IMG_%s\n",varname);
 
-fprintf(src,"//Data from bitmap file %s \n",imfile);
-fprintf(src,"//Image Height=%i,Width=%i RGB format\n",h,w);
-fprintf(src,"static unsigned char %s[][3]={\n",varname);
+bool rc2wxr::ReadOrs(wxString & w)
+{
+    wxString tok = PeekToken();
+    if (tok.IsNumber())
+        return false;
+    w=GetToken();
+    return true;
+}
 
 
-for (int y=0;y<h;y++)
+//Is it a check button or a radio button
+void rc2wxr::ParseCtrlButton(wxString label, wxString varname)
 {
-       for (int x=0;x<w;x++)
-       {
-       //fprintf(src,"{%i,%i,%i},",img.GetRed(x,y),img.GetGreen(x,y),img.GetBlue(x,y));
+    int x,y,width,height;
+    wxString tok = GetToken();
 
-       }
-fprintf(src,"\n");
-}      
+    m_controlid++;
 
-fprintf(src,"};\n\n");
+    if (tok==_T("BS_AUTOCHECKBOX"))
+    {
+        wxFprintf(m_wxr,_T("  control = [%i,wxCheckBox,'%s','0','%s',"),m_controlid,label.c_str(),varname.c_str());
+        while (ReadOrs(tok))
+            ;
 
-fprintf(src,"wxBitmap Load%s()\n{\n",varname);
-fprintf(src,"wxImage myimg(%i,%i);\n",w,h);
-int size=w*h*3;
-fprintf(src,"memcpy(myimg.GetData(),&%s[0][0],%i);\n",varname,size);
-fprintf(src,"return myimg.ConvertToBitmap();\n");
-fprintf(src,"}\n");
-fprintf(src,"#endif\n");
-fclose(src);
+        ReadRect(x,y,width,height);
+        wxFprintf(m_wxr,_T("%i,%i,%i,%i,0,\\\n"),x,y,width,height);
+        wxFprintf(m_wxr,_T("[8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif']],\\\n"));
+    }
 
-return TRUE;
-}
+    if (tok==_T("BS_AUTORADIOBUTTON"))
+    {
+        wxFprintf(m_wxr,_T("  control = [%i,wxRadioButton,'%s','0','%s',"),m_controlid,label.c_str(),varname.c_str());
+        while(ReadOrs(tok))
+            ;
 
+        ReadRect(x,y,width,height);
+        wxFprintf(m_wxr,_T("%i,%i,%i,%i,0,\\\n"),x,y,width,height);
+        wxFprintf(m_wxr,_T("[8, 'wxSWISS', 'wxNORMAL', 'wxNORMAL', 0, 'MS Sans Serif']],\\\n"));
+    }
+}