Commit ec48726f authored by Jacek Caban's avatar Jacek Caban Committed by Alexandre Julliard

Always add gecko directory to the path before loading xpcom.

parent 80af4940
...@@ -178,8 +178,11 @@ static BOOL load_gecko() ...@@ -178,8 +178,11 @@ static BOOL load_gecko()
nsString path; nsString path;
nsIFile *gre_dir; nsIFile *gre_dir;
PRUnichar gre_path[MAX_PATH]; PRUnichar gre_path[MAX_PATH];
WCHAR path_env[MAX_PATH];
int len;
static BOOL tried_load = FALSE; static BOOL tried_load = FALSE;
static const WCHAR wszPATH[] = {'P','A','T','H',0};
static const WCHAR strXPCOM[] = {'x','p','c','o','m','.','d','l','l',0}; static const WCHAR strXPCOM[] = {'x','p','c','o','m','.','d','l','l',0};
TRACE("()\n"); TRACE("()\n");
...@@ -195,13 +198,7 @@ static BOOL load_gecko() ...@@ -195,13 +198,7 @@ static BOOL load_gecko()
TRACE("found path %s\n", debugstr_w(gre_path)); TRACE("found path %s\n", debugstr_w(gre_path));
hXPCOM = LoadLibraryW(strXPCOM);
if(!hXPCOM) {
/* We have to modify PATH as XPCOM loads other DLLs from this directory. */ /* We have to modify PATH as XPCOM loads other DLLs from this directory. */
WCHAR path_env[MAX_PATH];
static WCHAR wszPATH[] = {'P','A','T','H',0};
int len;
GetEnvironmentVariableW(wszPATH, path_env, sizeof(path_env)/sizeof(WCHAR)); GetEnvironmentVariableW(wszPATH, path_env, sizeof(path_env)/sizeof(WCHAR));
len = strlenW(path_env); len = strlenW(path_env);
path_env[len++] = ';'; path_env[len++] = ';';
...@@ -213,7 +210,6 @@ static BOOL load_gecko() ...@@ -213,7 +210,6 @@ static BOOL load_gecko()
ERR("Could not load XPCOM: %ld\n", GetLastError()); ERR("Could not load XPCOM: %ld\n", GetLastError());
return FALSE; return FALSE;
} }
}
#define NS_DLSYM(func) \ #define NS_DLSYM(func) \
func = (typeof(func))GetProcAddress(hXPCOM, #func); \ func = (typeof(func))GetProcAddress(hXPCOM, #func); \
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment