diff options
author | Stephan Bergmann <sbergman@redhat.com> | 2012-11-16 14:56:58 +0100 |
---|---|---|
committer | Stephan Bergmann <sbergman@redhat.com> | 2012-11-16 14:57:12 +0100 |
commit | ef670259c7f770397e19c58fabda7b5e91b88291 (patch) | |
tree | 68aef6f52cc710461ba3dfb3575bdaf41fc19c53 | |
parent | 34b2748eb38f9487fdfcb81141b64844d3d2a734 (diff) |
Use sal/log.hxx instead of fprintf
...and some clean-up.
Change-Id: Ia958628a3d0fdada3f8e90cfc0b0ceaa45563206
-rw-r--r-- | extensions/source/plugin/inc/plugin/unx/sysplug.hxx | 2 | ||||
-rw-r--r-- | extensions/source/plugin/unx/sysplug.cxx | 74 |
2 files changed, 39 insertions, 37 deletions
diff --git a/extensions/source/plugin/inc/plugin/unx/sysplug.hxx b/extensions/source/plugin/inc/plugin/unx/sysplug.hxx index 0dc6a6e5afa0..9f985645ccd2 100644 --- a/extensions/source/plugin/inc/plugin/unx/sysplug.hxx +++ b/extensions/source/plugin/inc/plugin/unx/sysplug.hxx @@ -37,8 +37,6 @@ class UnxPluginComm : public PluginComm, public PluginConnector { private: - static int nConnCounter; - pid_t m_nCommPID; public: UnxPluginComm( const String& mimetype, diff --git a/extensions/source/plugin/unx/sysplug.cxx b/extensions/source/plugin/unx/sysplug.cxx index 24968feed942..584bae01a1dd 100644 --- a/extensions/source/plugin/unx/sysplug.cxx +++ b/extensions/source/plugin/unx/sysplug.cxx @@ -33,8 +33,6 @@ #undef _LINUX_SOURCE_COMPAT #endif -#include <cstdarg> - #include <sys/types.h> #include <signal.h> #include <sys/wait.h> @@ -50,8 +48,6 @@ return ::boost::shared_ptr<SysPlugData>(); } -int UnxPluginComm::nConnCounter = 0; - UnxPluginComm::UnxPluginComm( const String& /*mimetype*/, const String& library, @@ -60,13 +56,13 @@ UnxPluginComm::UnxPluginComm( int nDescriptor2 ) : PluginComm( ::rtl::OUStringToOString( library, osl_getThreadTextEncoding() ), false ), - PluginConnector( nDescriptor2 ) + PluginConnector( nDescriptor2 ), + m_nCommPID( 0 ) { rtl::OString path; if (!getPluginappPath(&path)) { - fprintf( stderr, "cannot construct path to pluginapp.bin\n" ); - m_nCommPID = -1; + SAL_WARN("extensions.plugin", "cannot construct path to pluginapp.bin"); return; } @@ -83,50 +79,58 @@ UnxPluginComm::UnxPluginComm( pArgs[3] = pWindow; pArgs[4] = NULL; -#if OSL_DEBUG_LEVEL > 1 - m_nCommPID = 10; - fprintf( stderr, "Try to launch: %s %s %s %s, descriptors are %d, %d\n", pArgs[0], pArgs[1], pArgs[2], pArgs[3], nDescriptor1, nDescriptor2 ); -#endif + SAL_INFO( + "extensions.plugin", + "try to launch: " << pArgs[0] << " " << pArgs[1] << " " << pArgs[2] + << " " << pArgs[3] << ", descriptors are " << nDescriptor1 << ", " + << nDescriptor2); - if( ! ( m_nCommPID = fork() ) ) + pid_t pid = fork(); + if( pid == 0 ) { execvp( pArgs[0], const_cast< char ** >(pArgs) ); - fprintf( stderr, "Error: could not exec %s\n", pArgs[0] ); + SAL_WARN("extensions.plugin", "could not exec " << pArgs[0]); _exit(255); } - if( m_nCommPID != -1 ) + if( pid == -1 ) + { + SAL_WARN("extensions.plugin", "fork failed"); + return; + } + + m_nCommPID = pid; + // wait for pluginapp.bin to start up + if( ! WaitForMessage( 5000 ) ) { - // wait for pluginapp.bin to start up - if( ! WaitForMessage( 5000 ) ) - { - fprintf( stderr, "Timeout on command: %s %s %s %s\n", pArgs[0], pArgs[1], pArgs[2], pArgs[3] ); - invalidate(); - } - else - { - MediatorMessage* pMessage = GetNextMessage( sal_True ); - Respond( pMessage->m_nID, - const_cast<char*>("init ack"),8, - NULL ); - delete pMessage; - NPP_Initialize(); - } + SAL_WARN( + "extensions.plugin", + "timeout on command: " << pArgs[0] << " " << pArgs[1] << " " + << pArgs[2] << " " << pArgs[3]); + invalidate(); + } + else + { + MediatorMessage* pMessage = GetNextMessage( sal_True ); + Respond( pMessage->m_nID, + const_cast<char*>("init ack"),8, + NULL ); + delete pMessage; + NPP_Initialize(); } } UnxPluginComm::~UnxPluginComm() { NPP_Shutdown(); - if( m_nCommPID != -1 && m_nCommPID != 0 ) + if( m_nCommPID != 0 ) { int status = 16777216; pid_t nExit = waitpid( m_nCommPID, &status, WUNTRACED ); -#if OSL_DEBUG_LEVEL > 1 - fprintf( stderr, "child %d (plugin app child %d) exited with status %d\n", (int)nExit, (int)m_nCommPID, (int)WEXITSTATUS(status) ); -#else - (void)nExit; -#endif + SAL_INFO( + "extensions.plugin", + "child " << nExit << " (plugin app child " << m_nCommPID + << ") exited with status " << WEXITSTATUS(status)); } } |