1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski // Use UNICODE Windows and C API.
25*b1cdbd2cSJim Jagielski #define _UNICODE
26*b1cdbd2cSJim Jagielski #define UNICODE
27*b1cdbd2cSJim Jagielski 
28*b1cdbd2cSJim Jagielski #ifdef _MSC_VER
29*b1cdbd2cSJim Jagielski #pragma warning(push, 1)
30*b1cdbd2cSJim Jagielski #endif
31*b1cdbd2cSJim Jagielski #include <windows.h>
32*b1cdbd2cSJim Jagielski #include "uno/environment.hxx"
33*b1cdbd2cSJim Jagielski #ifdef _MSC_VER
34*b1cdbd2cSJim Jagielski #pragma warning(pop)
35*b1cdbd2cSJim Jagielski #endif
36*b1cdbd2cSJim Jagielski 
37*b1cdbd2cSJim Jagielski #include <tchar.h>
38*b1cdbd2cSJim Jagielski 
39*b1cdbd2cSJim Jagielski #include "native_share.h"
40*b1cdbd2cSJim Jagielski 
41*b1cdbd2cSJim Jagielski #include "rtl/bootstrap.hxx"
42*b1cdbd2cSJim Jagielski #include "com/sun/star/uno/XComponentContext.hpp"
43*b1cdbd2cSJim Jagielski #include "cppuhelper/bootstrap.hxx"
44*b1cdbd2cSJim Jagielski #include <delayimp.h>
45*b1cdbd2cSJim Jagielski #include <stdio.h>
46*b1cdbd2cSJim Jagielski 
47*b1cdbd2cSJim Jagielski using namespace ::rtl;
48*b1cdbd2cSJim Jagielski using namespace ::com::sun::star;
49*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::uno;
50*b1cdbd2cSJim Jagielski 
51*b1cdbd2cSJim Jagielski namespace cli_ure {
52*b1cdbd2cSJim Jagielski     WCHAR * resolveLink(WCHAR * path);
53*b1cdbd2cSJim Jagielski }
54*b1cdbd2cSJim Jagielski 
55*b1cdbd2cSJim Jagielski // INSTALL_PATH value needs to correspond to the Windows registry subkey
56*b1cdbd2cSJim Jagielski // in main\scp2\source\ooo\registryitem_ooo.scp
57*b1cdbd2cSJim Jagielski #define INSTALL_PATH L"Software\\OpenOffice\\UNO\\InstallPath"
58*b1cdbd2cSJim Jagielski #define INSTALL_PATH_64 L"Software\\Wow6432Node\\OpenOffice\\UNO\\InstallPath"
59*b1cdbd2cSJim Jagielski #define UNO_PATH L"UNO_PATH"
60*b1cdbd2cSJim Jagielski 
61*b1cdbd2cSJim Jagielski namespace
62*b1cdbd2cSJim Jagielski {
63*b1cdbd2cSJim Jagielski 
64*b1cdbd2cSJim Jagielski  /*
65*b1cdbd2cSJim Jagielski  * Gets the installation path from the Windows Registry for the specified
66*b1cdbd2cSJim Jagielski  * registry key.
67*b1cdbd2cSJim Jagielski  *
68*b1cdbd2cSJim Jagielski  * @param hroot       open handle to predefined root registry key
69*b1cdbd2cSJim Jagielski  * @param subKeyName  name of the subkey to open
70*b1cdbd2cSJim Jagielski  *
71*b1cdbd2cSJim Jagielski  * @return the installation path or NULL, if no installation was found or
72*b1cdbd2cSJim Jagielski  *         if an error occured
73*b1cdbd2cSJim Jagielski  */
getPathFromRegistryKey(HKEY hroot,LPCWSTR subKeyName)74*b1cdbd2cSJim Jagielski WCHAR* getPathFromRegistryKey( HKEY hroot, LPCWSTR subKeyName )
75*b1cdbd2cSJim Jagielski {
76*b1cdbd2cSJim Jagielski     HKEY hkey;
77*b1cdbd2cSJim Jagielski     DWORD type;
78*b1cdbd2cSJim Jagielski     TCHAR* data = NULL;
79*b1cdbd2cSJim Jagielski     DWORD size;
80*b1cdbd2cSJim Jagielski 
81*b1cdbd2cSJim Jagielski     /* open the specified registry key */
82*b1cdbd2cSJim Jagielski     if ( RegOpenKeyEx( hroot, subKeyName, 0, KEY_READ, &hkey ) != ERROR_SUCCESS )
83*b1cdbd2cSJim Jagielski     {
84*b1cdbd2cSJim Jagielski         return NULL;
85*b1cdbd2cSJim Jagielski     }
86*b1cdbd2cSJim Jagielski 
87*b1cdbd2cSJim Jagielski     /* find the type and size of the default value */
88*b1cdbd2cSJim Jagielski     if ( RegQueryValueEx( hkey, NULL, NULL, &type, NULL, &size) != ERROR_SUCCESS )
89*b1cdbd2cSJim Jagielski     {
90*b1cdbd2cSJim Jagielski         RegCloseKey( hkey );
91*b1cdbd2cSJim Jagielski         return NULL;
92*b1cdbd2cSJim Jagielski     }
93*b1cdbd2cSJim Jagielski 
94*b1cdbd2cSJim Jagielski     /* get memory to hold the default value */
95*b1cdbd2cSJim Jagielski     data = new WCHAR[size];
96*b1cdbd2cSJim Jagielski 
97*b1cdbd2cSJim Jagielski     /* read the default value */
98*b1cdbd2cSJim Jagielski     if ( RegQueryValueEx( hkey, NULL, NULL, &type, (LPBYTE) data, &size ) != ERROR_SUCCESS )
99*b1cdbd2cSJim Jagielski     {
100*b1cdbd2cSJim Jagielski         RegCloseKey( hkey );
101*b1cdbd2cSJim Jagielski         return NULL;
102*b1cdbd2cSJim Jagielski     }
103*b1cdbd2cSJim Jagielski 
104*b1cdbd2cSJim Jagielski     /* release registry key handle */
105*b1cdbd2cSJim Jagielski     RegCloseKey( hkey );
106*b1cdbd2cSJim Jagielski 
107*b1cdbd2cSJim Jagielski     return data;
108*b1cdbd2cSJim Jagielski }
109*b1cdbd2cSJim Jagielski 
110*b1cdbd2cSJim Jagielski /* Returns the path to the program folder of the brand layer,
111*b1cdbd2cSJim Jagielski     for example c:/openoffice.org 3/program
112*b1cdbd2cSJim Jagielski    This path is either obtained from the environment variable UNO_PATH
113*b1cdbd2cSJim Jagielski    or the registry item
114*b1cdbd2cSJim Jagielski    "Software\\OpenOffice\\UNO\\InstallPath"
115*b1cdbd2cSJim Jagielski    either in HKEY_CURRENT_USER or HKEY_LOCAL_MACHINE
116*b1cdbd2cSJim Jagielski    The return value must be freed with delete[]
117*b1cdbd2cSJim Jagielski */
getInstallPath()118*b1cdbd2cSJim Jagielski WCHAR * getInstallPath()
119*b1cdbd2cSJim Jagielski {
120*b1cdbd2cSJim Jagielski     WCHAR * szInstallPath = NULL;
121*b1cdbd2cSJim Jagielski 
122*b1cdbd2cSJim Jagielski     DWORD  cChars = GetEnvironmentVariable(UNO_PATH, NULL, 0);
123*b1cdbd2cSJim Jagielski     if (cChars > 0)
124*b1cdbd2cSJim Jagielski     {
125*b1cdbd2cSJim Jagielski         szInstallPath = new WCHAR[cChars+1];
126*b1cdbd2cSJim Jagielski         cChars = GetEnvironmentVariable(UNO_PATH, szInstallPath, cChars+1);
127*b1cdbd2cSJim Jagielski 		//If PATH is not set then it is no error
128*b1cdbd2cSJim Jagielski 		if (cChars == 0)
129*b1cdbd2cSJim Jagielski 		{
130*b1cdbd2cSJim Jagielski 			delete[] szInstallPath;
131*b1cdbd2cSJim Jagielski 			return NULL;
132*b1cdbd2cSJim Jagielski 		}
133*b1cdbd2cSJim Jagielski     }
134*b1cdbd2cSJim Jagielski 
135*b1cdbd2cSJim Jagielski     if (! szInstallPath)
136*b1cdbd2cSJim Jagielski     {
137*b1cdbd2cSJim Jagielski         szInstallPath = getPathFromRegistryKey( HKEY_CURRENT_USER, INSTALL_PATH );
138*b1cdbd2cSJim Jagielski         if ( szInstallPath == NULL )
139*b1cdbd2cSJim Jagielski         {
140*b1cdbd2cSJim Jagielski             /* read the key's default value from HKEY_LOCAL_USER */
141*b1cdbd2cSJim Jagielski             szInstallPath = getPathFromRegistryKey( HKEY_CURRENT_USER, INSTALL_PATH_64 );
142*b1cdbd2cSJim Jagielski         }
143*b1cdbd2cSJim Jagielski         if ( szInstallPath == NULL )
144*b1cdbd2cSJim Jagielski         {
145*b1cdbd2cSJim Jagielski             /* read the key's default value from HKEY_LOCAL_MACHINE */
146*b1cdbd2cSJim Jagielski             szInstallPath = getPathFromRegistryKey( HKEY_LOCAL_MACHINE, INSTALL_PATH );
147*b1cdbd2cSJim Jagielski         }
148*b1cdbd2cSJim Jagielski         if ( szInstallPath == NULL )
149*b1cdbd2cSJim Jagielski         {
150*b1cdbd2cSJim Jagielski             /* read the key's default value from HKEY_LOCAL_MACHINE */
151*b1cdbd2cSJim Jagielski             szInstallPath = getPathFromRegistryKey( HKEY_LOCAL_MACHINE, INSTALL_PATH_64 );
152*b1cdbd2cSJim Jagielski         }
153*b1cdbd2cSJim Jagielski     }
154*b1cdbd2cSJim Jagielski     return szInstallPath;
155*b1cdbd2cSJim Jagielski }
156*b1cdbd2cSJim Jagielski 
157*b1cdbd2cSJim Jagielski 
158*b1cdbd2cSJim Jagielski /*We extend the path to contain the Ure/bin folder,
159*b1cdbd2cSJim Jagielski   so that components can use osl_loadModule with arguments, such as
160*b1cdbd2cSJim Jagielski   "reg3.dll". That is, the arguments are only the library names.
161*b1cdbd2cSJim Jagielski */
extendPath(LPCWSTR szUreBinPath)162*b1cdbd2cSJim Jagielski void extendPath(LPCWSTR szUreBinPath)
163*b1cdbd2cSJim Jagielski {
164*b1cdbd2cSJim Jagielski 	if (!szUreBinPath)
165*b1cdbd2cSJim Jagielski 		return;
166*b1cdbd2cSJim Jagielski 
167*b1cdbd2cSJim Jagielski     WCHAR * sEnvPath = NULL;
168*b1cdbd2cSJim Jagielski     DWORD  cChars = GetEnvironmentVariable(L"PATH", sEnvPath, 0);
169*b1cdbd2cSJim Jagielski     if (cChars > 0)
170*b1cdbd2cSJim Jagielski     {
171*b1cdbd2cSJim Jagielski         sEnvPath = new WCHAR[cChars];
172*b1cdbd2cSJim Jagielski         cChars = GetEnvironmentVariable(L"PATH", sEnvPath, cChars);
173*b1cdbd2cSJim Jagielski 		//If PATH is not set then it is no error
174*b1cdbd2cSJim Jagielski 		if (cChars == 0 && GetLastError() != ERROR_ENVVAR_NOT_FOUND)
175*b1cdbd2cSJim Jagielski 		{
176*b1cdbd2cSJim Jagielski 			delete[] sEnvPath;
177*b1cdbd2cSJim Jagielski 			return;
178*b1cdbd2cSJim Jagielski 		}
179*b1cdbd2cSJim Jagielski     }
180*b1cdbd2cSJim Jagielski     //prepare the new PATH. Add the Ure/bin directory at the front.
181*b1cdbd2cSJim Jagielski     //note also adding ';'
182*b1cdbd2cSJim Jagielski     WCHAR * sNewPath = new WCHAR[lstrlen(sEnvPath) + lstrlen(szUreBinPath) + 2];
183*b1cdbd2cSJim Jagielski     sNewPath[0] = L'\0';
184*b1cdbd2cSJim Jagielski 	lstrcat(sNewPath, szUreBinPath);
185*b1cdbd2cSJim Jagielski 	if (lstrlen(sEnvPath))
186*b1cdbd2cSJim Jagielski 	{
187*b1cdbd2cSJim Jagielski 		lstrcat(sNewPath, L";");
188*b1cdbd2cSJim Jagielski 		lstrcat(sNewPath, sEnvPath);
189*b1cdbd2cSJim Jagielski 	}
190*b1cdbd2cSJim Jagielski     BOOL bSet = SetEnvironmentVariable(L"PATH", sNewPath);
191*b1cdbd2cSJim Jagielski 
192*b1cdbd2cSJim Jagielski     delete[] sEnvPath;
193*b1cdbd2cSJim Jagielski     delete[] sNewPath;
194*b1cdbd2cSJim Jagielski }
195*b1cdbd2cSJim Jagielski 
196*b1cdbd2cSJim Jagielski 
loadFromPath(LPCWSTR sLibName)197*b1cdbd2cSJim Jagielski HMODULE loadFromPath(LPCWSTR sLibName)
198*b1cdbd2cSJim Jagielski {
199*b1cdbd2cSJim Jagielski 	if (sLibName == NULL)
200*b1cdbd2cSJim Jagielski 		return NULL;
201*b1cdbd2cSJim Jagielski 
202*b1cdbd2cSJim Jagielski 	WCHAR * szUreBinPath =  getInstallPath();
203*b1cdbd2cSJim Jagielski 	if (!szUreBinPath)
204*b1cdbd2cSJim Jagielski 		return NULL;
205*b1cdbd2cSJim Jagielski 
206*b1cdbd2cSJim Jagielski     extendPath(szUreBinPath);
207*b1cdbd2cSJim Jagielski 
208*b1cdbd2cSJim Jagielski     WCHAR*  szFullPath = new WCHAR[lstrlen(sLibName) + lstrlen(szUreBinPath) + 2];
209*b1cdbd2cSJim Jagielski     szFullPath[0] = L'\0';
210*b1cdbd2cSJim Jagielski     lstrcat(szFullPath, szUreBinPath);
211*b1cdbd2cSJim Jagielski     lstrcat(szFullPath, L"\\");
212*b1cdbd2cSJim Jagielski     lstrcat(szFullPath, sLibName);
213*b1cdbd2cSJim Jagielski     HMODULE handle = LoadLibraryEx(szFullPath, NULL,
214*b1cdbd2cSJim Jagielski 		LOAD_WITH_ALTERED_SEARCH_PATH);
215*b1cdbd2cSJim Jagielski 
216*b1cdbd2cSJim Jagielski     delete[] szFullPath;
217*b1cdbd2cSJim Jagielski     delete[] szUreBinPath;
218*b1cdbd2cSJim Jagielski 	return handle;
219*b1cdbd2cSJim Jagielski }
220*b1cdbd2cSJim Jagielski 
221*b1cdbd2cSJim Jagielski /*Hook for delayed loading of libraries which this library is linked with.
222*b1cdbd2cSJim Jagielski     This is a failure hook. That is, it is only called when the loading of
223*b1cdbd2cSJim Jagielski     a library failed. It will be called when loading of cppuhelper failed.
224*b1cdbd2cSJim Jagielski     Because we extend the PATH to the URE/bin folder while this function is
225*b1cdbd2cSJim Jagielski     executed (see extendPath), all other libraries are found.
226*b1cdbd2cSJim Jagielski */
delayLoadHook(unsigned dliNotify,PDelayLoadInfo pdli)227*b1cdbd2cSJim Jagielski extern "C" FARPROC WINAPI delayLoadHook(
228*b1cdbd2cSJim Jagielski     unsigned        dliNotify,
229*b1cdbd2cSJim Jagielski     PDelayLoadInfo  pdli
230*b1cdbd2cSJim Jagielski     )
231*b1cdbd2cSJim Jagielski {
232*b1cdbd2cSJim Jagielski     if (dliNotify == dliFailLoadLib)
233*b1cdbd2cSJim Jagielski     {
234*b1cdbd2cSJim Jagielski         LPWSTR szLibName = NULL;
235*b1cdbd2cSJim Jagielski      	//Convert the ansi file name to wchar_t*
236*b1cdbd2cSJim Jagielski 		int size = MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, pdli->szDll, -1, NULL, 0);
237*b1cdbd2cSJim Jagielski 		if (size > 0)
238*b1cdbd2cSJim Jagielski 		{
239*b1cdbd2cSJim Jagielski 			szLibName = new WCHAR[size];
240*b1cdbd2cSJim Jagielski 			if (! MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, pdli->szDll, -1, szLibName, size))
241*b1cdbd2cSJim Jagielski 			{
242*b1cdbd2cSJim Jagielski                 return 0;
243*b1cdbd2cSJim Jagielski 			}
244*b1cdbd2cSJim Jagielski 		}
245*b1cdbd2cSJim Jagielski         HANDLE h = loadFromPath(szLibName);
246*b1cdbd2cSJim Jagielski         delete[] szLibName;
247*b1cdbd2cSJim Jagielski 		return (FARPROC) h;
248*b1cdbd2cSJim Jagielski     }
249*b1cdbd2cSJim Jagielski     return 0;
250*b1cdbd2cSJim Jagielski }
251*b1cdbd2cSJim Jagielski }
252*b1cdbd2cSJim Jagielski 
253*b1cdbd2cSJim Jagielski ExternC
254*b1cdbd2cSJim Jagielski PfnDliHook   __pfnDliFailureHook2 = delayLoadHook;
255*b1cdbd2cSJim Jagielski 
256*b1cdbd2cSJim Jagielski namespace uno
257*b1cdbd2cSJim Jagielski {
258*b1cdbd2cSJim Jagielski namespace util
259*b1cdbd2cSJim Jagielski {
260*b1cdbd2cSJim Jagielski 
261*b1cdbd2cSJim Jagielski /** Bootstrapping native UNO.
262*b1cdbd2cSJim Jagielski 
263*b1cdbd2cSJim Jagielski     Bootstrapping requires the existence of many libraries which are contained
264*b1cdbd2cSJim Jagielski     in an URE installation. To find and load these libraries the Windows
265*b1cdbd2cSJim Jagielski     registry keys HKEY_CURRENT_USER\Software\OpenOffice\UNO\InstallPath
266*b1cdbd2cSJim Jagielski     and HKEY_LOCAL_MACHINE\Software\OpenOffice\UNO\InstallPath are examined.
267*b1cdbd2cSJim Jagielski     The default value contain the path to the office prgoram dir. No seaparate URE
268*b1cdbd2cSJim Jagielski     anymore.
269*b1cdbd2cSJim Jagielski */
270*b1cdbd2cSJim Jagielski public __sealed __gc class Bootstrap
271*b1cdbd2cSJim Jagielski {
272*b1cdbd2cSJim Jagielski     inline Bootstrap() {}
273*b1cdbd2cSJim Jagielski 
274*b1cdbd2cSJim Jagielski public:
275*b1cdbd2cSJim Jagielski 
276*b1cdbd2cSJim Jagielski     /** Bootstraps the initial component context from a native UNO installation.
277*b1cdbd2cSJim Jagielski 
278*b1cdbd2cSJim Jagielski         @see cppuhelper/bootstrap.hxx:defaultBootstrap_InitialComponentContext()
279*b1cdbd2cSJim Jagielski     */
280*b1cdbd2cSJim Jagielski     static ::unoidl::com::sun::star::uno::XComponentContext *
281*b1cdbd2cSJim Jagielski         defaultBootstrap_InitialComponentContext();
282*b1cdbd2cSJim Jagielski 
283*b1cdbd2cSJim Jagielski     /** Bootstraps the initial component context from a native UNO installation.
284*b1cdbd2cSJim Jagielski 
285*b1cdbd2cSJim Jagielski         @param ini_file
286*b1cdbd2cSJim Jagielski                a file URL of an ini file, e.g. uno.ini/unorc. (The ini file must
287*b1cdbd2cSJim Jagielski                reside next to the cppuhelper library)
288*b1cdbd2cSJim Jagielski         @param bootstrap_parameters
289*b1cdbd2cSJim Jagielski                bootstrap parameters (maybe null)
290*b1cdbd2cSJim Jagielski 
291*b1cdbd2cSJim Jagielski         @see cppuhelper/bootstrap.hxx:defaultBootstrap_InitialComponentContext()
292*b1cdbd2cSJim Jagielski     */
293*b1cdbd2cSJim Jagielski     static ::unoidl::com::sun::star::uno::XComponentContext *
294*b1cdbd2cSJim Jagielski         defaultBootstrap_InitialComponentContext(
295*b1cdbd2cSJim Jagielski             ::System::String * ini_file,
296*b1cdbd2cSJim Jagielski             ::System::Collections::IDictionaryEnumerator *
297*b1cdbd2cSJim Jagielski               bootstrap_parameters );
298*b1cdbd2cSJim Jagielski 
299*b1cdbd2cSJim Jagielski     /** Bootstraps the initial component context from a native UNO installation.
300*b1cdbd2cSJim Jagielski 
301*b1cdbd2cSJim Jagielski     @see cppuhelper/bootstrap.hxx:bootstrap()
302*b1cdbd2cSJim Jagielski      */
303*b1cdbd2cSJim Jagielski     static ::unoidl::com::sun::star::uno::XComponentContext *
304*b1cdbd2cSJim Jagielski     bootstrap();
305*b1cdbd2cSJim Jagielski };
306*b1cdbd2cSJim Jagielski 
307*b1cdbd2cSJim Jagielski //______________________________________________________________________________
308*b1cdbd2cSJim Jagielski ::unoidl::com::sun::star::uno::XComponentContext *
309*b1cdbd2cSJim Jagielski Bootstrap::defaultBootstrap_InitialComponentContext(
310*b1cdbd2cSJim Jagielski     ::System::String * ini_file,
311*b1cdbd2cSJim Jagielski     ::System::Collections::IDictionaryEnumerator * bootstrap_parameters )
312*b1cdbd2cSJim Jagielski {
313*b1cdbd2cSJim Jagielski     if (0 != bootstrap_parameters)
314*b1cdbd2cSJim Jagielski     {
315*b1cdbd2cSJim Jagielski         bootstrap_parameters->Reset();
316*b1cdbd2cSJim Jagielski         while (bootstrap_parameters->MoveNext())
317*b1cdbd2cSJim Jagielski         {
318*b1cdbd2cSJim Jagielski             OUString key(
319*b1cdbd2cSJim Jagielski                 String_to_ustring( __try_cast< ::System::String * >(
320*b1cdbd2cSJim Jagielski                                        bootstrap_parameters->get_Key() ) ) );
321*b1cdbd2cSJim Jagielski             OUString value(
322*b1cdbd2cSJim Jagielski                 String_to_ustring( __try_cast< ::System::String * >(
323*b1cdbd2cSJim Jagielski                                        bootstrap_parameters->get_Value() ) ) );
324*b1cdbd2cSJim Jagielski 
325*b1cdbd2cSJim Jagielski             ::rtl::Bootstrap::set( key, value );
326*b1cdbd2cSJim Jagielski         }
327*b1cdbd2cSJim Jagielski     }
328*b1cdbd2cSJim Jagielski 
329*b1cdbd2cSJim Jagielski     // bootstrap native uno
330*b1cdbd2cSJim Jagielski     Reference< XComponentContext > xContext;
331*b1cdbd2cSJim Jagielski     if (0 == ini_file)
332*b1cdbd2cSJim Jagielski     {
333*b1cdbd2cSJim Jagielski         xContext = ::cppu::defaultBootstrap_InitialComponentContext();
334*b1cdbd2cSJim Jagielski     }
335*b1cdbd2cSJim Jagielski     else
336*b1cdbd2cSJim Jagielski     {
337*b1cdbd2cSJim Jagielski         xContext = ::cppu::defaultBootstrap_InitialComponentContext(
338*b1cdbd2cSJim Jagielski             String_to_ustring( __try_cast< ::System::String * >( ini_file ) ) );
339*b1cdbd2cSJim Jagielski     }
340*b1cdbd2cSJim Jagielski 
341*b1cdbd2cSJim Jagielski     return __try_cast< ::unoidl::com::sun::star::uno::XComponentContext * >(
342*b1cdbd2cSJim Jagielski         to_cli( xContext ) );
343*b1cdbd2cSJim Jagielski }
344*b1cdbd2cSJim Jagielski 
345*b1cdbd2cSJim Jagielski //______________________________________________________________________________
346*b1cdbd2cSJim Jagielski ::unoidl::com::sun::star::uno::XComponentContext *
347*b1cdbd2cSJim Jagielski Bootstrap::defaultBootstrap_InitialComponentContext()
348*b1cdbd2cSJim Jagielski {
349*b1cdbd2cSJim Jagielski     return defaultBootstrap_InitialComponentContext( 0, 0 );
350*b1cdbd2cSJim Jagielski }
351*b1cdbd2cSJim Jagielski 
352*b1cdbd2cSJim Jagielski ::unoidl::com::sun::star::uno::XComponentContext * Bootstrap::bootstrap()
353*b1cdbd2cSJim Jagielski {
354*b1cdbd2cSJim Jagielski     Reference<XComponentContext> xContext = ::cppu::bootstrap();
355*b1cdbd2cSJim Jagielski     return __try_cast< ::unoidl::com::sun::star::uno::XComponentContext * >(
356*b1cdbd2cSJim Jagielski         to_cli( xContext ) );
357*b1cdbd2cSJim Jagielski 
358*b1cdbd2cSJim Jagielski }
359*b1cdbd2cSJim Jagielski 
360*b1cdbd2cSJim Jagielski }
361*b1cdbd2cSJim Jagielski }
362