X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/af870ed80f7cbfe49a0900c35310dedf82b06f63..5e23e2d59a25a7eae5ca16958877be59f7eeb33b:/samples/mobile/wxedit/wxedit.cpp diff --git a/samples/mobile/wxedit/wxedit.cpp b/samples/mobile/wxedit/wxedit.cpp index fa4a2d3ee3..491b8c333d 100644 --- a/samples/mobile/wxedit/wxedit.cpp +++ b/samples/mobile/wxedit/wxedit.cpp @@ -2,11 +2,11 @@ // Name: wxedit.cpp // Author: Robert Roebling // Created: 04/07/02 -// Copyright: +// Copyright: ///////////////////////////////////////////////////////////////////////////// #ifdef __GNUG__ - #pragma implementation "wxedit.cpp" + #pragma implementation "wxedit.h" #endif // For compilers that support precompilation @@ -34,20 +34,20 @@ BEGIN_EVENT_TABLE(MyFrame,wxFrame) EVT_MENU(ID_ABOUT, MyFrame::OnAbout) - + EVT_MENU(ID_NEW, MyFrame::OnNew) EVT_MENU(ID_OPEN, MyFrame::OnOpen) EVT_MENU(ID_SAVE, MyFrame::OnSave) EVT_MENU(ID_SAVEAS, MyFrame::OnSaveAs) EVT_MENU(ID_QUIT, MyFrame::OnQuit) - + EVT_MENU(ID_COPY, MyFrame::OnCopy) EVT_MENU(ID_CUT, MyFrame::OnCut) EVT_MENU(ID_PASTE, MyFrame::OnPaste) EVT_MENU(ID_DELETE, MyFrame::OnDelete) - + EVT_MENU_RANGE(ID_LAST_1, ID_LAST_3, MyFrame::OnLastFiles) - + EVT_CLOSE(MyFrame::OnCloseWindow) EVT_UPDATE_UI(wxID_ANY,MyFrame::OnUpdateUI) END_EVENT_TABLE() @@ -58,28 +58,30 @@ MyFrame::MyFrame( wxWindow *parent, wxWindowID id, const wxString &title, { // Create menu and status bar. CreateMyMenuBar(); +#if wxUSE_STATUSBAR CreateStatusBar(1); SetStatusText( _T("Welcome to wxEdit!") ); - +#endif // wxUSE_STATUSBAR + // Create edit control. Since it is the only // control in the frame, it will be resized // to file it out. m_text = new wxTextCtrl( this, wxID_ANY, _T(""), wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE ); - + // Read .ini file for file history etc. wxConfig *conf = (wxConfig*) wxConfig::Get(); - int entries = 0; + int entries = 0; conf->Read( _T("/History/Count"), &entries ); - + for (int i = 0; i < entries; i++) { wxString tmp; tmp.Printf( _T("/History/File%d"), (int)i ); - + wxString res; conf->Read( tmp, &res ); - + if (!res.empty()) AddToHistory( res ); } @@ -88,19 +90,19 @@ MyFrame::MyFrame( wxWindow *parent, wxWindowID id, const wxString &title, void MyFrame::MakeHistory() { wxMenuBar *mb = GetMenuBar(); - + wxASSERT( mb ); int max = m_history.GetCount(); if (max > HISTORY_ENTRIES) max = HISTORY_ENTRIES; - + for (int i = 0; i < max; i++) { wxMenu *menu = NULL; mb->FindItem( ID_LAST_1 + i, &menu ); wxASSERT( menu ); - + wxFileName fname( m_history[(size_t)i] ); menu->SetLabel( ID_LAST_1 + i, fname.GetFullName() ); } @@ -110,12 +112,12 @@ void MyFrame::AddToHistory( const wxString &fname ) { // Fill menu with history index int index = m_history.Index( fname ); - + if (index != wxNOT_FOUND) m_history.RemoveAt( (size_t) index ); - + m_history.Insert( fname, 0 ); - + // Update menu MakeHistory(); } @@ -138,17 +140,17 @@ void MyFrame::CreateMyMenuBar() edit_menu->Append( ID_PASTE, _T("Paste") ); edit_menu->AppendSeparator(); edit_menu->Append( ID_DELETE, _T("Delete") ); - + wxMenu *history_menu = new wxMenu; history_menu->Append( ID_LAST_1, _T("No file.") ); history_menu->Append( ID_LAST_2, _T("No file.") ); history_menu->Append( ID_LAST_3, _T("No file.") ); - + wxMenuBar *menu_bar = new wxMenuBar(); menu_bar->Append( file_menu, _T("&File") ); menu_bar->Append( edit_menu, _T("&Edit") ); menu_bar->Append( history_menu, _T("&History") ); - + SetMenuBar( menu_bar ); } @@ -174,17 +176,19 @@ void MyFrame::OnLastFiles( wxCommandEvent &event ) if (!m_filename.empty()) AddToHistory( m_filename ); - + size_t index = event.GetId() - ID_LAST_1; - + if( index < m_history.GetCount() ) { - m_filename = m_history[index]; - - m_text->Clear(); - m_text->LoadFile( m_filename ); - - SetStatusText( m_filename ); + m_filename = m_history[index]; + + m_text->Clear(); + m_text->LoadFile( m_filename ); + +#if wxUSE_STATUSBAR + SetStatusText( m_filename ); +#endif // wxUSE_STATUSBAR } else { @@ -202,13 +206,15 @@ void MyFrame::OnNew( wxCommandEvent& WXUNUSED(event) ) if (!Discard()) return; m_text->Clear(); - + if (!m_filename.empty()) AddToHistory( m_filename ); - + m_filename = wxEmptyString; - + +#if wxUSE_STATUSBAR SetStatusText( _T("") ); +#endif // wxUSE_STATUSBAR } void MyFrame::OnOpen( wxCommandEvent& WXUNUSED(event) ) @@ -223,6 +229,8 @@ void MyFrame::OnOpen( wxCommandEvent& WXUNUSED(event) ) m_text->Clear(); #ifdef __WXX11__ + // requires wxUSE_UNIV_TEXTCTRL to be set to 0 +#if 0 wxFileName fname( dialog.GetPath() ); if ((fname.GetExt() == _T("cpp")) || (fname.GetExt() == _T("c")) || @@ -247,12 +255,15 @@ void MyFrame::OnOpen( wxCommandEvent& WXUNUSED(event) ) { m_text->SetLanguage( wxSOURCE_LANG_NONE ); } +#endif #endif m_filename = dialog.GetPath(); m_text->LoadFile( m_filename ); - + +#if wxUSE_STATUSBAR SetStatusText( m_filename ); +#endif // wxUSE_STATUSBAR } } @@ -270,8 +281,10 @@ void MyFrame::OnSaveAs( wxCommandEvent& WXUNUSED(event) ) { m_filename = dialog.GetPath(); m_text->SaveFile( m_filename ); - + +#if wxUSE_STATUSBAR SetStatusText( m_filename ); +#endif // wxUSE_STATUSBAR } } @@ -290,12 +303,12 @@ void MyFrame::OnQuit( wxCommandEvent& WXUNUSED(event) ) bool MyFrame::Save() { wxCommandEvent event; - + if (m_filename.empty()) OnSaveAs( event ); else m_text->SaveFile( m_filename ); - + return true; } @@ -305,19 +318,19 @@ bool MyFrame::Discard() { wxMessageDialog dialog( this, _T("Text has been\nmodified! Save?"), _T("wxEdit"), wxYES_NO|wxCANCEL|wxICON_EXCLAMATION ); - + int ret = dialog.ShowModal(); - + if (ret == wxID_CANCEL) return false; - + if (ret == wxID_YES) { if (!Save()) return false; } } - + return true; } @@ -343,7 +356,7 @@ void MyFrame::OnUpdateUI( wxUpdateUIEvent &event ) m_text->GetSelection(& selFrom, & selTo); event.Enable( selFrom != selTo ); } -#endif +#endif break; default: break; @@ -353,29 +366,29 @@ void MyFrame::OnUpdateUI( wxUpdateUIEvent &event ) void MyFrame::OnCloseWindow( wxCloseEvent& WXUNUSED(event) ) { // Save changes? - if (!Discard()) return; - + if (!Discard()) return; + // Add current to history if (!m_filename.empty()) AddToHistory( m_filename ); - // Write .ini file + // Write .ini file wxConfig *conf = (wxConfig*) wxConfig::Get(); - + int max = HISTORY_ENTRIES; if (m_history.GetCount() < (size_t)max) max = m_history.GetCount(); - + conf->Write( _T("/History/Count"), max ); - + for (int i = 0; i < max; i++) { wxString tmp; tmp.Printf( _T("/History/File%d"), (int)i ); - + conf->Write( tmp, m_history[(size_t)i] ); } - + // Flush and delete config delete wxConfig::Set( NULL ); @@ -389,18 +402,14 @@ void MyFrame::OnCloseWindow( wxCloseEvent& WXUNUSED(event) ) IMPLEMENT_APP(MyApp) -MyApp::MyApp() -{ -} - bool MyApp::OnInit() { SetVendorName(_T("Free world")); SetAppName(_T("wxEdit")); - + MyFrame *frame = new MyFrame( NULL, wxID_ANY, _T("wxEdit"), wxPoint(20,20), wxSize(500,340) ); frame->Show( true ); - + return true; }