X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/d9b21c9f47f59f36d73220270002b55a7babfdfc..ae901b234c4a0aa7c1777b3bd181dd7f8517ad21:/utils/helpview/src/helpview.cpp?ds=sidebyside

diff --git a/utils/helpview/src/helpview.cpp b/utils/helpview/src/helpview.cpp
index b2ed6bb6fd..6a74791cff 100644
--- a/utils/helpview/src/helpview.cpp
+++ b/utils/helpview/src/helpview.cpp
@@ -10,10 +10,6 @@
 // Licence:     wxWindows licence
 /////////////////////////////////////////////////////////////////////////////
 
-#ifdef __GNUG__
-#pragma implementation "help.cpp"
-#endif
-
 // For compilers that support precompilation, includes "wx/wx.h".
 #include "wx/wxprec.h"
 
@@ -22,7 +18,7 @@
 #endif
 
 // for all others, include the necessary headers (this file is usually all you
-// need because it includes almost all "standard" wxWindows headers
+// need because it includes almost all "standard" wxWidgets headers
 #ifndef WX_PRECOMP
 #include "wx/wx.h"
 #endif
@@ -48,7 +44,7 @@ IMPLEMENT_APP(hvApp)
 
 hvApp::hvApp()
 {
-#if hvUSE_IPC
+#if wxUSE_IPC
     m_server = NULL;
 #endif
 }
@@ -58,31 +54,33 @@ bool hvApp::OnInit()
 #ifdef __WXMOTIF__
     delete wxLog::SetActiveTarget(new wxLogStderr); // So dialog boxes aren't used
 #endif
-	
-    wxArtProvider::PushProvider(new AlternateArtProvider);
-	
-#ifdef __WXMAC__
-    wxFileName::MacRegisterDefaultTypeAndCreator( "htb" , 'HTBD' , 'HTBA' ) ;
+
+    wxArtProvider::Push(new AlternateArtProvider);
+
+#if defined( __WXOSX_MAC__ ) && wxOSX_USE_CARBON
+    wxApp::s_macAboutMenuItemId = wxID_ABOUT;
+    wxFileName::MacRegisterDefaultTypeAndCreator( wxT("htb") , 'HTBD' , 'HTBA' ) ;
 #endif
 
     int istyle = wxHF_DEFAULT_STYLE;
-	
-    wxString service, windowName, book[10], titleFormat, argStr;
+
+    wxString service, windowName, titleFormat, argStr;
+    wxString book[10];
     int bookCount = 0;
     int i;
-    bool hasService = FALSE;
-    bool hasWindowName = FALSE;
-    bool createServer = FALSE;
-	
-#if hvUSE_IPC
+    bool hasService = false;
+    bool hasWindowName = false;
+    bool createServer = false;
+
+#if wxUSE_IPC
     m_server = NULL;
 #endif
-	
+
     // Help books are recognized by extension ".hhp" ".htb" or ".zip".
     // Service and window_name can occur anywhere in arguments,
     // but service must be first
     // Other arguments (topic?) could be added
-	
+
     //  modes of operation:
     //  1) no arguments - stand alone, prompt user for book
     //  2) books only - stand alone, open books
@@ -91,161 +89,164 @@ bool hvApp::OnInit()
     //  4) at least one argument which is not book, and not "--server" - take first
     //     such argument as service, second (if present) as window name,
     //     start service, open any books
