summaryrefslogtreecommitdiff
path: root/desktop
diff options
context:
space:
mode:
Diffstat (limited to 'desktop')
-rw-r--r--desktop/source/app/officeipcthread.cxx37
-rw-r--r--desktop/win32/source/officeloader/officeloader.cxx196
2 files changed, 1 insertions, 232 deletions
diff --git a/desktop/source/app/officeipcthread.cxx b/desktop/source/app/officeipcthread.cxx
index 30b86df09df5..efb23a53a0c7 100644
--- a/desktop/source/app/officeipcthread.cxx
+++ b/desktop/source/app/officeipcthread.cxx
@@ -37,7 +37,6 @@
#include <rtl/instance.hxx>
#include <osl/conditn.hxx>
#include <unotools/moduleoptions.hxx>
-#include <rtl/bootstrap.hxx>
#include <rtl/strbuf.hxx>
#include <comphelper/processfactory.hxx>
#include <cppuhelper/supportsservice.hxx>
@@ -483,41 +482,7 @@ RequestHandler::Status RequestHandler::Enable(bool ipc)
// First we try to create our pipe if this fails we try to connect. We have to do this
// in a loop because the other office can crash or shutdown between createPipe
// and connectPipe!!
-
- OUString aIniName;
-
- osl_getExecutableFile( &aIniName.pData );
-
- sal_uInt32 lastIndex = aIniName.lastIndexOf('/');
- if ( lastIndex > 0 )
- {
- aIniName = aIniName.copy( 0, lastIndex+1 );
- aIniName += "perftune";
-#if defined(_WIN32)
- aIniName += ".ini";
-#else
- aIniName += "rc";
-#endif
- }
-
- ::rtl::Bootstrap aPerfTuneIniFile( aIniName );
-
- OUString aDefault( "0" );
- OUString aPreloadData;
-
- aPerfTuneIniFile.getFrom( "FastPipeCommunication", aPreloadData, aDefault );
-
- OUString aUserInstallPathHashCode;
-
- if ( aPreloadData == "1" )
- {
- sal_Char szBuffer[32];
- sprintf( szBuffer, "%d", LIBO_VERSION_MAJOR * 10000 + LIBO_VERSION_MINOR * 100 + LIBO_VERSION_MICRO * 1 );
- aUserInstallPathHashCode = OUString( szBuffer, strlen(szBuffer), osl_getThreadTextEncoding() );
- }
- else
- aUserInstallPathHashCode = CreateMD5FromString( aDummy );
-
+ auto aUserInstallPathHashCode = CreateMD5FromString( aDummy );
// Check result to create a hash code from the user install path
if ( aUserInstallPathHashCode.isEmpty() )
diff --git a/desktop/win32/source/officeloader/officeloader.cxx b/desktop/win32/source/officeloader/officeloader.cxx
index 504c000ab143..68c2e5566fbc 100644
--- a/desktop/win32/source/officeloader/officeloader.cxx
+++ b/desktop/win32/source/officeloader/officeloader.cxx
@@ -28,14 +28,12 @@
#pragma warning(push, 1)
#endif
#include <windows.h>
-#include <shellapi.h>
#if defined _MSC_VER
#pragma warning(pop)
#endif
#include <tchar.h>
-#include <malloc.h>
#include <string.h>
#include <stdlib.h>
#include <systools/win32/uwinapi.h>
@@ -48,75 +46,6 @@
#include <config_version.h>
-#define PIPE_PREFIX TEXT("\\\\.\\pipe\\OSL_PIPE_")
-#define PIPE_POSTFIX TEXT("_SingleOfficeIPC_")
-#define PIPE_TERMINATION_SEQUENCE "InternalIPC::ProcessingDone"
-
-BOOL WINAPI ConvertSidToStringSid( PSID pSid, LPTSTR* StringSid )
-{
- PSID_IDENTIFIER_AUTHORITY psia;
- DWORD dwSubAuthorities;
- DWORD dwSidRev=SID_REVISION;
- DWORD dwCounter;
- DWORD dwSidSize;
-
- // Validate the binary SID.
-
- if(!IsValidSid(pSid)) return FALSE;
-
- // Get the identifier authority value from the SID.
-
- psia = GetSidIdentifierAuthority(pSid);
-
- // Get the number of subauthorities in the SID.
-
- dwSubAuthorities = *GetSidSubAuthorityCount(pSid);
-
- // Compute the buffer length.
- // S-SID_REVISION- + IdentifierAuthority- + subauthorities- + NULL
-
- dwSidSize=(15 + 12 + (12 * dwSubAuthorities) + 1) * sizeof(TCHAR);
-
- *StringSid = (LPTSTR)LocalAlloc( LMEM_FIXED, dwSidSize );
-
- // Add 'S' prefix and revision number to the string.
-
- dwSidSize=wsprintf(*StringSid, TEXT("S-%lu-"), dwSidRev );
-
- // Add a SID identifier authority to the string.
-
- if ( (psia->Value[0] != 0) || (psia->Value[1] != 0) )
- {
- dwSidSize+=wsprintf(*StringSid + lstrlen(*StringSid),
- TEXT("0x%02hx%02hx%02hx%02hx%02hx%02hx"),
- (USHORT)psia->Value[0],
- (USHORT)psia->Value[1],
- (USHORT)psia->Value[2],
- (USHORT)psia->Value[3],
- (USHORT)psia->Value[4],
- (USHORT)psia->Value[5]);
- }
- else
- {
- dwSidSize+=wsprintf(*StringSid + lstrlen(*StringSid),
- TEXT("%lu"),
- (ULONG)(psia->Value[5] ) +
- (ULONG)(psia->Value[4] << 8) +
- (ULONG)(psia->Value[3] << 16) +
- (ULONG)(psia->Value[2] << 24) );
- }
-
- // Add SID subauthorities to the string.
- for (dwCounter=0 ; dwCounter < dwSubAuthorities ; dwCounter++)
- {
- dwSidSize+=wsprintf(*StringSid + dwSidSize, TEXT("-%lu"),
- *GetSidSubAuthority(pSid, dwCounter) );
- }
-
- return TRUE;
-}
-
-
static LPTSTR *GetCommandArgs( int *pArgc )
{
#ifdef UNICODE
@@ -171,7 +100,6 @@ int WINAPI _tWinMain( HINSTANCE, HINSTANCE, LPTSTR, int )
{
TCHAR szTargetFileName[MAX_PATH] = TEXT("");
TCHAR szIniDirectory[MAX_PATH];
- TCHAR szPerfTuneIniFile[MAX_PATH] = TEXT("");
STARTUPINFO aStartupInfo;
desktop_win32::getPaths(szTargetFileName, szIniDirectory);
@@ -181,17 +109,6 @@ int WINAPI _tWinMain( HINSTANCE, HINSTANCE, LPTSTR, int )
GetStartupInfo( &aStartupInfo );
- TCHAR szModuleFileName[MAX_PATH];
-
- GetModuleFileName( NULL, szModuleFileName, MAX_PATH );
- _TCHAR *lpLastSlash = _tcsrchr( szModuleFileName, '\\' );
- if ( lpLastSlash )
- {
- size_t len = lpLastSlash - szModuleFileName + 1;
- _tcsncpy( szPerfTuneIniFile, szModuleFileName, len );
- _tcsncpy( szPerfTuneIniFile + len, _T("perftune.ini"), SAL_N_ELEMENTS(szPerfTuneIniFile) - len );
- }
-
// Create process with same command line, environment and stdio handles which
// are directed to the created pipes
@@ -210,119 +127,6 @@ int WINAPI _tWinMain( HINSTANCE, HINSTANCE, LPTSTR, int )
do
{
- TCHAR szKey[32];
-
- GetPrivateProfileString(
- TEXT("PerformanceTuning"),
- TEXT("FastPipeCommunication"),
- TEXT("0"),
- szKey,
- SAL_N_ELEMENTS(szKey),
- szPerfTuneIniFile
- );
-
- if ( 0 == _tcscmp( szKey, TEXT("1") ) )
- {
- HANDLE hProcessToken;
-
- if ( OpenProcessToken( GetCurrentProcess(), TOKEN_QUERY, &hProcessToken ) )
- {
- TCHAR szPipeName[4096];
-
-
- DWORD dwTokenLength = 0;
-
-
- fSuccess = GetTokenInformation( hProcessToken, TokenUser, NULL, dwTokenLength, &dwTokenLength );
-
- PVOID pTokenInfo = _alloca(dwTokenLength);
- fSuccess = GetTokenInformation( hProcessToken, TokenUser, pTokenInfo, dwTokenLength, &dwTokenLength );
- CloseHandle( hProcessToken );
-
- PSID pSid = ((PTOKEN_USER)pTokenInfo)->User.Sid;
- LPTSTR szUserIdent = NULL;
- TCHAR szSUPD[11] = TEXT("0");
-
- fSuccess = ConvertSidToStringSid( pSid, &szUserIdent );
-
- _tcsncpy( szPipeName, PIPE_PREFIX, SAL_N_ELEMENTS(szPipeName) );
- _tcsncat( szPipeName, szUserIdent, SAL_N_ELEMENTS(szPipeName) - _tcslen(szPipeName) - 1 );
- _tcsncat( szPipeName, PIPE_POSTFIX, SAL_N_ELEMENTS(szPipeName) - _tcslen(szPipeName) - 1 );
- _tcsncat( szPipeName, _ultot( LIBO_VERSION_MAJOR * 10000 + LIBO_VERSION_MINOR * 100 + LIBO_VERSION_MICRO * 1
- , szSUPD, 10), SAL_N_ELEMENTS(szPipeName) - _tcslen(szPipeName) - 1 );
-
- LocalFree( szUserIdent );
-
- HANDLE hPipe = CreateFile(
- szPipeName,
- GENERIC_READ|GENERIC_WRITE,
- FILE_SHARE_READ | FILE_SHARE_WRITE,
- NULL,
- OPEN_EXISTING,
- FILE_ATTRIBUTE_NORMAL,
- NULL);
-
- if ( INVALID_HANDLE_VALUE != hPipe )
- {
- DWORD dwBytesRead = 0;
- char *pBuffer = (char *)_alloca( sizeof("InternalIPC::SendArguments") + 1);
- fSuccess = ReadFile( hPipe, pBuffer, sizeof("InternalIPC::SendArguments") + 1, &dwBytesRead, NULL );
- if ( fSuccess )
- {
- fSuccess = (dwBytesRead == (sizeof("InternalIPC::SendArguments") + 1) &&
- 0 == strncmp( "InternalIPC::SendArguments", pBuffer, dwBytesRead - 1 ) );
- }
- if ( fSuccess )
- {
- DWORD dwBytesWritten;
- int argc2 = 0;
- LPWSTR *argv2 = CommandLineToArgvW( GetCommandLine(), &argc2 );
-
- fSuccess = WriteFile( hPipe, RTL_CONSTASCII_STRINGPARAM("InternalIPC::Arguments"), &dwBytesWritten, NULL );
- if (fSuccess) {
- if (cwdLen > 0) {
- fSuccess = writeArgument(hPipe, '2', cwd);
- } else {
- fSuccess = WriteFile(
- hPipe, RTL_CONSTASCII_STRINGPARAM("0"),
- &dwBytesWritten, NULL);
- }
- }
- for ( int argn = 1; fSuccess && argn < argc2; argn++ )
- {
- if (std::wcsncmp(
- argv2[argn], L"-env:", std::wcslen(L"-env:"))
- != 0)
- {
- fSuccess = writeArgument(hPipe, ',', argv2[argn]);
- }
- }
-
- if ( fSuccess )
- {
- fSuccess = WriteFile( hPipe, "", 1, &dwBytesWritten, NULL );
- if ( fSuccess )
- {
- DWORD dwBytesRead2 = 0;
- char *pBuffer2 = (char *)_alloca( sizeof(PIPE_TERMINATION_SEQUENCE) );
- fSuccess = ReadFile( hPipe, pBuffer2, sizeof(PIPE_TERMINATION_SEQUENCE) - 1, &dwBytesRead2, NULL );
- if ( fSuccess )
- {
- pBuffer2[dwBytesRead2] = 0;
- if ( 0 != strcmp( PIPE_TERMINATION_SEQUENCE, pBuffer2 ) )
- fSuccess = FALSE;
- }
- }
- }
- }
- CloseHandle( hPipe );
-
- return fSuccess ? 0 : -1;
- }
-
- }
- }
-
if ( bFirst ) {
argv = GetCommandArgs(&argc);
std::size_t n = wcslen(argv[0]) + 2;