]> git.saurik.com Git - wxWidgets.git/blobdiff - contrib/utils/convertrc/rc2wxr.cpp
corrected version number extraction
[wxWidgets.git] / contrib / utils / convertrc / rc2wxr.cpp
index d31c59a49e587426bcaf347b2cdfb214aa450adf..af389830d12864a37247888edba5bbd08159b79e 100644 (file)
 // 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
-
 */
 
 #ifdef __GNUG__
-
-#pragma implementation "rc2wxr.cpp"
-
-#pragma interface "rc2wxr.cpp"
-
+#pragma implementation "rc2wxr.h"
 #endif
 
-
-
 // For compilers that support precompilation, includes "wx/wx.h".
-
 #include "wx/wxprec.h"
 
-
-
 #ifdef __BORLANDC__
-
-#pragma hdrstop
-
+    #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>
-
+    #include "wx/wx.h"
 #endif
 
-
-
-
-
-#include "rc2wxr.h"
-
 #include "wx/image.h"
-
 #include "wx/deprecated/setup.h"
 #include "wx/deprecated/resource.h"
 
-//////////////////////////////////////////////////////////////////////
+#include "rc2wxr.h"
 
+//////////////////////////////////////////////////////////////////////
 // Construction/Destruction
-
 //////////////////////////////////////////////////////////////////////
 
-
-
 rc2wxr::rc2wxr()
-
 {
-
-m_done=false;
-
-m_controlid=6000;
-
+    m_done=false;
+    m_controlid=6000;
 }
 
-
-
 rc2wxr::~rc2wxr()
-
 {
-
-
-
 }
 
-
-
 void rc2wxr::Convert(wxString wxrfile, wxString rcfile)
-
-{
-
-m_rc.Open(rcfile);
-
-m_filesize=m_rc.Length();
-
-if( (m_wxr  = wxFopen( wxrfile, _T("wt") )) == NULL )
-
-{
-
-  return;
-
-}
-
-
-
-
-
-wxString tok,prevtok;
-
-
-
-
-
-while (!m_done)
-
 {
+    m_rc.Open(rcfile);
+    m_filesize=m_rc.Length();
+    if( (m_wxr  = wxFopen( wxrfile, _T("wt") )) == NULL )
+    {
+        return;
+    }
 
+    wxString tok,prevtok;
 
+    while (!m_done)
+    {
+        tok=GetToken();
 
-tok=GetToken();
-
-
-
-if (tok==_T("DIALOG"))
-
-{
-
-ParseDialog(prevtok);
-
-}
-
-
-
-
-
-if (tok==_T("MENU"))
-
-{
-
-ParseMenu(prevtok);
-
-}
-
-
-
-prevtok=tok;
-
-}
-
-
-
-fclose(m_wxr);
-
-//fclose(m_rc);
+        if (tok==_T("DIALOG"))
+        {
+            ParseDialog(prevtok);
+        }
 
-m_rc.Close();
+        if (tok==_T("MENU"))
+        {
+            ParseMenu(prevtok);
+        }
 
+        prevtok=tok;
+    }
 
+    fclose(m_wxr);
 
+    m_rc.Close();
 }
 
 
-
-
-
 /*
 
 Example .rc
@@ -187,8 +97,6 @@ CAPTION "About Funimator"
 
 FONT 8, "MS Sans Serif"
 
-
-
   Borland 4.5 style rc
 
 IDD_DIBATTR DIALOG 7, 16, 172, 119
@@ -205,12 +113,6 @@ FONT 8, "MS Sans Serif"
 
  PUSHBUTTON "Cancel", IDCANCEL, 114, 28, 50, 14
 
-
-
-
-
-
-
 */
 
 void rc2wxr::ParseDialog(wxString dlgname)