-	
-    for( i=1; i < argc; i++ )
+
+    for( i=1; i<argc; i++ )
     {
-		argStr = argv[i];
-		
-		if ( argStr.Find( wxT(".hhp") ) >= 0 ||
-			argStr.Find( wxT(".htb") ) >= 0 ||
-			argStr.Find( wxT(".zip") ) >= 0 ) {
-			book[bookCount] = argStr;
-			bookCount++; 
-		}
-		else if ( argStr == wxT("--server") )
-		{
-			createServer = TRUE;
+        argStr = argv[i];
+
+        if ( argStr.Find( wxT(".hhp") ) >= 0
+            || argStr.Find( wxT(".htb") ) >= 0
+            || argStr.Find( wxT(".zip") ) >= 0 )
+        {
+            book[bookCount] = argStr;
+            bookCount++;
+        }
+        else if ( argStr == wxT("--server") )
+        {
+            createServer = true;
 #if defined(__WXMSW__)
-			service = wxT("generic_helpservice");
+            service = wxT("generic_helpservice");
 #elif defined(__UNIX__)
-			service = wxT("/tmp/") + wxString(wxT("generic_helpservice"));
+            service = wxT("/tmp/") + wxString(wxT("generic_helpservice"));
 #else
-			service = wxT("4242");
+            service = wxT("4242");
 #endif
-		}
-		else if ( !hasService )
-		{
-			service = argStr;
-			hasService = TRUE;
-			createServer = TRUE;
-		}
-		else if ( !hasWindowName )
-		{
-			windowName = argStr;
-			hasWindowName = TRUE;
-		}
-		else if ( argStr.Find( wxT("--Style") )  >= 0 )
-		{
-			long i;
-			wxString numb = argStr.AfterLast(wxT('e'));
-			if ( !(numb.ToLong(&i) ) )
-			{
-				wxLogError( wxT("Integer conversion failed for --Style") );
-			}
-			else
-			{
-				istyle = i;
-			}
-		}
-		else
-		{
-			//unknown - could be topic?
-		}
+        }
+        else if ( !hasService )
+        {
+            service = argStr;
+            hasService = true;
+            createServer = true;
+        }
+        else if ( !hasWindowName )
+        {
+            windowName = argStr;
+            hasWindowName = true;
+        }
+        else if ( argStr.Find( wxT("--Style") )  >= 0 )
+        {
+            long i;
+            wxString numb = argStr.AfterLast(wxT('e'));
+            if ( !(numb.ToLong(&i) ) )
+            {
+                wxLogError( wxT("Integer conversion failed for --Style") );
+            }
+            else
+            {
+                istyle = i;
+            }
+        }
+        else
+        {
+            //unknown - could be topic?
+        }
     }
-	
+
     // No book - query user; but not on Mac, since there
     // may be an AppleEvent to open a document on the way
 #ifndef __WXMAC__
     if ( bookCount < 1 )
     {
-		wxString s = wxFileSelector( wxT("Open help file"),
-			wxGetCwd(),
-			wxEmptyString,
-			wxEmptyString,
-			wxT(
-			"Help books (*.htb)|*.htb|Help books (*.zip)|*.zip|\
-			HTML Help Project (*.hhp)|*.hhp"),
-			wxOPEN | wxFILE_MUST_EXIST,
-			NULL);
-		
-		if (!s.IsEmpty())
-		{
-			book[0] = s;
-			bookCount = 1;
-		}
-    } 
+        wxString s = wxFileSelector( wxT("Open help file"),
+            wxGetCwd(),
+            wxEmptyString,
+            wxEmptyString,
+            wxT("Help books (*.htb)|*.htb|Help books (*.zip)|*.zip|HTML Help Project (*.hhp)|*.hhp"),
+            wxFD_OPEN | wxFD_FILE_MUST_EXIST,
+            NULL);
+
+        if (!s.empty())
+        {
+            book[0] = s;
+            bookCount = 1;
+        }
+    }
 #endif
