Request for review JDK-8010706 - system properties -> nashorn options
Marcus Lagergren
marcus.lagergren at oracle.com
Tue Mar 26 00:50:32 PDT 2013
Fixed and updated developer docs to reflect this.
On Mar 26, 2013, at 8:43 AM, Hannes Wallnoefer <hannes.wallnoefer at oracle.com> wrote:
> The change looks good.
>
> I was just confused a bit by the example because it looks like you're setting an environment variable, while I guess you'd have to set a Java system property using mvn -Dnashorn.args=...
>
> Hannes
>
> Am 2013-03-26 07:42, schrieb Marcus Lagergren:
>> In order to make opaque frameworks easier to debug, I've added some code to Options.java that converts system properties given by the value of the property "nashorn.args" to nashorn parameters. This way we can set e.g. "--log=compiler" for something that runs three levels deep in JavaScript meta-execution frameworks without knowing exactly how they launch.
>>
>> Usage example:
>>
>> export nashorn.args="--lazy-compilation --log=compiler" mvn clean verify
>>
>> Patch:
>>
>> diff -r d5d80b52cf1c src/jdk/nashorn/internal/runtime/options/Options.java
>> --- a/src/jdk/nashorn/internal/runtime/options/Options.java Fri Mar 15 16:07:13 2013 +0100
>> +++ b/src/jdk/nashorn/internal/runtime/options/Options.java Tue Mar 19 18:16:36 2013 +0100
>> @@ -386,6 +386,13 @@
>> final LinkedList<String> argList = new LinkedList<>();
>> Collections.addAll(argList, args);
>>
>> + final String extra = getStringProperty("nashorn.args", null);
>> + if (extra != null) {
>> + for (final StringTokenizer st = new StringTokenizer(extra); st.hasMoreTokens(); ) {
>> + argList.add(st.nextToken());
>> + }
>> + }
>> +
>> while (!argList.isEmpty()) {
>> final String arg = argList.remove(0);
>>
>> @@ -406,7 +413,7 @@
>> files.add(arg);
>> continue;
>> }
>> -
>> +
>> if (arg.startsWith(definePropPrefix)) {
>> final String value = arg.substring(definePropPrefix.length());
>> final int eq = value.indexOf('=');
>>
>> /M
>>
>
More information about the nashorn-dev
mailing list