3
0
Fork 0

+ new version with quoted arguments for windows

small_fixes
kelson42 12 years ago
parent 909549c5bf
commit c7adaa2a27

@ -19,9 +19,6 @@
* MA 02110-1301, USA. * MA 02110-1301, USA.
*/ */
#include <stdlib.h>
#ifdef _WIN32 #ifdef _WIN32
#pragma comment( linker, "/subsystem:\"windows\" /entry:\"mainCRTStartup\"" ) #pragma comment( linker, "/subsystem:\"windows\" /entry:\"mainCRTStartup\"" )
#include <Windows.h> #include <Windows.h>
@ -40,6 +37,20 @@
using namespace std; using namespace std;
/* Quote string on Windows */
char *prepareArgument(const char *argument) {
if (argument != NULL) {
#ifdef _WIN32
string quotedArgument = "\"" + string(argument) + "\"";
return strdup(quotedArgument.c_str());
#else
return strdup(argument);
#endif
} else {
return NULL;
}
}
int main(int argc, char *argv[]) { int main(int argc, char *argv[]) {
/* Initialisation of a few paths */ /* Initialisation of a few paths */
@ -65,8 +76,8 @@ int main(int argc, char *argv[]) {
} }
} }
if (!fileExists(xulrunnerDirectory)) { if (!fileExists(xulrunnerDirectory)) {
perror("Unable to find the xulrunner directory"); perror("Unable to find the xulrunner directory");
return EXIT_FAILURE; return EXIT_FAILURE;
} }
/* Find xulrunner binary path */ /* Find xulrunner binary path */
@ -89,18 +100,13 @@ int main(int argc, char *argv[]) {
/* Compute application.ini path */ /* Compute application.ini path */
string applicationIniPath = computeAbsolutePath(removeLastPathElement(xulrunnerDirectory, false, false), "application.ini"); string applicationIniPath = computeAbsolutePath(removeLastPathElement(xulrunnerDirectory, false, false), "application.ini");
#ifdef _WIN32
applicationIniPath = "\"" + applicationIniPath + "\"";
#endif
/* Debug prints */ /* Debug prints */
/*
cout << "Executable directory (executableDirectory): " << executableDirectory << endl; cout << "Executable directory (executableDirectory): " << executableDirectory << endl;
cout << "Executable path (executablePath): " << executablePath << endl; cout << "Executable path (executablePath): " << executablePath << endl;
cout << "Xulrunner directory (xulrunnerDirectory): " << xulrunnerDirectory << endl; cout << "Xulrunner directory (xulrunnerDirectory): " << xulrunnerDirectory << endl;
cout << "Xulrunner path (xulrunnerPath): " << xulrunnerPath << endl; cout << "Xulrunner path (xulrunnerPath): " << xulrunnerPath << endl;
cout << "Application.ini path (applicationIniPath): " << applicationIniPath << endl; cout << "Application.ini path (applicationIniPath): " << applicationIniPath << endl;
*/
/* Modify environnement variables */ /* Modify environnement variables */
#ifdef _WIN32 #ifdef _WIN32
@ -117,37 +123,102 @@ int main(int argc, char *argv[]) {
/* Launch xulrunner */ /* Launch xulrunner */
if (argc == 0) { if (argc == 0) {
return EXECL(xulrunnerPath.c_str(), execlArg0.c_str(), applicationIniPath.c_str(), return EXECL(xulrunnerPath.c_str(),
"", NULL); execlArg0.c_str(),
prepareArgument(applicationIniPath.c_str()),
NULL);
} else if (argc == 1) { } else if (argc == 1) {
return EXECL(xulrunnerPath.c_str(), execlArg0.c_str(), applicationIniPath.c_str(), return EXECL(xulrunnerPath.c_str(),
argv[1], NULL); execlArg0.c_str(),
prepareArgument(applicationIniPath.c_str()),
prepareArgument(argv[1]),
NULL);
} else if (argc == 2) { } else if (argc == 2) {
return EXECL(xulrunnerPath.c_str(), execlArg0.c_str(), applicationIniPath.c_str(), return EXECL(xulrunnerPath.c_str(),
argv[1], argv[2], NULL); execlArg0.c_str(),
prepareArgument(applicationIniPath.c_str()),
prepareArgument(argv[1]),
prepareArgument(argv[2]),
NULL);
} else if (argc == 3) { } else if (argc == 3) {
return EXECL(xulrunnerPath.c_str(), execlArg0.c_str(), applicationIniPath.c_str(), return EXECL(xulrunnerPath.c_str(),
argv[1], argv[2], argv[3], NULL); execlArg0.c_str(),
prepareArgument(applicationIniPath.c_str()),
prepareArgument(argv[1]),
prepareArgument(argv[2]),
prepareArgument(argv[3]),
NULL);
} else if (argc == 4) { } else if (argc == 4) {
return EXECL(xulrunnerPath.c_str(), execlArg0.c_str(), applicationIniPath.c_str(), return EXECL(xulrunnerPath.c_str(),
argv[1], argv[2], argv[3], argv[4], NULL); execlArg0.c_str(),
prepareArgument(applicationIniPath.c_str()),
prepareArgument(argv[1]),
prepareArgument(argv[2]),
prepareArgument(argv[3]),
prepareArgument(argv[4]),
NULL);
} else if (argc == 5) { } else if (argc == 5) {
return EXECL(xulrunnerPath.c_str(), execlArg0.c_str(), applicationIniPath.c_str(), return EXECL(xulrunnerPath.c_str(),
argv[1], argv[2], argv[3], argv[4], argv[5], NULL); execlArg0.c_str(),
prepareArgument(applicationIniPath.c_str()),
prepareArgument(argv[1]),
prepareArgument(argv[2]),
prepareArgument(argv[3]),
prepareArgument(argv[4]),
prepareArgument(argv[5]),
NULL);
} else if (argc == 6) { } else if (argc == 6) {
return EXECL(xulrunnerPath.c_str(), execlArg0.c_str(), applicationIniPath.c_str(), return EXECL(xulrunnerPath.c_str(),
argv[1], argv[2], argv[3], argv[4], argv[5], argv[6], NULL); execlArg0.c_str(),
prepareArgument(applicationIniPath.c_str()),
prepareArgument(argv[1]),
prepareArgument(argv[2]),
prepareArgument(argv[3]),
prepareArgument(argv[4]),
prepareArgument(argv[5]),
prepareArgument(argv[6]),
NULL);
} else if (argc == 7) { } else if (argc == 7) {
return EXECL(xulrunnerPath.c_str(), execlArg0.c_str(), applicationIniPath.c_str(), return EXECL(xulrunnerPath.c_str(),
argv[1], argv[2], argv[3], argv[4], argv[5], argv[6], argv[7], NULL); execlArg0.c_str(),
prepareArgument(applicationIniPath.c_str()),
prepareArgument(argv[1]),
prepareArgument(argv[2]),
prepareArgument(argv[3]),
prepareArgument(argv[4]),
prepareArgument(argv[5]),
prepareArgument(argv[6]),
prepareArgument(argv[7]),
NULL);
} else if (argc == 8) { } else if (argc == 8) {
return EXECL(xulrunnerPath.c_str(), execlArg0.c_str(), applicationIniPath.c_str(), return EXECL(xulrunnerPath.c_str(),
argv[1], argv[2], argv[3], argv[4], argv[5], argv[6], argv[7], argv[8], NULL); execlArg0.c_str(),
prepareArgument(applicationIniPath.c_str()),
prepareArgument(argv[1]),
prepareArgument(argv[2]),
prepareArgument(argv[3]),
prepareArgument(argv[4]),
prepareArgument(argv[5]),
prepareArgument(argv[6]),
prepareArgument(argv[7]),
prepareArgument(argv[8]),
NULL);
} else if (argc >= 9) { } else if (argc >= 9) {
if (argc > 9) { if (argc > 9) {
fprintf(stderr, "Kiwix was not able to forward all your arguments to the xulrunner binary."); cerr << "Kiwix was not able to forward all your arguments to the xulrunner binary." << endl;
} }
return EXECL(xulrunnerPath.c_str(), execlArg0.c_str(), applicationIniPath.c_str(), return EXECL(xulrunnerPath.c_str(),
argv[1], argv[2], argv[3], argv[4], argv[5], argv[6], argv[7], argv[8], argv[9], NULL); execlArg0.c_str(),
prepareArgument(applicationIniPath.c_str()),
prepareArgument(argv[1]),
prepareArgument(argv[2]),
prepareArgument(argv[3]),
prepareArgument(argv[4]),
prepareArgument(argv[5]),
prepareArgument(argv[6]),
prepareArgument(argv[7]),
prepareArgument(argv[8]),
prepareArgument(argv[9]),
NULL);
} }
} }

Loading…
Cancel
Save