RFR: 8035063: Option handling in sjavac needs to be rewritten
Jonathan Gibbons
jonathan.gibbons at oracle.com
Wed Mar 19 16:19:42 UTC 2014
I think sjavac should filter out all directories which could not
correspond to package names.
-- Jon
On 03/19/2014 06:58 AM, Erik Joelsson wrote:
> I should fill in that the background for this change is that there are
> a bunch of directories named "doc-files" in the classes source dir.
> They have been there a long time. These contain html and gif files
> (mainly) that shouldn't get copied into the output classes directory.
>
> In a recent cleanup of the copy mechanism, I changed the copy rules to
> by default include html and gif files and explicitly exclude those
> that shouldn't be included, rather than explicitly listing what should
> be copied. Because of this, we now have the following exclude rules:
>
> # These directories should not be copied at all
> EXCLUDES += \
> com/sun/org/apache/xml/internal/security/resource/schema \
> java/awt/doc-files \
> java/lang/doc-files \
> javax/swing/doc-files \
> javax/swing/text/doc-files \
> javax/swing/plaf/synth/doc-files \
> javax/swing/undo/doc-files \
> sun/awt/X11/doc-files \
> sun/util/cldr/resources \
> #
>
> When building with sjavac, these get translated to "-e
> java.awt.doc-files.*" which sjavac does not accept, because doc-files
> are not proper package names. Another possible fix would be to filter
> out non valid package names from the excludes sent to sjavac.
>
> /Erik
>
> On 2014-03-19 14:32, Andreas Lundblad wrote:
>> On Wed, Mar 19, 2014 at 01:58:21PM +0100, Fredrik Öhrström wrote:
>>> The code by itself looks good. However I think that changing from .
>>> to / is
>>> a really bad idea.
>>>
>>> If someone committed a package directory that does not map correctly
>>> to the
>>> package name, then that is a major problem. You will not find that
>>> source
>>> through -sourcepath, which means that you just broke sjavac ability to
>>> compile using multiple threads. This is just as bad as when Nashorn
>>> tried
>>> to insert $ into java source file names! The horror, the horror.
>>>
>>> I.e. do not replace . with /. Fix the problem in the jdk.
>> In this case, the directory did not contain any source files, just a
>> bunch of resources for documentation, such as .gif-files. (How could
>> it contain source files? A package may not contain a '-'.) So unless
>> I misunderstood you, there should therefore be no problem in this case.
>>
>> I would prefer to see -i and -x as filters on what directories (not
>> packages) exists in the subsequent source root: This is more in line
>> with other options (-if, -xf, -src, ...) which all talk about paths
>> and more general since each package corresponds to a directory, but
>> only some directories correspond to packages.
>>
>> - Andreas
>
More information about the compiler-dev
mailing list