-    
-#if hvUSE_IPC
-	
-    if ( createServer ) {
-		// Create a new server
-		m_server = new hvServer;
-		
-		if ( !m_server->Create(service) ) {
-			wxString wxm = wxT("Server Create failed - service: ");
-			wxString xxm = wxm << service;
-			wxLogError( xxm );
-			//if MSW quits here, probably another copy already exists
-			return FALSE;
-			
-		}
-		createServer = FALSE; 
+
+#if wxUSE_IPC
+
+    if ( createServer )
+    {
+        // Create a new server
+        m_server = new hvServer;
+
+        if ( !m_server->Create(service) )
+        {
+            wxString wxm = wxT("Server Create failed - service: ");
+            wxString xxm = wxm << service;
+            wxLogError( xxm );
+            //if MSW quits here, probably another copy already exists
+            return false;
+        }
+        createServer = false;
+        wxUnusedVar(createServer);
     }
-	
-#endif  // hvUSE_IPC
-	
+
+#endif  // wxUSE_IPC
+
     //now add help
     wxInitAllImageHandlers();
-    wxFileSystem::AddHandler(new wxZipFSHandler); 
-	
-    SetVendorName(wxT("wxWindows") );
-    SetAppName(wxT("wxHTMLHelpServer") ); 
+    wxFileSystem::AddHandler(new wxZipFSHandler);
+
+    SetVendorName(wxT("wxWidgets") );
+    SetAppName(wxT("wxHTMLHelpServer") );
     wxConfig::Get(); // create an instance
-	
+
     m_helpController = new wxHtmlHelpController( istyle );
-	
+
     if ( !hasWindowName )
+    {
         titleFormat = wxT("Help: %s") ;
+    }
     else
     {
-		//remove underscores
-		windowName.Replace( wxT("_"), wxT(" ") );
-		titleFormat = windowName;
+        //remove underscores
+        windowName.Replace( wxT("_"), wxT(" ") );
+        titleFormat = windowName;
     }
-	
+
     m_helpController->SetTitleFormat( titleFormat );
-	
-    for( i=0; i < bookCount; i++ )
+
+    for( i=0; i<bookCount; i++ )
     {
         wxFileName fileName(book[i]);
-		m_helpController->AddBook(fileName);
+        m_helpController->AddBook(fileName);
     }
-	
+
 #ifdef __WXMOTIF__
     delete wxLog::SetActiveTarget(new wxLogGui);
 #endif
-	
-    m_helpController -> DisplayContents();
-	
-    return TRUE;
+
+    m_helpController->DisplayContents();
+
+    return true;
 }
 
 
 int hvApp::OnExit()
 {
-#if hvUSE_IPC
-    wxNode* node = m_connections.First();
+#if wxUSE_IPC
+    wxObjectList::compatibility_iterator node = m_connections.GetFirst();
     while (node)
     {
-        wxNode* next = node->Next();
-        hvConnection* connection = (hvConnection*) node->Data();
+        wxObjectList::compatibility_iterator next = node->GetNext();
+        hvConnection* connection = (hvConnection*) node->GetData();
         connection->Disconnect();
         delete connection;
         node = next;
     }
     m_connections.Clear();
-	
+
     if (m_server)
     {
         delete m_server;
         m_server = NULL;
     }
 #endif
-	
+
     delete m_helpController;
     delete wxConfig::Set(NULL);
-	
+
     return 0;
 }
 
@@ -256,12 +257,12 @@ bool hvApp::OpenBook(wxHtmlHelpController* controller)
         wxEmptyString,
         wxEmptyString,
         _(
-		"Help books (*.htb)|*.htb|Help books (*.zip)|*.zip|\
-		HTML Help Project (*.hhp)|*.hhp"),
-		wxOPEN | wxFILE_MUST_EXIST,
-		NULL);
-	
-    if (!s.IsEmpty())
+        "Help books (*.htb)|*.htb|Help books (*.zip)|*.zip|\
+        HTML Help Project (*.hhp)|*.hhp"),
+        wxFD_OPEN | wxFD_FILE_MUST_EXIST,
+        NULL);
+
+    if ( !s.empty() )
     {
         wxString ext = s.Right(4).Lower();
         if (ext == _T(".zip") || ext == _T(".htb") || ext == _T(".hhp"))
@@ -269,10 +270,11 @@ bool hvApp::OpenBook(wxHtmlHelpController* controller)
             wxBusyCursor bcur;
             wxFileName fileName(s);
             controller->AddBook(fileName);
-            return TRUE;
+            return true;
         }
     }
-    return FALSE;
+
+    return false;
 }
 
 #ifdef __WXMAC__
