X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/b5ffecfc985136771bb521074c0f46a07894e62e..b51b78a9c7b50053cdcf4a22d2222500a20eb8ee:/demos/dbbrowse/doc.cpp diff --git a/demos/dbbrowse/doc.cpp b/demos/dbbrowse/doc.cpp index 806ceaf397..afe107b74c 100644 --- a/demos/dbbrowse/doc.cpp +++ b/demos/dbbrowse/doc.cpp @@ -1,44 +1,44 @@ -//--------------------------------------------------------------------------- +//---------------------------------------------------------------------------------------- // Name: Doc.cpp -// Purpose: Holds information for DBBrowser +// Purpose: Holds information for DBBrowser - (a do-it-yourself document) // Author: Mark Johnson, mj10777@gmx.net // Modified by: 19990808.mj10777 // BJO : Bart A.M. JOURQUIN // Created: 19990808 // Copyright: (c) Mark Johnson // Licence: wxWindows license -//--------------------------------------------------------------------------- -//-- all #ifdefs that the whole Project needs. ------------------------------ -//--------------------------------------------------------------------------- +// RCS-ID: $Id$ +//---------------------------------------------------------------------------------------- +//-- all #ifdefs that the whole Project needs. ------------------------------------------- +//---------------------------------------------------------------------------------------- #ifdef __GNUG__ - #pragma implementation - #pragma interface +#pragma implementation +#pragma interface #endif -//--------------------------------------------------------------------------- +//---------------------------------------------------------------------------------------- // For compilers that support precompilation, includes "wx/wx.h". #include "wx/wxprec.h" -//--------------------------------------------------------------------------- +//---------------------------------------------------------------------------------------- #ifdef __BORLANDC__ - #pragma hdrstop +#pragma hdrstop #endif -//--------------------------------------------------------------------------- +//---------------------------------------------------------------------------------------- #ifndef WX_PRECOMP - #include "wx/wx.h" +#include "wx/wx.h" #endif -//--------------------------------------------------------------------------- -//--------------------------------------------------------------------------- -//-- all #includes that every .cpp needs ----19990807.mj10777 --- -//--------------------------------------------------------------------------- +//---------------------------------------------------------------------------------------- +//-- all #includes that every .cpp needs ----19990807.mj10777 ---------------- +//---------------------------------------------------------------------------------------- #include "std.h" // sorgsam Pflegen ! -//--------------------------------------------------------------------------- -//-- Some Global Vars for all Files (extern in ?.h needed) ----------------- +//---------------------------------------------------------------------------------------- +//-- Some Global Vars for all Files (extern in ?.h needed) ------------------------------- // Global structure for holding ODBC connection information - struct DbStuff DbConnectInf; -//--------------------------------------------------------------------------- +struct DbStuff DbConnectInf; +//---------------------------------------------------------------------------------------- wxConfigBase *p_ProgramCfg; // All Config and Path information wxLogTextCtrl *p_LogBook; // All Log messages wxString LogBuf; // String for all Logs -//--------------------------------------------------------------------------- +//---------------------------------------------------------------------------------------- mjDoc::mjDoc() { db_Br = NULL; @@ -54,8 +54,10 @@ mjDoc::mjDoc() p_PageArea = NULL; i_TabNr = 0; i_PageNr = 0; + s_BColour = "WHEAT"; + ft_Doc = new wxFont(wxSystemSettings::GetSystemFont(wxSYS_SYSTEM_FONT)); } -//--------------------------------------------------------------------------- +//---------------------------------------------------------------------------------------- mjDoc::~mjDoc() { // ---------------------------------------------------------- @@ -75,66 +77,66 @@ mjDoc::~mjDoc() delete [] db_Br; // wxMessageBox("~mjDoc"); } -//--------------------------------------------------------------------------- +//---------------------------------------------------------------------------------------- bool mjDoc::OnNewDocument() { - //------------------------------------------------------------------- - if (!OnInitView()) // LogBook is now activ + wxStopWatch sw; + //--------------------------------------------------------------------------------------- + if (!OnInitView()) return FALSE; p_PgmCtrl->OnPopulate(); - //------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- + wxLogMessage(_("-I-> mjDoc::OnNewDocument() - End - Time needed : %ld ms"),sw.Time()); return TRUE; } -//--------------------------------------------------------------------------- +//---------------------------------------------------------------------------------------- bool mjDoc::OnInitView() { Sash = p_ProgramCfg->Read("/MainFrame/Sash", 200); // wxMessageBox("OnInitView() - Begin ","-I->mjDoc::OnInitView"); - //-------------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- // create "workplace" window - //-------------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- p_TabArea = new wxTabbedWindow(); // Init the Pointer p_TabArea->Create(p_Splitter, -1); - //-------------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- p_PgmCtrl = new PgmCtrl(p_TabArea, TREE_CTRL_PGM,wxDefaultPosition, wxDefaultSize, - wxTR_HAS_BUTTONS | wxSUNKEN_BORDER); + wxTR_HAS_BUTTONS | wxSUNKEN_BORDER); p_PgmCtrl->i_TabArt = 0; // 0 = Tab ; 1 = Page p_PgmCtrl->i_ViewNr = p_TabArea->GetTabCount()-1; - //-------------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- wxBitmap *p_FolderClose = new wxBitmap("PgmCtrl"); //, wxBITMAP_TYPE_BMP_RESOURCE); // BJO20000115 - //-------------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- p_TabArea->AddTab(p_PgmCtrl,"PgmCtrl",p_FolderClose); - //-------------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- // now create "output" window - //-------------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- p_PageArea = new wxPaggedWindow(); // Init the Pointer p_PageArea->Create(p_Splitter, -1); - //-------------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- p_LogWin = new wxTextCtrl(p_PageArea,-1,wxEmptyString, - wxDefaultPosition, wxDefaultSize,wxTE_MULTILINE ); - wxFont* ft_Temp = new wxFont(10,wxSWISS,wxNORMAL,wxBOLD,FALSE,"Comic Sans MS"); - p_LogWin->SetFont(* ft_Temp); + wxDefaultPosition, wxDefaultSize,wxTE_MULTILINE ); + p_LogWin->SetFont(* ft_Doc); // Don't forget ! This is always : i_TabArt = 0 ; i_ViewNr = 1; - //------------------------------------------------------------------ + //--------------------------------------------------------------------------------------- p_LogBook = new wxLogTextCtrl(p_LogWin); // make p_LogWin the LogBook p_LogBook->SetActiveTarget(p_LogBook); p_LogBook->SetTimestamp( NULL ); - //------------------------------------------------------------------ + //--------------------------------------------------------------------------------------- p_PageArea->AddTab(p_LogWin,_("LogBook"), "what is this?" ); i_TabNr = p_TabArea->GetTabCount()-1; // Add one when a new AddTab is done; i_PageNr = p_PageArea->GetTabCount()-1; // Add one when a new AddTab is done; - //-------------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- p_PgmCtrl->pDoc = this; p_TabArea->SetActiveTab(i_PageNr); - //-------------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- p_Splitter->Initialize(p_TabArea); p_Splitter->SplitHorizontally(p_TabArea,p_PageArea,Sash); - //-------------------------------------------------------------------------- - + //--------------------------------------------------------------------------------------- if (!OnInitODBC()) return FALSE; - //-------------------------------------------------------------------------- - Temp0.Printf("-I-> mjDoc::OnInitView() - End - %d DSN's found",i_DSN); + //--------------------------------------------------------------------------------------- + Temp0.Printf(_("-I-> mjDoc::OnInitView() - End - %d DSN's found"),i_DSN); p_MainFrame->SetStatusText(Temp0, 0); wxLogMessage(Temp0); return TRUE; @@ -147,22 +149,21 @@ bool mjDoc::OnInitODBC() Temp0 = ""; i_DSN = 0; // Counter int i = 0; - //--------------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- // Initialize the ODBC Environment for Database Operations if (SQLAllocEnv(&DbConnectInf.Henv) != SQL_SUCCESS) { return FALSE; } - //--------------------------------------------------------------------------- - + //--------------------------------------------------------------------------------------- const char sep = 3; // separator character used in string between DSN ans DsDesc wxStringList s_SortDSNList, s_SortDsDescList; // BJO-20000127 // In order to have same sort result on both Dsn and DsDesc, create a 'keyed' string. // The key will be removed after sorting wxString KeyString; - //--------------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- while(GetDataSource(DbConnectInf.Henv, Dsn, sizeof(Dsn), DsDesc, sizeof(DsDesc))) { i_DSN++; // How many Dsn have we ? @@ -175,7 +176,7 @@ bool mjDoc::OnInitODBC() char ** s_SortDSN = s_SortDSNList.ListToArray(); //BJO char ** s_SortDsDesc = s_SortDsDescList.ListToArray(); //BJO - //--------------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- // Allocate n ODBC-DSN objects to hold the information p_DSN = new DSN[i_DSN]; //BJO for (i=0;iDrv = s_SortDsDesc[i]; (p_DSN+i)->Usr = ""; (p_DSN+i)->Pas = ""; - Temp0.Printf("%02d) Dsn(%s) DsDesc(%s)",i,(p_DSN+i)->Dsn,(p_DSN+i)->Drv); + Temp0.Printf("%02d) Dsn(%s) DsDesc(%s)",i,(p_DSN+i)->Dsn.c_str(),(p_DSN+i)->Drv.c_str()); wxLogMessage(Temp0); } i = 0; - //--------------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- // Allocate n wxDatabase objects to hold the column information db_Br = new BrowserDB[i_DSN]; for (i=0;ipDoc = this; (db_Br+i)->i_Which = i; } - if (SQLFreeEnv(&DbConnectInf.Henv) != SQL_SUCCESS) // BJO20000125 { - // Error freeing environment handle + // Error freeing environment handle } - delete [] s_SortDSN; delete [] s_SortDsDesc; - - //--------------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- if (!i_DSN) { wxMessageBox(_("No Dataset names found in ODBC!\n" \ - " Program will exit!\n\n" \ - " Ciao"),"-E-> Fatal situation"); + " Program will exit!\n\n" \ + " Ciao"),"-E-> Fatal situation"); return FALSE; } - //--------------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- return TRUE; } //---------------------------------------------------------------------------------------- bool mjDoc::OnChosenDSN(int Which) { // wxLogMessage("OnChosenDSN(%d) - Begin",Which); - //--------------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- if (p_DBTree != NULL) { p_TabArea->Show(FALSE); // Deactivate the Window @@ -238,7 +236,7 @@ bool mjDoc::OnChosenDSN(int Which) //------------------------- p_TabArea->Show(FALSE); // Deactivate the Window p_DBTree = new DBTree(p_TabArea, TREE_CTRL_DB,wxDefaultPosition, wxDefaultSize, - wxTR_HAS_BUTTONS | wxSUNKEN_BORDER); + wxTR_HAS_BUTTONS | wxSUNKEN_BORDER); p_TabArea->AddTab(p_DBTree,(p_DSN+Which)->Dsn," ? "); p_DBTree->i_ViewNr = p_TabArea->GetTabCount()-1; p_TabArea->Show(TRUE); // Deactivate the Window @@ -248,7 +246,7 @@ bool mjDoc::OnChosenDSN(int Which) p_DBTree->pDoc = this; p_DBTree->OnPopulate(); p_TabArea->SetActiveTab(p_DBTree->i_ViewNr); - //--------------------------------------------------------------------------- + //--------------------------------------------------------------------------------------- // wxLogMessage("OnChosenDSN(%d) - End",Which); return TRUE; } @@ -281,7 +279,7 @@ bool mjDoc::OnChosenTbl(int Tab,wxString Table) { p_TabArea->Show(FALSE); // Deactivate the Window p_DBGrid = new DBGrid(p_TabArea,GRID_CTRL_DB,wxDefaultPosition, wxDefaultSize, - wxSUNKEN_BORDER); + wxSUNKEN_BORDER); p_TabArea->AddTab(p_DBGrid, Table, ""); p_DBGrid->i_ViewNr = p_TabArea->GetTabCount()-1; p_DBGrid->pDoc = this; @@ -294,7 +292,7 @@ bool mjDoc::OnChosenTbl(int Tab,wxString Table) { p_PageArea->Show(FALSE); // Deactivate the Window p_DBGrid = new DBGrid(p_PageArea,GRID_CTRL_DB,wxDefaultPosition, wxDefaultSize, - wxSUNKEN_BORDER); + wxSUNKEN_BORDER); p_PageArea->AddTab(p_DBGrid, Table, ""); p_DBGrid->i_ViewNr = p_PageArea->GetTabCount()-1; p_DBGrid->pDoc = this; @@ -305,7 +303,7 @@ bool mjDoc::OnChosenTbl(int Tab,wxString Table) p_PageArea->SetActiveTab(p_DBGrid->i_ViewNr); } p_DBGrid->i_TabArt = Tab; - //---*---------------------- + //-------------------------- return TRUE;; } //---------------------------------------------------------------------------------------- @@ -320,8 +318,7 @@ void mjDoc::OnLeer(wxString Aufrufer) BEGIN_EVENT_TABLE(DocSplitterWindow, wxSplitterWindow) END_EVENT_TABLE() //---------------------------------------------------------------------------------------- -// Define a constructor for my p_Splitter DocSplitterWindow::DocSplitterWindow(wxWindow *parent, wxWindowID id) : wxSplitterWindow(parent, id) -{ +{ // Define a constructor for my p_Splitter } //----------------------------------------------------------------------------------------