[kaffe] CVS kaffe (dalibor): Implemented -Xbooclasspath options
Kaffe CVS
Kaffe Mailing List <kaffe@kaffe.org>
Thu May 20 07:09:02 2004
PatchSet 4755
Date: 2004/05/20 13:51:38
Author: dalibor
Branch: HEAD
Tag: (none)
Log:
Implemented -Xbooclasspath options
2004-05-20 Dalibor Topic <robilad@kaffe.org>
* kaffe/kaffe/main.c:
(options) Added -Xbootclasspath and Xbootclasspath/a
option handling.
(usage) Added new options. Fixed intendation problems.
Reported by: Julio M. Merino Vidal <jmmv@menta.net>
Members:
ChangeLog:1.2326->1.2327
kaffe/kaffe/main.c:1.51->1.52
Index: kaffe/ChangeLog
diff -u kaffe/ChangeLog:1.2326 kaffe/ChangeLog:1.2327
--- kaffe/ChangeLog:1.2326 Wed May 19 17:27:42 2004
+++ kaffe/ChangeLog Thu May 20 13:51:38 2004
@@ -1,3 +1,12 @@
+2004-05-20 Dalibor Topic <robilad@kaffe.org>
+
+ * kaffe/kaffe/main.c:
+ (options) Added -Xbootclasspath and Xbootclasspath/a
+ option handling.
+ (usage) Added new options. Fixed intendation problems.
+
+ Reported by: Julio M. Merino Vidal <jmmv@menta.net>
+
2004-05-19 Dalibor Topic <robilad@kaffe.org>
* include/Makefile.am:
Index: kaffe/kaffe/kaffe/main.c
diff -u kaffe/kaffe/kaffe/main.c:1.51 kaffe/kaffe/kaffe/main.c:1.52
--- kaffe/kaffe/kaffe/main.c:1.51 Sat Apr 3 02:57:44 2004
+++ kaffe/kaffe/kaffe/main.c Thu May 20 13:51:40 2004
@@ -459,6 +459,50 @@
/* set the new boot classpath */
vmargs.bootClasspath = newbootcpath;
}
+ else if (strncmp(argv[i], "-Xbootclasspath/a:", (j=18)) == 0) {
+ char *newbootcpath;
+ unsigned int bootcpathlength;
+
+ bootcpathlength = strlen(&argv[i][j])
+ + strlen(path_separator)
+ + ((vmargs.bootClasspath != NULL) ?
+ strlen(vmargs.bootClasspath) : 0)
+ + 1;
+
+ /* Get longer buffer FIXME: free the old one */
+ if ((newbootcpath = malloc(bootcpathlength)) == NULL) {
+ fprintf(stderr, "Error: out of memory.\n");
+ exit(1);
+ }
+
+ /* Construct new boot classpath */
+ if( vmargs.bootClasspath != 0 ) {
+ strcpy(newbootcpath, vmargs.bootClasspath);
+ strcat(newbootcpath, path_separator);
+ }
+ strcat(newbootcpath, &argv[i][j]);
+
+ /* set the new boot classpath */
+ vmargs.bootClasspath = newbootcpath;
+ }
+ else if (strncmp(argv[i], "-Xbootclasspath:", (j=16)) == 0) {
+ char *newbootcpath;
+ unsigned int bootcpathlength;
+
+ bootcpathlength = strlen(&argv[i][j]) + 1;
+
+ /* Get longer buffer FIXME: free the old one */
+ if ((newbootcpath = malloc(bootcpathlength)) == NULL) {
+ fprintf(stderr, "Error: out of memory.\n");
+ exit(1);
+ }
+
+ /* Construct new boot classpath */
+ strcpy(newbootcpath, &argv[i][j]);
+
+ /* set the new boot classpath */
+ vmargs.bootClasspath = newbootcpath;
+ }
else if ((strncmp(argv[i], "-ss", (j=3)) == 0)
|| (strncmp(argv[i], "-Xss", (j=4)) == 0)) {
if (argv[i][j] == 0) {
@@ -701,60 +745,63 @@
{
fprintf(stderr, "usage: kaffe [-options] class\n");
fprintf(stderr, "Options are:\n");
- fprintf(stderr, " -help Print this message\n");
- fprintf(stderr, " -version Print version number\n");
- fprintf(stderr, " -fullversion Print verbose version info\n");
+ fprintf(stderr, " -help Print this message\n");
+ fprintf(stderr, " -version Print version number\n");
+ fprintf(stderr, " -fullversion Print verbose version info\n");
#if defined(__ia64__)
- fprintf(stderr, " -ia32 Execute the ia32 version of Kaffe\n");
+ fprintf(stderr, " -ia32 Execute the ia32 version of Kaffe\n");
#endif
- fprintf(stderr, " -ss <size> Maximum native stack size\n");
- fprintf(stderr, " -mx <size> Maximum heap size\n");
- fprintf(stderr, " -ms <size> Initial heap size\n");
- fprintf(stderr, " -as <size> Heap increment\n");
- fprintf(stderr, " -classpath <path> Set classpath\n");
- fprintf(stderr, " -D<property>=<value> Set a property\n");
- fprintf(stderr, " -verify * Verify all bytecode\n");
- fprintf(stderr, " -verifyremote * Verify bytecode loaded from network\n");
- fprintf(stderr, " -noverify Do not verify any bytecode\n");
- fprintf(stderr, " -noclassgc Disable class garbage collection\n");
- fprintf(stderr, " -verbosegc Print message during garbage collection\n");
- fprintf(stderr, " -v, -verbose Be verbose\n");
- fprintf(stderr, " -verbosejit Print message during JIT code generation\n");
- fprintf(stderr, " -verbosemem Print detailed memory allocation statistics\n");
- fprintf(stderr, " -verbosecall Print detailed call flow information\n");
- fprintf(stderr, " -nodeadlock Disable deadlock detection\n");
+ fprintf(stderr, " -ss <size> Maximum native stack size\n");
+ fprintf(stderr, " -mx <size> Maximum heap size\n");
+ fprintf(stderr, " -ms <size> Initial heap size\n");
+ fprintf(stderr, " -as <size> Heap increment\n");
+ fprintf(stderr, " -classpath <path> Set classpath\n");
+ fprintf(stderr, " -Xbootclasspath:<path> Set bootclasspath\n");
+ fprintf(stderr, " -Xbootclasspath:/a<path> Append path to bootclasspath\n");
+ fprintf(stderr, " -Xbootclasspath:/p<path> Prepend path to bootclasspath\n");
+ fprintf(stderr, " -D<property>=<value> Set a property\n");
+ fprintf(stderr, " -verify * Verify all bytecode\n");
+ fprintf(stderr, " -verifyremote * Verify bytecode loaded from network\n");
+ fprintf(stderr, " -noverify Do not verify any bytecode\n");
+ fprintf(stderr, " -noclassgc Disable class garbage collection\n");
+ fprintf(stderr, " -verbosegc Print message during garbage collection\n");
+ fprintf(stderr, " -v, -verbose Be verbose\n");
+ fprintf(stderr, " -verbosejit Print message during JIT code generation\n");
+ fprintf(stderr, " -verbosemem Print detailed memory allocation statistics\n");
+ fprintf(stderr, " -verbosecall Print detailed call flow information\n");
+ fprintf(stderr, " -nodeadlock Disable deadlock detection\n");
#if defined(KAFFE_PROFILER)
- fprintf(stderr, " -prof Enable profiling of Java methods\n");
+ fprintf(stderr, " -prof Enable profiling of Java methods\n");
#endif
#if defined(KAFFE_XPROFILER)
- fprintf(stderr, " -Xxprof Enable cross language profiling\n");
- fprintf(stderr, " -Xxprof_syms <file> Name of the profiling symbols file [Default: kaffe-jit-symbols.s]\n");
- fprintf(stderr, " -Xxprof_gmon <file> Base name for gmon files [Default: xgmon.out]\n");
+ fprintf(stderr, " -Xxprof Enable cross language profiling\n");
+ fprintf(stderr, " -Xxprof_syms <file> Name of the profiling symbols file [Default: kaffe-jit-symbols.s]\n");
+ fprintf(stderr, " -Xxprof_gmon <file> Base name for gmon files [Default: xgmon.out]\n");
#endif
#if defined(KAFFE_XDEBUGGING)
- fprintf(stderr, " -Xxdebug_file <file> Name of the debugging symbols file\n");
+ fprintf(stderr, " -Xxdebug_file <file> Name of the debugging symbols file\n");
#endif
#if defined(KAFFE_FEEDBACK)
- fprintf(stderr, " -Xfeedback <file> The file name to write feedback data to\n");
+ fprintf(stderr, " -Xfeedback <file> The file name to write feedback data to\n");
#endif
- fprintf(stderr, " -debug * Trace method calls\n");
- fprintf(stderr, " -noasyncgc * Do not garbage collect asynchronously\n");
- fprintf(stderr, " -cs, -checksource * Check source against class files\n");
- fprintf(stderr, " -oss <size> * Maximum java stack size\n");
- fprintf(stderr, " -jar Executable is a JAR\n");
+ fprintf(stderr, " -debug * Trace method calls\n");
+ fprintf(stderr, " -noasyncgc * Do not garbage collect asynchronously\n");
+ fprintf(stderr, " -cs, -checksource * Check source against class files\n");
+ fprintf(stderr, " -oss <size> * Maximum java stack size\n");
+ fprintf(stderr, " -jar Executable is a JAR\n");
#ifdef KAFFE_VMDEBUG
- fprintf(stderr, " -vmdebug <flag{,flag}> Internal VM debugging. Set flag=list for a list\n");
+ fprintf(stderr, " -vmdebug <flag{,flag}> Internal VM debugging. Set flag=list for a list\n");
#endif
#ifdef KAFFE_STATS
- fprintf(stderr, " -vmstats <flag{,flag}> Print VM statistics. Set flag=all for all\n");
+ fprintf(stderr, " -vmstats <flag{,flag}> Print VM statistics. Set flag=all for all\n");
#endif
fprintf(stderr, " * Option currently ignored.\n");
fprintf(stderr, "\n");
fprintf(stderr, "Compatibility options:\n");
- fprintf(stderr, " -Xss <size> Maximum native stack size\n");
- fprintf(stderr, " -Xmx <size> Maximum heap size\n");
- fprintf(stderr, " -Xms <size> Initial heap size\n");
- fprintf(stderr, " -cp <path> Set classpath\n");
+ fprintf(stderr, " -Xss <size> Maximum native stack size\n");
+ fprintf(stderr, " -Xmx <size> Maximum heap size\n");
+ fprintf(stderr, " -Xms <size> Initial heap size\n");
+ fprintf(stderr, " -cp <path> Set classpath\n");
}
static