@@ -299,22 +301,7 @@ void hvApp::MacOpenFile(const wxString& filename)
 #define ART(artId, xpmRc) \
 if ( id == artId ) return wxBitmap(xpmRc##_xpm);
 
-// Compatibility hack to use wxApp::GetStdIcon of overriden by the user
-#if WXWIN_COMPATIBILITY_2_2
-#define GET_STD_ICON_FROM_APP(iconId) \
-	if ( client == wxART_MESSAGE_BOX ) \
-{ \
-	wxIcon icon = wxTheApp->GetStdIcon(iconId); \
-	if ( icon.Ok() ) \
-{ \
-	wxBitmap bmp; \
-	bmp.CopyFromIcon(icon); \
-	return bmp; \
-} \
-}
-#else
 #define GET_STD_ICON_FROM_APP(iconId)
-#endif
 
 // There are two ways of getting the standard icon: either via XPMs or via
 // wxIcon ctor. This depends on the platform:
@@ -325,10 +312,10 @@ if ( id == artId ) return wxBitmap(xpmRc##_xpm);
 #else
 #define CREATE_STD_ICON(iconId, xpmRc) \
 { \
-	wxIcon icon(_T(iconId)); \
-	wxBitmap bmp; \
-	bmp.CopyFromIcon(icon); \
-	return bmp; \
+    wxIcon icon(_T(iconId)); \
+    wxBitmap bmp; \
+    bmp.CopyFromIcon(icon); \
+    return bmp; \
 }
 #endif
 
@@ -336,8 +323,8 @@ if ( id == artId ) return wxBitmap(xpmRc##_xpm);
 #define ART_MSGBOX(artId, iconId, xpmRc) \
     if ( id == artId ) \
 { \
-	GET_STD_ICON_FROM_APP(iconId) \
-	CREATE_STD_ICON(#iconId, xpmRc) \
+    GET_STD_ICON_FROM_APP(iconId) \
+    CREATE_STD_ICON(#iconId, xpmRc) \
 }
 
 // ---------------------------------------------------------------------
@@ -370,32 +357,32 @@ wxBitmap AlternateArtProvider::CreateBitmap(const wxArtID& id,
                                             const wxSize& WXUNUSED(size))
 {
     ART(wxART_HELP_SIDE_PANEL,                     helpsidepanel)
-		ART(wxART_HELP_SETTINGS,                       helpoptions)
-		ART(wxART_HELP_BOOK,                           helpbook)
-		ART(wxART_HELP_FOLDER,                         helpbook)
-		ART(wxART_HELP_PAGE,                           helppage)
-		//ART(wxART_ADD_BOOKMARK,                        addbookm)
-		//ART(wxART_DEL_BOOKMARK,                        delbookm)
-		ART(wxART_GO_BACK,                             helpback)
-		ART(wxART_GO_FORWARD,                          helpforward)
-		ART(wxART_GO_UP,                               helpup)
-		ART(wxART_GO_DOWN,                             helpdown)
-		ART(wxART_GO_TO_PARENT,                        helpuplevel)
-		ART(wxART_FILE_OPEN,                           helpopen)
-		if (client == wxART_HELP_BROWSER)
-		{
-			//ART(wxART_FRAME_ICON,                          helpicon)
-			ART(wxART_HELP,                          helpicon)
-		}
-		
-		//ART(wxART_GO_HOME,                             home)
-		
-		// Any wxWindows icons not implemented here
-		// will be provided by the default art provider.
-		return wxNullBitmap;
+        ART(wxART_HELP_SETTINGS,                       helpoptions)
+        ART(wxART_HELP_BOOK,                           helpbook)
+        ART(wxART_HELP_FOLDER,                         helpbook)
+        ART(wxART_HELP_PAGE,                           helppage)
+        //ART(wxART_ADD_BOOKMARK,                        addbookm)
+        //ART(wxART_DEL_BOOKMARK,                        delbookm)
+        ART(wxART_GO_BACK,                             helpback)
+        ART(wxART_GO_FORWARD,                          helpforward)
+        ART(wxART_GO_UP,                               helpup)
+        ART(wxART_GO_DOWN,                             helpdown)
+        ART(wxART_GO_TO_PARENT,                        helpuplevel)
+        ART(wxART_FILE_OPEN,                           helpopen)
+        if (client == wxART_HELP_BROWSER)
+        {
+            //ART(wxART_FRAME_ICON,                          helpicon)
+            ART(wxART_HELP,                          helpicon)
+        }
+
+        //ART(wxART_GO_HOME,                             home)
+
+        // Any wxWidgets icons not implemented here
+        // will be provided by the default art provider.
+        return wxNullBitmap;
 }
 
-#if hvUSE_IPC
+#if wxUSE_IPC
 
 wxConnectionBase *hvServer::OnAcceptConnection(const wxString& topic)
 {
@@ -425,26 +412,28 @@ bool hvConnection::OnExecute(const wxString& WXUNUSED(topic),
                              int WXUNUSED(size),
                              wxIPCFormat WXUNUSED(format))
 {
-	//    wxLogStatus("Execute command: %s", data);
-	
-	if ( !wxStrncmp( data, wxT("--intstring"), 11 ) )
-	{
+    //    wxLogStatus("Execute command: %s", data);
+
+    if ( !wxStrncmp( data, wxT("--intstring"), 11 ) )
+    {
         long i;
-		wxString argStr = data;
-		wxString numb = argStr.AfterLast(wxT('g'));
-		if ( !(numb.ToLong(&i) ) ) {
-			wxLogError( wxT("Integer conversion failed for --intstring") );
-		}
-		else {				 
-			wxGetApp().GetHelpController()->Display(int(i));
-		}
-	}
-	else
-	{
-		wxGetApp().GetHelpController()->Display(data);
-	}
-    
-    return TRUE;
+        wxString argStr = data;
+        wxString numb = argStr.AfterLast(wxT('g'));
+        if ( !(numb.ToLong(&i) ) )
+        {
+            wxLogError( wxT("Integer conversion failed for --intstring") );
+        }
+        else
+        {
+            wxGetApp().GetHelpController()->Display(int(i));
+        }
+    }
+    else
+    {
+        wxGetApp().GetHelpController()->Display(data);
+    }
+
+    return true;
 }
 
 bool hvConnection::OnPoke(const wxString& WXUNUSED(topic),
@@ -453,56 +442,56 @@ bool hvConnection::OnPoke(const wxString& WXUNUSED(topic),
                           int WXUNUSED(size),
                           wxIPCFormat WXUNUSED(format))
 {
-	//    wxLogStatus("Poke command: %s = %s", item.c_str(), data);
-	//topic is not tested
-	
-	if ( wxGetApp().GetHelpController() )
-	{
-		if ( item == wxT("--AddBook") )
-		{
-			wxGetApp().GetHelpController()->AddBook(data);
-		}
-		else if ( item == wxT("--DisplayContents") )
-		{
-			wxGetApp().GetHelpController()->DisplayContents();
-		}
-		else if ( item == wxT("--DisplayIndex") )
-		{
-			wxGetApp().GetHelpController()->DisplayIndex();
-		}
-		else if ( item == wxT("--KeywordSearch") )
-		{
-			wxGetApp().GetHelpController()->KeywordSearch(data);
-		}
-		else if ( item == wxT("--SetTitleFormat") )
-		{
-			wxString newname = data; 
-			newname.Replace( wxT("_"), wxT(" ") );
-			wxGetApp().GetHelpController()->SetTitleFormat(newname);
-			//does not redraw title bar?
-			//wxGetApp().GetHelpController()->ReFresh(); - or something
-		}
-		else if ( item == wxT("--SetTempDir") )
-		{
-			wxGetApp().GetHelpController()->SetTempDir(data);
-		}
-		else if ( item == wxT("--YouAreDead") )
-		{
-			// don't really know how to kill app from down here...
-			// use wxKill from client instead
-			//wxWindow *win = wxTheApp->GetTopWindow();
-			//if ( win )
-			//	win->Destroy();
-		}
-	}
-	
-    return TRUE;
+    //    wxLogStatus("Poke command: %s = %s", item.c_str(), data);
+    //topic is not tested
+
+    if ( wxGetApp().GetHelpController() )
+    {
+        if ( item == wxT("--AddBook") )
+        {
+            wxGetApp().GetHelpController()->AddBook(data);
+        }
+        else if ( item == wxT("--DisplayContents") )
+        {
+            wxGetApp().GetHelpController()->DisplayContents();
+        }
+        else if ( item == wxT("--DisplayIndex") )
+        {
+            wxGetApp().GetHelpController()->DisplayIndex();
+        }
+        else if ( item == wxT("--KeywordSearch") )
+        {
+            wxGetApp().GetHelpController()->KeywordSearch(data);
+        }
+        else if ( item == wxT("--SetTitleFormat") )
+        {
+            wxString newname = data;
+            newname.Replace( wxT("_"), wxT(" ") );
+            wxGetApp().GetHelpController()->SetTitleFormat(newname);
+            //does not redraw title bar?
+            //wxGetApp().GetHelpController()->ReFresh(); - or something
+        }
+        else if ( item == wxT("--SetTempDir") )
+        {
+            wxGetApp().GetHelpController()->SetTempDir(data);
+        }
+        else if ( item == wxT("--YouAreDead") )
+        {
+            // don't really know how to kill app from down here...
+            // use wxKill from client instead
+            //wxWindow *win = wxTheApp->GetTopWindow();
+            //if ( win )
+            //    win->Destroy();
+        }
+    }
+
+    return true;
 }
 
 wxChar *hvConnection::OnRequest(const wxString& WXUNUSED(topic),
-								const wxString& WXUNUSED(item),
-								int * WXUNUSED(size),
-								wxIPCFormat WXUNUSED(format))
+                                const wxString& WXUNUSED(item),
+                                int * WXUNUSED(size),
+                                wxIPCFormat WXUNUSED(format))
 {
     return NULL;
 }
@@ -510,8 +499,7 @@ wxChar *hvConnection::OnRequest(const wxString& WXUNUSED(topic),
 bool hvConnection::OnStartAdvise(const wxString& WXUNUSED(topic),
                                  const wxString& WXUNUSED(item))
 {
-    return TRUE;
+    return true;
 }
 
-#endif
-    // hvUSE_IPC
+#endif // #if wxUSE_IPC