@@ -256,13 +158,8 @@ wxFprintf(m_wxr,_T("static char *dialog%i = \"dialog(name = '%s',\\\n"),dlgid,dl
 //be lazy about style for now. add it later
 
 wxFprintf(m_wxr,_T("style = 'wxRAISED_BORDER | wxCAPTION | wxTHICK_FRAME | wxSYSTEM_MENU',\\\n"));
-
-
-
 wxFprintf(m_wxr,_T("id = %i,\\\n"),dlgid);
 
-
-
 //Record x,y,width,height
 
 int x,y,width,height;
@@ -272,9 +169,6 @@ ReadRect(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
@@ -676,440 +570,233 @@ return tok;
 
 
 wxString rc2wxr::GetQuoteField()
-
 {
+    wxString phrase;
 
-wxString phrase;
-
-//ASCII code 34 "
-
-int ch=0;
-
-ReadChar(ch);
-
+    //ASCII code 34 "
+    int ch=0;
+    ReadChar(ch);
 
+    while (ch!=34)
+        ReadChar(ch);
 
-while (ch!=34)
+    ReadChar(ch);
 
-  ReadChar(ch);
-
-
-
-  ReadChar(ch);
-
-
-
-while (ch!=34)
-
-{
-
-  phrase+=(char)ch;
-
-  ReadChar(ch);
-
-}
-
-return phrase;
+    while (ch!=34)
+    {
+        phrase+=(char)ch;
+        ReadChar(ch);
+    }
 
+    return phrase;
 }
 
 
 
 void rc2wxr::ReadChar(int &ch)
-
 {
+    wxFileOffset result = m_rc.Tell();
 
-    int result;
-
-result=m_rc.Tell();
-
-
-
-if((result>=m_filesize))
-
-    m_done=true;
-
+    if ( result >= m_filesize )
+        m_done=true;
 
+    result = m_rc.Read(&ch,1);
 
-result=m_rc.Read(&ch,1);
-
-
-
-if((result==-1))
-
-   m_done=true;
-
-
-
-if(ch==EOF)
-
-   m_done=true;
+    if ( result==wxInvalidOffset )
+        m_done=true;
 
+    if(ch==EOF)
+        m_done=true;
 }
 
 
-
-void rc2wxr::ParseComboBox()
-
-{
-
 /* COMBOBOX        IDC_SCALECOMBO,10,110,48,52,CBS_DROPDOWNLIST | CBS_SORT |
-
                     WS_VSCROLL | WS_TABSTOP */
+void rc2wxr::ParseComboBox()
+{
+    int x,y,width,height;
+    wxString tok;
+    wxString varname = GetToken();
 
-wxString tok;
-
-wxString varname;
-
-varname=GetToken();
-
-m_controlid++;
-
-int x,y,width,height;
-
-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"));
-
-
-
-
+    m_controlid++;
 
+    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"));
 }
 
 
-
 void rc2wxr::ParseMenu(wxString name)
-
-{
-
-wxString tok=wxEmptyString;
-
-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("}")))
-
 {
+    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"));
 
-   tok=GetToken();
-
-if (tok==_T("POPUP"))
+    while ((tok!=_T("BEGIN"))&(tok!=_T("{")))
+        tok=GetToken();
 
+    while ((tok!=_T("END"))&(tok!=_T("}")))
     {
+        tok=GetToken();
 
-    ParsePopupMenu();
-
-    wxFprintf(m_wxr,_T("  ],\\\n"));
-
+        if (tok==_T("POPUP"))
+        {
+            ParsePopupMenu();
+            wxFprintf(m_wxr,_T("  ],\\\n"));
+        }
     }
 
+    wxFprintf(m_wxr,_T("]).\";\n\n"));
 }
 
 
-
-wxFprintf(m_wxr,_T("]).\";\n\n"));
-
-}
-
-
-
 void rc2wxr::ParsePopupMenu()
-
-{
-
-static int menuitem=99;
-
-menuitem++;
-
-
-
-wxString tok;
-
-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);
-
-while ((tok!=_T("BEGIN"))&(tok!=_T("{")))
-
-   tok=GetToken();
-
-
-
-while ((tok!=_T("END"))&(tok!=_T("}")))
-
-{
-
-   tok=GetToken();
-
-if (tok==_T("MENUITEM"))
-
-{
-
-if (PeekToken()==_T("SEPARATOR"))
-
-wxFprintf(m_wxr,_T("      [],\\\n"));
-
-else
-
 {
+    static int menuitem=99;
 
-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);
-
-}
-
-}
-
-
-
-}
+    menuitem++;
 
