WCHAR * getTestJVMFileName(WCHAR * testJVMFile) { WCHAR * filePtr = testJVMFile; WCHAR * testJavaClass = NULL; if(filePtr!=NULL) { WCHAR * dotClass = NULL; while(searchW(filePtr, L"\\")!=NULL) { filePtr = searchW(filePtr, L"\\"); filePtr++; } dotClass = searchW(filePtr, L".class"); if(dotClass!=NULL) { testJavaClass = appendStringNW(NULL, 0, filePtr, getLengthW(filePtr) - getLengthW(dotClass)); } } return testJavaClass; }
void unpackJars(LauncherProperties * props, WCHAR * jvmDir, WCHAR * startDir, WCHAR * unpack200exe) { DWORD attrs; DWORD dwError; DWORD count = 0 ; if(!isOK(props)) return; attrs = GetFileAttributesW(startDir); if(attrs==INVALID_FILE_ATTRIBUTES) { writeErrorA(props, OUTPUT_LEVEL_DEBUG, 1, "Error! Can`t get attributes of the file : ", startDir, GetLastError()); return; } if(attrs & FILE_ATTRIBUTE_DIRECTORY) { // is directory WIN32_FIND_DATAW FindFileData; HANDLE hFind = INVALID_HANDLE_VALUE; WCHAR * DirSpec = appendStringW(appendStringW(NULL, startDir), L"\\*" ); // Find the first file in the directory. hFind = FindFirstFileW(DirSpec, &FindFileData); if (hFind == INVALID_HANDLE_VALUE) { writeErrorA(props, OUTPUT_LEVEL_DEBUG, 1, "Error! Can`t file with pattern ", DirSpec, GetLastError()); } else { // List all the other files in the directory. writeMessageA(props, OUTPUT_LEVEL_DEBUG, 0, "... listing directory ", 0); writeMessageW(props, OUTPUT_LEVEL_DEBUG, 0, startDir, 1); while (FindNextFileW(hFind, &FindFileData) != 0 && isOK(props)) { if(lstrcmpW(FindFileData.cFileName, L".")!=0 && lstrcmpW(FindFileData.cFileName, L"..")!=0) { WCHAR * child = NULL; child = appendStringW(appendStringW(appendStringW(NULL, startDir), FILE_SEP), FindFileData.cFileName); if(isDirectory(child)) { writeMessageA(props, OUTPUT_LEVEL_DEBUG, 0, "... directory : ", 0); writeMessageW(props, OUTPUT_LEVEL_DEBUG, 0, child, 1); unpackJars(props, jvmDir, child, unpack200exe); } else if(searchW(FindFileData.cFileName, JAR_PACK_GZ_SUFFIX)!=NULL) { WCHAR * jarName = appendStringW(appendStringW( appendStringW(NULL, startDir), FILE_SEP), appendStringNW(NULL, 0, FindFileData.cFileName, getLengthW(FindFileData.cFileName) - getLengthW(PACK_GZ_SUFFIX))); WCHAR * unpackCommand = NULL; writeMessageA(props, OUTPUT_LEVEL_DEBUG, 0, "... packed jar : ", 0); writeMessageW(props, OUTPUT_LEVEL_DEBUG, 0, child, 1); writeMessageA(props, OUTPUT_LEVEL_DEBUG, 0, "... jar name : ", 0); writeMessageW(props, OUTPUT_LEVEL_DEBUG, 0, jarName, 1); appendCommandLineArgument(&unpackCommand, unpack200exe); appendCommandLineArgument(&unpackCommand, child); appendCommandLineArgument(&unpackCommand, jarName); executeCommand(props, unpackCommand, NULL, UNPACK200_EXTRACTION_TIMEOUT, props->stdoutHandle, props->stderrHandle, NORMAL_PRIORITY_CLASS); FREE(unpackCommand); if(!isOK(props)) { if(props->status==ERROR_PROCESS_TIMEOUT) { writeMessageA(props, OUTPUT_LEVEL_DEBUG, 1, "... could not unpack file : timeout", 1); } else { writeMessageA(props, OUTPUT_LEVEL_DEBUG, 1, "... an error occured unpacking the file", 1); } props->exitCode = props->status; } FREE(jarName); } FREE(child); } } dwError = GetLastError(); FindClose(hFind); if (dwError != ERROR_NO_MORE_FILES) { writeErrorA(props, OUTPUT_LEVEL_DEBUG, 1, "Error! Can`t find file with pattern : ", DirSpec, dwError); } } FREE(DirSpec); } }
void loadI18NStrings(LauncherProperties * props) { DWORD i=0; DWORD j=0; //read number of locales DWORD numberOfLocales = 0; DWORD numberOfProperties = 0; readNumberWithDebug(props, &numberOfLocales, "number of locales"); if(!isOK(props)) return; if(numberOfLocales==0) { props->status = ERROR_INTEGRITY; return ; } readNumberWithDebug( props, &numberOfProperties, "i18n properties"); if(!isOK(props)) return; if(numberOfProperties==0) { props->status = ERROR_INTEGRITY; return ; } props->i18nMessages = (I18NStrings * ) LocalAlloc(LPTR, sizeof(I18NStrings) * numberOfProperties); props->I18N_PROPERTIES_NUMBER = numberOfProperties; props->i18nMessages->properties = newppChar(props->I18N_PROPERTIES_NUMBER); props->i18nMessages->strings = newppWCHAR(props->I18N_PROPERTIES_NUMBER); for(i=0; isOK(props) && i<numberOfProperties;i++) { // read property name as ASCII char * propName = NULL; char * number = DWORDtoCHARN(i,2); props->i18nMessages->properties[i] = NULL; props->i18nMessages->strings[i] = NULL; propName = appendString(NULL, "property name "); propName = appendString(propName, number); FREE(number); readStringWithDebugA(props, & (props->i18nMessages->properties[i]), propName); FREE(propName); } if(isOK(props)) { DWORD isLocaleMatches; WCHAR * localeName; WCHAR * currentLocale = getLocaleName(); writeMessageA(props, OUTPUT_LEVEL_DEBUG, 0, "Current System Locale : ", 0); writeMessageW(props, OUTPUT_LEVEL_DEBUG, 0, currentLocale, 1); if(props->userDefinedLocale!=NULL) { // using user-defined locale via command-line parameter writeMessageA(props, OUTPUT_LEVEL_NORMAL, 0, "[CMD Argument] Try to use locale ", 0); writeMessageW(props, OUTPUT_LEVEL_NORMAL, 0, props->userDefinedLocale, 1); FREE(currentLocale); currentLocale = appendStringW(NULL, props->userDefinedLocale); } for(j=0;j<numberOfLocales;j++) { // for all locales in file... // read locale name as UNICODE .. // it should be like en_US or smth like that localeName = NULL; readStringWithDebugW(props, &localeName, "locale name"); if(!isOK(props)) break; isLocaleMatches = (localeName==NULL) ? 1 : searchW(currentLocale, localeName) != NULL; //read properties names and value for(i=0;i<numberOfProperties;i++) { // read property value as UNICODE WCHAR * value = NULL; char * s1 = DWORDtoCHAR(i + 1); char * s2 = DWORDtoCHAR(numberOfProperties); char * s3 = appendString(NULL , "value "); s3 = appendString(s3 , s1); s3 = appendString(s3, "/"); s3 = appendString(s3, s2); FREE(s1); FREE(s2); readStringWithDebugW(props, &value, s3); FREE(s3); if(!isOK(props)) break; if(isLocaleMatches) { //it is a know property FREE(props->i18nMessages->strings[i]); props->i18nMessages->strings[i] = appendStringW(NULL, value); } FREE(value); } FREE(localeName); } FREE(currentLocale); } }