aboutsummaryrefslogtreecommitdiffstats
path: root/find_java/src
diff options
context:
space:
mode:
authorDavid Herman <davidherman@google.com>2014-10-15 09:03:35 -0700
committerDavid Herman <davidherman@google.com>2014-10-17 14:29:53 -0700
commit127af49b6548e0a20cb02fa8ce86c90d1da7f875 (patch)
treea20b324633bd7b5ac4c3a4ceadc09b1ef408a357 /find_java/src
parent411ca610db2c1b2e4ba677819c38b39c41bc9979 (diff)
downloadsdk-127af49b6548e0a20cb02fa8ce86c90d1da7f875.zip
sdk-127af49b6548e0a20cb02fa8ce86c90d1da7f875.tar.gz
sdk-127af49b6548e0a20cb02fa8ce86c90d1da7f875.tar.bz2
find_java now supports 64-bit builds
Change-Id: I46f2462f396c7c2f40238b7da438189b9de02a15
Diffstat (limited to 'find_java/src')
-rw-r--r--find_java/src/source/find_java_exe.cpp5
-rwxr-xr-xfind_java/src/source/find_java_lib.cpp80
-rwxr-xr-xfind_java/src/source/utils.h30
3 files changed, 38 insertions, 77 deletions
diff --git a/find_java/src/source/find_java_exe.cpp b/find_java/src/source/find_java_exe.cpp
index 6b1add9..fa5746a 100644
--- a/find_java/src/source/find_java_exe.cpp
+++ b/find_java/src/source/find_java_exe.cpp
@@ -117,15 +117,12 @@ int main(int argc, char* argv[]) {
_ASSERT(!javaPath.isEmpty());
if (doShortPath) {
- PVOID oldWow64Value = disableWow64FsRedirection();
if (!javaPath.toShortPath(&javaPath)) {
- revertWow64FsRedirection(&oldWow64Value);
fprintf(stderr,
"Failed to convert path to a short DOS path: %s\n",
javaPath.cstr());
return 1;
}
- revertWow64FsRedirection(&oldWow64Value);
}
if (doVersion) {
@@ -140,11 +137,9 @@ int main(int argc, char* argv[]) {
CPath javawPath(javaPath);
javawPath.replaceName("java.exe", "javaw.exe");
// Only accept it if we can actually find the exec
- PVOID oldWow64Value = disableWow64FsRedirection();
if (javawPath.fileExists()) {
javaPath.set(javawPath.cstr());
}
- revertWow64FsRedirection(&oldWow64Value);
}
// Print java.exe path found
diff --git a/find_java/src/source/find_java_lib.cpp b/find_java/src/source/find_java_lib.cpp
index f292171..95d0729 100755
--- a/find_java/src/source/find_java_lib.cpp
+++ b/find_java/src/source/find_java_lib.cpp
@@ -35,6 +35,17 @@
typedef LONG LSTATUS;
#endif
+// Check to see if the application is running in 32-bit or 64-bit mode. In other words, this will
+// return false if you run a 32-bit build even on a 64-bit machine.
+static bool isApplication64() {
+ SYSTEM_INFO sysInfo;
+ GetSystemInfo(&sysInfo);
+
+ // Note: The constant name here is a bit misleading, as it actually covers all 64-bit processors
+ // and not just AMD.
+ // See also: http://msdn.microsoft.com/en-us/library/windows/desktop/ms724958(v=vs.85).aspx
+ return (sysInfo.wProcessorArchitecture == PROCESSOR_ARCHITECTURE_AMD64);
+}
// Extract the first thing that looks like (digit.digit+).
// Note: this will break when java reports a version with major > 9.
@@ -79,7 +90,6 @@ static int checkPath(CPath *inOutPath) {
inOutPath->addPath("java.exe");
int result = 0;
- PVOID oldWow64Value = disableWow64FsRedirection();
if (inOutPath->fileExists()) {
// Run java -version
// Reject the version if it's not at least our current minimum.
@@ -88,7 +98,6 @@ static int checkPath(CPath *inOutPath) {
}
}
- revertWow64FsRedirection(oldWow64Value);
return result;
}
@@ -305,44 +314,18 @@ static bool getMaxJavaInRegistry(const char *entry, REGSAM access, CPath *outJav
}
int findJavaInRegistry(CPath *outJavaPath) {
- // We'll do the registry test 3 times: first using the default mode,
- // then forcing the use of the 32-bit registry then forcing the use of
- // 64-bit registry. On Windows 2k, the 2 latter will fail since the
- // flags are not supported. On a 32-bit OS the 64-bit is obviously
- // useless and the 2 first tests should be equivalent so we just
- // need the first case.
-
// Check the JRE first, then the JDK.
int version = MIN_JAVA_VERSION - 1;
bool result = false;
result |= getMaxJavaInRegistry("Java Runtime Environment", 0, outJavaPath, &version);
result |= getMaxJavaInRegistry("Java Development Kit", 0, outJavaPath, &version);
- // Get the app sysinfo state (the one hidden by WOW64)
- SYSTEM_INFO sysInfo;
- GetSystemInfo(&sysInfo);
- WORD programArch = sysInfo.wProcessorArchitecture;
- // Check the real sysinfo state (not the one hidden by WOW64) for x86
- GetNativeSystemInfo(&sysInfo);
- WORD actualArch = sysInfo.wProcessorArchitecture;
-
- // Only try to access the WOW64-32 redirected keys on a 64-bit system.
- // There's no point in doing this on a 32-bit system.
- if (actualArch == PROCESSOR_ARCHITECTURE_AMD64) {
- if (programArch != PROCESSOR_ARCHITECTURE_INTEL) {
- // If we did the 32-bit case earlier, don't do it twice.
- result |= getMaxJavaInRegistry(
- "Java Runtime Environment", KEY_WOW64_32KEY, outJavaPath, &version);
- result |= getMaxJavaInRegistry(
- "Java Development Kit", KEY_WOW64_32KEY, outJavaPath, &version);
-
- } else if (programArch != PROCESSOR_ARCHITECTURE_AMD64) {
- // If we did the 64-bit case earlier, don't do it twice.
- result |= getMaxJavaInRegistry(
- "Java Runtime Environment", KEY_WOW64_64KEY, outJavaPath, &version);
- result |= getMaxJavaInRegistry(
- "Java Development Kit", KEY_WOW64_64KEY, outJavaPath, &version);
- }
+ // Even if we're 64-bit, try again but check the 32-bit registry, looking for 32-bit java.
+ if (isApplication64()) {
+ result |= getMaxJavaInRegistry(
+ "Java Runtime Environment", KEY_WOW64_32KEY, outJavaPath, &version);
+ result |= getMaxJavaInRegistry(
+ "Java Development Kit", KEY_WOW64_32KEY, outJavaPath, &version);
}
return result ? version : 0;
@@ -350,12 +333,13 @@ int findJavaInRegistry(CPath *outJavaPath) {
// --------------
-static bool checkProgramFiles(CPath *outJavaPath, int *inOutVersion) {
+static bool checkProgramFiles(CPath *outJavaPath, int *inOutVersion, bool force32bit) {
char programFilesPath[MAX_PATH + 1];
+ int nFolder = force32bit ? CSIDL_PROGRAM_FILESX86 : CSIDL_PROGRAM_FILES;
HRESULT result = SHGetFolderPathA(
NULL, // hwndOwner
- CSIDL_PROGRAM_FILES, // nFolder
+ nFolder,
NULL, // hToken
SHGFP_TYPE_CURRENT, // dwFlags
programFilesPath); // pszPath
@@ -364,7 +348,7 @@ static bool checkProgramFiles(CPath *outJavaPath, int *inOutVersion) {
CPath path(programFilesPath);
path.addPath("Java");
- // Do we have a C:\\Program Files\\Java directory?
+ // Do we have a C:\Program Files\Java directory?
if (!path.dirExists()) return false;
CPath glob(path);
@@ -378,7 +362,7 @@ static bool checkProgramFiles(CPath *outJavaPath, int *inOutVersion) {
if ((findData.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) != 0) {
CPath temp(path);
temp.addPath(findData.cFileName);
- // Check C:\\Program Files[x86]\\Java\\j*\\bin\\java.exe
+ // Check C:\Program Files\Java\j*\bin\java.exe
int v = checkBinPath(&temp);
if (v > *inOutVersion) {
found = true;
@@ -394,23 +378,15 @@ static bool checkProgramFiles(CPath *outJavaPath, int *inOutVersion) {
int findJavaInProgramFiles(CPath *outJavaPath) {
- // Check the C:\\Program Files (x86) directory
- // With WOW64 fs redirection in place by default, we should get the x86
- // version on a 64-bit OS since this app is a 32-bit itself.
+ // Check the C:\Program Files directory
bool result = false;
int version = MIN_JAVA_VERSION - 1;
- result |= checkProgramFiles(outJavaPath, &version);
+ result |= checkProgramFiles(outJavaPath, &version, false);
- // Check the real sysinfo state (not the one hidden by WOW64) for x86
- SYSTEM_INFO sysInfo;
- GetNativeSystemInfo(&sysInfo);
-
- if (sysInfo.wProcessorArchitecture == PROCESSOR_ARCHITECTURE_AMD64) {
- // On a 64-bit OS, try again by disabling the fs redirection so
- // that we can try the real C:\\Program Files directory.
- PVOID oldWow64Value = disableWow64FsRedirection();
- result |= checkProgramFiles(outJavaPath, &version);
- revertWow64FsRedirection(oldWow64Value);
+ // Even if we're 64-bit, try again but check the C:\Program Files (x86) directory, looking for
+ // 32-bit java.
+ if (isApplication64()) {
+ result |= checkProgramFiles(outJavaPath, &version, true);
}
return result ? version : 0;
diff --git a/find_java/src/source/utils.h b/find_java/src/source/utils.h
index dc9031d..a65e6fe 100755
--- a/find_java/src/source/utils.h
+++ b/find_java/src/source/utils.h
@@ -73,7 +73,7 @@ public:
CString() { mStr = NULL; }
CString(const CString &str) { mStr = NULL; set(str.mStr); }
explicit CString(const char *str) { mStr = NULL; set(str); }
- CString(const char *start, int length) { mStr = NULL; set(start, length); }
+ CString(const char *start, size_t length) { mStr = NULL; set(start, length); }
CString& operator=(const CString &str) {
return set(str.cstr());
@@ -89,7 +89,7 @@ public:
return *this;
}
- CString& set(const char *start, int length) {
+ CString& set(const char *start, size_t length) {
_free();
if (start != NULL) {
mStr = (char *)malloc(length + 1);
@@ -103,7 +103,7 @@ public:
_free();
// _vscprintf(str, ap) is only available with the MSVCRT, not MinGW.
// Instead we'll iterate till we have enough space to generate the string.
- int len = strlen(str) + 1024;
+ size_t len = strlen(str) + 1024;
mStr = (char *)malloc(len);
strcpy(mStr, str); // provide a default in case vsnprintf totally fails
for (int guard = 0; guard < 10; guard++) {
@@ -145,7 +145,7 @@ public:
return mStr == NULL || *mStr == 0;
}
- int length() const {
+ size_t length() const {
return mStr == NULL ? 0 : strlen(mStr);
}
@@ -163,7 +163,7 @@ public:
if (mStr == NULL) {
set(str, length);
} else {
- int l1 = strlen(mStr);
+ size_t l1 = strlen(mStr);
mStr = (char *)realloc((void *)mStr, l1 + length + 1);
strncpy(mStr + l1, str, length);
mStr[l1 + length] = 0;
@@ -256,7 +256,7 @@ public:
CPath& addPath(const char *s) {
_ASSERT(s != NULL);
if (s != NULL && s[0] != 0) {
- int n = length();
+ size_t n = length();
if (n > 0 && s[0] != '\\' && mStr[n-1] != '\\') add("\\");
add(s);
}
@@ -308,12 +308,12 @@ public:
// If the path ends with the given searchName, replace in-place by the new name
void replaceName(const char *searchName, const char* newName) {
if (mStr == NULL) return;
- int n = length();
- int sn = strlen(searchName);
+ size_t n = length();
+ size_t sn = strlen(searchName);
if (n < sn) return;
// if mStr ends with searchName
if (strcmp(mStr + n - sn, searchName) == 0) {
- int sn2 = strlen(newName);
+ size_t sn2 = strlen(newName);
if (sn2 > sn) {
mStr = (char *)realloc((void *)mStr, n + sn2 - sn + 1);
}
@@ -330,7 +330,7 @@ public:
const char *longPath = mStr;
if (mStr == NULL) return false;
- DWORD lenShort = strlen(longPath) + 1;
+ DWORD lenShort = (DWORD)strlen(longPath) + 1; // GetShortPathName deals with DWORDs
char * shortPath = (char *)malloc(lenShort);
DWORD length = GetShortPathName(longPath, shortPath, lenShort);
@@ -366,15 +366,5 @@ int execWait(const char *cmd);
bool getModuleDir(CPath *outDir);
-// Disables the FS redirection done by WOW64.
-// Because this runs as a 32-bit app, Windows automagically remaps some
-// folder under the hood (e.g. "Programs Files(x86)" is mapped as "Program Files").
-// This prevents the app from correctly searching for java.exe in these folders.
-// The registry is also remapped.
-PVOID disableWow64FsRedirection();
-
-// Reverts the redirection disabled in disableWow64FsRedirection.
-void revertWow64FsRedirection(PVOID oldWow64Value);
-
#endif /* _WIN32 */
#endif /* _H_UTILS */