+    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);
 
+    while ((tok!=_T("BEGIN"))&(tok!=_T("{")))
+        tok=GetToken();
 
+    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);
+            }
+        }
+    }
 }
 
 
 
 wxString rc2wxr::PeekToken()
-
 {
-
-wxString tok;
-
-int p;
-
-p=m_rc.Tell();
-
-tok=GetToken();
-
-
-
-m_rc.Seek(p);
-
-return tok;
-
+    wxFileOffset p = m_rc.Tell();
+    wxString tok = GetToken();
+    m_rc.Seek(p);
+    return tok;
 }
 
 //Windows pain in the butt CONTROL
-
 void rc2wxr::ParseControlMS()
-
 {
+    wxString tok;
+    wxString label=GetQuoteField();
+    wxString varname=GetToken();
+    wxString kindctrl=GetQuoteField();
 
-wxString label,varname,kindctrl,tok;
-
-label=GetQuoteField();
-
-varname=GetToken();
-
-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);
-
+    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);
 }
 
 /*    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;
 
-wxString tok;
-
-while (ReadOrs(tok))
-    ;
-
-wxFprintf(m_wxr,_T("  control = [%i,wxSlider,'','wxSL_HORIZONTAL','%s',"),m_controlid,varname.c_str());
-
-int x,y,width,height;
-
-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"));
-
+    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"));
 }
 
 /*
-
 CONTROL         "Progress1",CG_IDC_PROGDLG_PROGRESS,"msctls_progress32",
-
                     WS_BORDER,15,52,154,13
-
 */
-
 void rc2wxr::ParseProgressBar(wxString WXUNUSED(label), wxString varname)
-
 {
-
-wxString tok;
-
-while (ReadOrs(tok))
-    ;
-
-wxFprintf(m_wxr,_T("  control = [%i,wxGauge,'','wxGA_HORIZONTAL','%s',"),m_controlid,varname.c_str());
-
-int x,y,width,height;
-
-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"));
-
-}
-
-
-
-bool rc2wxr::ReadOrs(wxString & w)
-
-{
-
-wxString tok;
-
-tok=PeekToken();
-
-if (tok.IsNumber())
-
-   return false;
-
-w=GetToken();
-
-return true;
-
-}
-
-
-
-//Is it a check button or a radio button
-
-void rc2wxr::ParseCtrlButton(wxString label, wxString varname)
-
-{
-
-wxString tok;
-
-tok=GetToken();
-
-
-
-m_controlid++;
-
-int x,y,width,height;
-
-
-
-if (tok==_T("BS_AUTOCHECKBOX"))
-
-{
-
-    wxFprintf(m_wxr,_T("  control = [%i,wxCheckBox,'%s','0','%s',"),m_controlid,label.c_str(),varname.c_str());
+    int x,y,width,height;
+    wxString tok;
 
     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,0,\\\n"),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 (tok==_T("BS_AUTORADIOBUTTON"))
-
+bool rc2wxr::ReadOrs(wxString & w)
 {
-
-    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"));
-
+    wxString tok = PeekToken();
+    if (tok.IsNumber())
+        return false;
+    w=GetToken();
+    return true;
 }
 
 
+//Is it a check button or a radio button
+void rc2wxr::ParseCtrlButton(wxString label, wxString varname)
+{
+    int x,y,width,height;
+    wxString tok = GetToken();
 
+    m_controlid++;
 
+    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))
+            ;
 
+        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"));
+    }
 
+    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"));
+    }
 }
 
-
-