RFR: 8201274: Launch Single-File Source-Code Programs

Maurizio Cimadamore maurizio.cimadamore at oracle.com
Fri Apr 13 10:43:28 UTC 2018


One small followup question - the test SourceLauncherTest is not 
covering any shebang cases - is that deliberate? I see that those seem 
to be covered in the launcher test too, but I wonder if we should have 
tests for clearly broken stuff, such as

'#'

'#!'

'#!\n'

Another small question - I see that the shebang process essentially 
replaces the first line separator with \n - that is probably ok given 
that the file is processed internally after that - but I wonder if you 
have thought about pros and cons of preserving the original line separator.

Cheers
Maurizio


On 12/04/18 21:46, Maurizio Cimadamore wrote:
> Looks great - some initial comments (I can't really comment on the 
> launcher changes):
>
> * This logic is efficient:
>
> int magic = (in.read() << 8) + in.read();
> boolean shebang = magic == (('#' << 8) + '!');
>
> but convoluted to read; perhaps could be improved slightly by making 
> '#' << 8) + '!' a static constant, and comparing against that.
>
> * I note that the reading logic in general could be simplified, e.g. 
> using Files.lines(Path) - but I assume that you wrote the code as is 
> for performance reasons (e.g. to avoid creating too many string 
> objects) ?
>
> * I see that both the file manager and the class loader reasonably 
> share the same context: a Map<String, byte[]>. I would make this more 
> explicit, by having a Context class, whose state is the map, and then 
> have the context provide two methods:
>
> getClassLoader()
> getFileManager()
>
> This way the sharing will be automatic, no need to extract one field 
> from one place and pass it over to the other place.
>
> * Big whohoo for being able to use the enhanced diagnostic framework 
> with a couple of tweaks on the makefile - I hope that would have been 
> the case when I put in the support, but since we have never done it - 
> wasn't 100% sure it would work ;-)
>
>
> Overall I like it quite a lot and I think you went for a really clean 
> design - kudos!
>
> Maurizio
>
>
>
> On 12/04/18 21:15, Jonathan Gibbons wrote:
>> Please review an initial implementation for the feature described in
>> JEP 330: Launch Single-File Source-Code Programs.
>>
>> The work is described in the JEP and CSR, and falls into various parts:
>>
>>   * The part to handle the new command-line options is in the native
>>     Java launcher code.
>>   * The part to invoke the compiler and subsequently execute the code
>>     found in the source file is in a new class in the jdk.compiler 
>> module.
>>   * There are some minor Makefile changes, to add support for a new
>>     resource file.
>>
>> There are no changes to javac itself.
>>
>> JEP: http://openjdk.java.net/jeps/330
>> JBS: https://bugs.openjdk.java.net/browse/JDK-8201274
>> CSR: https://bugs.openjdk.java.net/browse/JDK-8201275
>> Webrev: http://cr.openjdk.java.net/~jjg/8201274/webrev.00/
>>
>> -- Jon
>




More information about the build-dev mailing list