src/jdk.compiler/share/classes/com/sun/tools/javac/file/JavacFileManager.java
author erikj
Tue, 12 Sep 2017 19:03:39 +0200
changeset 47216 71c04702a3d5
parent 45504 langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/file/JavacFileManager.java@ea7475564d07
child 47446 fd458b0b7749
permissions -rw-r--r--
8187443: Forest Consolidation: Move files to unified layout Reviewed-by: darcy, ihse
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
10
06bc494ca11e Initial load
duke
parents:
diff changeset
     1
/*
44019
284fa2ebd030 8173914: StandardJavaFileManager.setLocationForModule
jjg
parents: 43772
diff changeset
     2
 * Copyright (c) 2005, 2017, Oracle and/or its affiliates. All rights reserved.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
06bc494ca11e Initial load
duke
parents:
diff changeset
     4
 *
06bc494ca11e Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
06bc494ca11e Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
5520
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 5007
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
10
06bc494ca11e Initial load
duke
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
5520
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 5007
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    10
 *
06bc494ca11e Initial load
duke
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
06bc494ca11e Initial load
duke
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
06bc494ca11e Initial load
duke
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
06bc494ca11e Initial load
duke
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
06bc494ca11e Initial load
duke
parents:
diff changeset
    15
 * accompanied this code).
06bc494ca11e Initial load
duke
parents:
diff changeset
    16
 *
06bc494ca11e Initial load
duke
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
06bc494ca11e Initial load
duke
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
06bc494ca11e Initial load
duke
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
06bc494ca11e Initial load
duke
parents:
diff changeset
    20
 *
5520
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 5007
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 5007
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 5007
diff changeset
    23
 * questions.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    24
 */
06bc494ca11e Initial load
duke
parents:
diff changeset
    25
731
1dd22bdb9ca5 6714364: refactor javac File handling code into new javac.file package
jjg
parents: 657
diff changeset
    26
package com.sun.tools.javac.file;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    27
06bc494ca11e Initial load
duke
parents:
diff changeset
    28
import java.io.File;
06bc494ca11e Initial load
duke
parents:
diff changeset
    29
import java.io.IOException;
06bc494ca11e Initial load
duke
parents:
diff changeset
    30
import java.net.MalformedURLException;
06bc494ca11e Initial load
duke
parents:
diff changeset
    31
import java.net.URI;
3782
ae62279eeb46 6419701: DefaultFileManager clean up: URI.create
jjg
parents: 3656
diff changeset
    32
import java.net.URISyntaxException;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    33
import java.net.URL;
06bc494ca11e Initial load
duke
parents:
diff changeset
    34
import java.nio.CharBuffer;
06bc494ca11e Initial load
duke
parents:
diff changeset
    35
import java.nio.charset.Charset;
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
    36
import java.nio.file.FileSystem;
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
    37
import java.nio.file.FileSystems;
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
    38
import java.nio.file.FileVisitOption;
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
    39
import java.nio.file.FileVisitResult;
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
    40
import java.nio.file.Files;
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
    41
import java.nio.file.InvalidPathException;
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
    42
import java.nio.file.LinkOption;
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
    43
import java.nio.file.Path;
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
    44
import java.nio.file.Paths;
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
    45
import java.nio.file.ProviderNotFoundException;
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
    46
import java.nio.file.SimpleFileVisitor;
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
    47
import java.nio.file.attribute.BasicFileAttributes;
37394
c36230ee15d9 8149757: Implement Multi-Release JAR aware JavacFileManager for javac
jjg
parents: 37390
diff changeset
    48
import java.nio.file.spi.FileSystemProvider;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    49
import java.util.ArrayList;
06bc494ca11e Initial load
duke
parents:
diff changeset
    50
import java.util.Arrays;
06bc494ca11e Initial load
duke
parents:
diff changeset
    51
import java.util.Collection;
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
    52
import java.util.Collections;
10813
95b39a692cd0 7101146: Paths should more directly managed by BaseFileManager
jjg
parents: 8837
diff changeset
    53
import java.util.Comparator;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    54
import java.util.EnumSet;
06bc494ca11e Initial load
duke
parents:
diff changeset
    55
import java.util.HashMap;
06bc494ca11e Initial load
duke
parents:
diff changeset
    56
import java.util.Iterator;
06bc494ca11e Initial load
duke
parents:
diff changeset
    57
import java.util.Map;
29291
076c277565f7 8073550: java* tools: replace obj.getClass hacks with Assert.checkNonNull or Objects.requireNonNull
mcimadamore
parents: 28332
diff changeset
    58
import java.util.Objects;
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
    59
import java.util.ServiceLoader;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    60
import java.util.Set;
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
    61
import java.util.stream.Collectors;
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
    62
import java.util.stream.Stream;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    63
06bc494ca11e Initial load
duke
parents:
diff changeset
    64
import javax.lang.model.SourceVersion;
06bc494ca11e Initial load
duke
parents:
diff changeset
    65
import javax.tools.FileObject;
06bc494ca11e Initial load
duke
parents:
diff changeset
    66
import javax.tools.JavaFileManager;
06bc494ca11e Initial load
duke
parents:
diff changeset
    67
import javax.tools.JavaFileObject;
731
1dd22bdb9ca5 6714364: refactor javac File handling code into new javac.file package
jjg
parents: 657
diff changeset
    68
import javax.tools.StandardJavaFileManager;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    69
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
    70
import com.sun.tools.javac.file.RelativePath.RelativeDirectory;
27226
53535e4e1b08 8061723: 8060056 breaks tests on Windows
jjg
parents: 27225
diff changeset
    71
import com.sun.tools.javac.file.RelativePath.RelativeFile;
45504
ea7475564d07 8170326: Inconsistencies between code, compiler.properties and comments
jlahoda
parents: 44822
diff changeset
    72
import com.sun.tools.javac.resources.CompilerProperties.Errors;
40513
39b67170b045 8153391: an image created for \"jdk.compiler\" fails to run javac
jlahoda
parents: 38533
diff changeset
    73
import com.sun.tools.javac.util.Assert;
731
1dd22bdb9ca5 6714364: refactor javac File handling code into new javac.file package
jjg
parents: 657
diff changeset
    74
import com.sun.tools.javac.util.Context;
42827
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42815
diff changeset
    75
import com.sun.tools.javac.util.Context.Factory;
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
    76
import com.sun.tools.javac.util.DefinedBy;
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
    77
import com.sun.tools.javac.util.DefinedBy.Api;
731
1dd22bdb9ca5 6714364: refactor javac File handling code into new javac.file package
jjg
parents: 657
diff changeset
    78
import com.sun.tools.javac.util.List;
1dd22bdb9ca5 6714364: refactor javac File handling code into new javac.file package
jjg
parents: 657
diff changeset
    79
import com.sun.tools.javac.util.ListBuffer;
38533
2bd347dde526 8157474: clean up/simplify/rename ModuleWrappers class
jjg
parents: 37944
diff changeset
    80
import com.sun.tools.javac.util.JDK9Wrappers.Configuration;
2bd347dde526 8157474: clean up/simplify/rename ModuleWrappers class
jjg
parents: 37944
diff changeset
    81
import com.sun.tools.javac.util.JDK9Wrappers.Layer;
2bd347dde526 8157474: clean up/simplify/rename ModuleWrappers class
jjg
parents: 37944
diff changeset
    82
import com.sun.tools.javac.util.JDK9Wrappers.ModuleFinder;
41033
49af2ecba616 8164742: ServiceConfigurationError on invoke of getServiceLoader method of StandardJavaFileManager
sadayapalam
parents: 40513
diff changeset
    83
import com.sun.tools.javac.util.JDK9Wrappers.Module;
38533
2bd347dde526 8157474: clean up/simplify/rename ModuleWrappers class
jjg
parents: 37944
diff changeset
    84
import com.sun.tools.javac.util.JDK9Wrappers.ServiceLoaderHelper;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    85
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
    86
import static java.nio.file.FileVisitOption.FOLLOW_LINKS;
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
    87
1205
b316e32eb90c 6508981: cleanup file separator handling in JavacFileManager
jjg
parents: 815
diff changeset
    88
import static javax.tools.StandardLocation.*;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    89
06bc494ca11e Initial load
duke
parents:
diff changeset
    90
/**
06bc494ca11e Initial load
duke
parents:
diff changeset
    91
 * This class provides access to the source, class and other files
06bc494ca11e Initial load
duke
parents:
diff changeset
    92
 * used by the compiler and related tools.
3380
a6c2bcab0fec 6865399: some javac files are missing Sun internal API comment
jjg
parents: 1789
diff changeset
    93
 *
5847
1908176fd6e3 6944312: Potential rebranding issues in openjdk/langtools repository sources
jjg
parents: 5520
diff changeset
    94
 * <p><b>This is NOT part of any supported API.
3380
a6c2bcab0fec 6865399: some javac files are missing Sun internal API comment
jjg
parents: 1789
diff changeset
    95
 * If you write code that depends on this, you do so at your own risk.
a6c2bcab0fec 6865399: some javac files are missing Sun internal API comment
jjg
parents: 1789
diff changeset
    96
 * This code and its internal interfaces are subject to change or
a6c2bcab0fec 6865399: some javac files are missing Sun internal API comment
jjg
parents: 1789
diff changeset
    97
 * deletion without notice.</b>
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    98
 */
4548
bc0d5b3c3b2d 6906175: bridge JSR199 and JSR 203 APIs
jjg
parents: 4073
diff changeset
    99
public class JavacFileManager extends BaseFileManager implements StandardJavaFileManager {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   100
27318
4660a5da7d90 8062376: Suppress cast warnings when using NIO buffers
rwarburton
parents: 27226
diff changeset
   101
    @SuppressWarnings("cast")
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   102
    public static char[] toArray(CharBuffer buffer) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   103
        if (buffer.hasArray())
06bc494ca11e Initial load
duke
parents:
diff changeset
   104
            return ((CharBuffer)buffer.compact().flip()).array();
06bc494ca11e Initial load
duke
parents:
diff changeset
   105
        else
06bc494ca11e Initial load
duke
parents:
diff changeset
   106
            return buffer.toString().toCharArray();
06bc494ca11e Initial load
duke
parents:
diff changeset
   107
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   108
1208
5072b0dd3d52 6743107: clean up use of static caches in file manager
jjg
parents: 1205
diff changeset
   109
    private FSInfo fsInfo;
5072b0dd3d52 6743107: clean up use of static caches in file manager
jjg
parents: 1205
diff changeset
   110
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   111
    private final Set<JavaFileObject.Kind> sourceOrClass =
06bc494ca11e Initial load
duke
parents:
diff changeset
   112
        EnumSet.of(JavaFileObject.Kind.SOURCE, JavaFileObject.Kind.CLASS);
06bc494ca11e Initial load
duke
parents:
diff changeset
   113
14362
598fd301e4de 8001229: refactor javac so that ct.sym is just used for javac, not all clients of JavacFileManager
jjg
parents: 14259
diff changeset
   114
    protected boolean symbolFileEnabled;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   115
37944
1153fab98d25 8149843: StandardJavaFileManager should provide a way to get paths from strings
jjg
parents: 37394
diff changeset
   116
    private PathFactory pathFactory = Paths::get;
1153fab98d25 8149843: StandardJavaFileManager should provide a way to get paths from strings
jjg
parents: 37394
diff changeset
   117
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   118
    protected enum SortFiles implements Comparator<Path> {
7334
f432af22de29 7003006: add option to list directory in deterministic order
jjg
parents: 6721
diff changeset
   119
        FORWARD {
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   120
            @Override
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   121
            public int compare(Path f1, Path f2) {
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   122
                return f1.getFileName().compareTo(f2.getFileName());
7334
f432af22de29 7003006: add option to list directory in deterministic order
jjg
parents: 6721
diff changeset
   123
            }
f432af22de29 7003006: add option to list directory in deterministic order
jjg
parents: 6721
diff changeset
   124
        },
f432af22de29 7003006: add option to list directory in deterministic order
jjg
parents: 6721
diff changeset
   125
        REVERSE {
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   126
            @Override
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   127
            public int compare(Path f1, Path f2) {
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   128
                return -f1.getFileName().compareTo(f2.getFileName());
7334
f432af22de29 7003006: add option to list directory in deterministic order
jjg
parents: 6721
diff changeset
   129
            }
22163
3651128c74eb 8030244: Update langtools to use Diamond
briangoetz
parents: 14362
diff changeset
   130
        }
3651128c74eb 8030244: Update langtools to use Diamond
briangoetz
parents: 14362
diff changeset
   131
    }
3651128c74eb 8030244: Update langtools to use Diamond
briangoetz
parents: 14362
diff changeset
   132
7334
f432af22de29 7003006: add option to list directory in deterministic order
jjg
parents: 6721
diff changeset
   133
    protected SortFiles sortFiles;
f432af22de29 7003006: add option to list directory in deterministic order
jjg
parents: 6721
diff changeset
   134
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   135
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
   136
     * Register a Context.Factory to create a JavacFileManager.
06bc494ca11e Initial load
duke
parents:
diff changeset
   137
     */
8614
06e42328ddab 7021650: fix Context issues
jjg
parents: 8432
diff changeset
   138
    public static void preRegister(Context context) {
42827
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42815
diff changeset
   139
        context.put(JavaFileManager.class,
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42815
diff changeset
   140
                (Factory<JavaFileManager>)c -> new JavacFileManager(c, true, null));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   141
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   142
06bc494ca11e Initial load
duke
parents:
diff changeset
   143
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
   144
     * Create a JavacFileManager using a given context, optionally registering
06bc494ca11e Initial load
duke
parents:
diff changeset
   145
     * it as the JavaFileManager for that context.
06bc494ca11e Initial load
duke
parents:
diff changeset
   146
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   147
    public JavacFileManager(Context context, boolean register, Charset charset) {
4548
bc0d5b3c3b2d 6906175: bridge JSR199 and JSR 203 APIs
jjg
parents: 4073
diff changeset
   148
        super(charset);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   149
        if (register)
06bc494ca11e Initial load
duke
parents:
diff changeset
   150
            context.put(JavaFileManager.class, this);
06bc494ca11e Initial load
duke
parents:
diff changeset
   151
        setContext(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   152
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   153
06bc494ca11e Initial load
duke
parents:
diff changeset
   154
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
   155
     * Set the context for JavacFileManager.
06bc494ca11e Initial load
duke
parents:
diff changeset
   156
     */
4548
bc0d5b3c3b2d 6906175: bridge JSR199 and JSR 203 APIs
jjg
parents: 4073
diff changeset
   157
    @Override
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   158
    public void setContext(Context context) {
4548
bc0d5b3c3b2d 6906175: bridge JSR199 and JSR 203 APIs
jjg
parents: 4073
diff changeset
   159
        super.setContext(context);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   160
1208
5072b0dd3d52 6743107: clean up use of static caches in file manager
jjg
parents: 1205
diff changeset
   161
        fsInfo = FSInfo.instance(context);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   162
14362
598fd301e4de 8001229: refactor javac so that ct.sym is just used for javac, not all clients of JavacFileManager
jjg
parents: 14259
diff changeset
   163
        symbolFileEnabled = !options.isSet("ignore.symbol.file");
7334
f432af22de29 7003006: add option to list directory in deterministic order
jjg
parents: 6721
diff changeset
   164
f432af22de29 7003006: add option to list directory in deterministic order
jjg
parents: 6721
diff changeset
   165
        String sf = options.get("sortFiles");
f432af22de29 7003006: add option to list directory in deterministic order
jjg
parents: 6721
diff changeset
   166
        if (sf != null) {
f432af22de29 7003006: add option to list directory in deterministic order
jjg
parents: 6721
diff changeset
   167
            sortFiles = (sf.equals("reverse") ? SortFiles.REVERSE : SortFiles.FORWARD);
f432af22de29 7003006: add option to list directory in deterministic order
jjg
parents: 6721
diff changeset
   168
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   169
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   170
37944
1153fab98d25 8149843: StandardJavaFileManager should provide a way to get paths from strings
jjg
parents: 37394
diff changeset
   171
    @Override @DefinedBy(DefinedBy.Api.COMPILER)
1153fab98d25 8149843: StandardJavaFileManager should provide a way to get paths from strings
jjg
parents: 37394
diff changeset
   172
    public void setPathFactory(PathFactory f) {
1153fab98d25 8149843: StandardJavaFileManager should provide a way to get paths from strings
jjg
parents: 37394
diff changeset
   173
        pathFactory = Objects.requireNonNull(f);
1153fab98d25 8149843: StandardJavaFileManager should provide a way to get paths from strings
jjg
parents: 37394
diff changeset
   174
        locations.setPathFactory(f);
1153fab98d25 8149843: StandardJavaFileManager should provide a way to get paths from strings
jjg
parents: 37394
diff changeset
   175
    }
1153fab98d25 8149843: StandardJavaFileManager should provide a way to get paths from strings
jjg
parents: 37394
diff changeset
   176
1153fab98d25 8149843: StandardJavaFileManager should provide a way to get paths from strings
jjg
parents: 37394
diff changeset
   177
    private Path getPath(String first, String... more) {
1153fab98d25 8149843: StandardJavaFileManager should provide a way to get paths from strings
jjg
parents: 37394
diff changeset
   178
        return pathFactory.getPath(first, more);
1153fab98d25 8149843: StandardJavaFileManager should provide a way to get paths from strings
jjg
parents: 37394
diff changeset
   179
    }
1153fab98d25 8149843: StandardJavaFileManager should provide a way to get paths from strings
jjg
parents: 37394
diff changeset
   180
14362
598fd301e4de 8001229: refactor javac so that ct.sym is just used for javac, not all clients of JavacFileManager
jjg
parents: 14259
diff changeset
   181
    /**
598fd301e4de 8001229: refactor javac so that ct.sym is just used for javac, not all clients of JavacFileManager
jjg
parents: 14259
diff changeset
   182
     * Set whether or not to use ct.sym as an alternate to rt.jar.
598fd301e4de 8001229: refactor javac so that ct.sym is just used for javac, not all clients of JavacFileManager
jjg
parents: 14259
diff changeset
   183
     */
598fd301e4de 8001229: refactor javac so that ct.sym is just used for javac, not all clients of JavacFileManager
jjg
parents: 14259
diff changeset
   184
    public void setSymbolFileEnabled(boolean b) {
598fd301e4de 8001229: refactor javac so that ct.sym is just used for javac, not all clients of JavacFileManager
jjg
parents: 14259
diff changeset
   185
        symbolFileEnabled = b;
598fd301e4de 8001229: refactor javac so that ct.sym is just used for javac, not all clients of JavacFileManager
jjg
parents: 14259
diff changeset
   186
    }
598fd301e4de 8001229: refactor javac so that ct.sym is just used for javac, not all clients of JavacFileManager
jjg
parents: 14259
diff changeset
   187
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   188
    public boolean isSymbolFileEnabled() {
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   189
        return symbolFileEnabled;
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   190
    }
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   191
28332
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   192
    // used by tests
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   193
    public JavaFileObject getJavaFileObject(String name) {
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   194
        return getJavaFileObjects(name).iterator().next();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   195
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   196
28332
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   197
    // used by tests
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   198
    public JavaFileObject getJavaFileObject(Path file) {
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   199
        return getJavaFileObjects(file).iterator().next();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   200
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   201
06bc494ca11e Initial load
duke
parents:
diff changeset
   202
    public JavaFileObject getFileForOutput(String classname,
06bc494ca11e Initial load
duke
parents:
diff changeset
   203
                                           JavaFileObject.Kind kind,
06bc494ca11e Initial load
duke
parents:
diff changeset
   204
                                           JavaFileObject sibling)
06bc494ca11e Initial load
duke
parents:
diff changeset
   205
        throws IOException
06bc494ca11e Initial load
duke
parents:
diff changeset
   206
    {
06bc494ca11e Initial load
duke
parents:
diff changeset
   207
        return getJavaFileForOutput(CLASS_OUTPUT, classname, kind, sibling);
06bc494ca11e Initial load
duke
parents:
diff changeset
   208
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   209
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   210
    @Override @DefinedBy(Api.COMPILER)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   211
    public Iterable<? extends JavaFileObject> getJavaFileObjectsFromStrings(Iterable<String> names) {
28332
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   212
        ListBuffer<Path> paths = new ListBuffer<>();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   213
        for (String name : names)
37944
1153fab98d25 8149843: StandardJavaFileManager should provide a way to get paths from strings
jjg
parents: 37394
diff changeset
   214
            paths.append(getPath(nullCheck(name)));
28332
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   215
        return getJavaFileObjectsFromPaths(paths.toList());
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   216
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   217
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   218
    @Override @DefinedBy(Api.COMPILER)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   219
    public Iterable<? extends JavaFileObject> getJavaFileObjects(String... names) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   220
        return getJavaFileObjectsFromStrings(Arrays.asList(nullCheck(names)));
06bc494ca11e Initial load
duke
parents:
diff changeset
   221
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   222
06bc494ca11e Initial load
duke
parents:
diff changeset
   223
    private static boolean isValidName(String name) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   224
        // Arguably, isValidName should reject keywords (such as in SourceVersion.isName() ),
06bc494ca11e Initial load
duke
parents:
diff changeset
   225
        // but the set of keywords depends on the source level, and we don't want
06bc494ca11e Initial load
duke
parents:
diff changeset
   226
        // impls of JavaFileManager to have to be dependent on the source level.
06bc494ca11e Initial load
duke
parents:
diff changeset
   227
        // Therefore we simply check that the argument is a sequence of identifiers
06bc494ca11e Initial load
duke
parents:
diff changeset
   228
        // separated by ".".
06bc494ca11e Initial load
duke
parents:
diff changeset
   229
        for (String s : name.split("\\.", -1)) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   230
            if (!SourceVersion.isIdentifier(s))
06bc494ca11e Initial load
duke
parents:
diff changeset
   231
                return false;
06bc494ca11e Initial load
duke
parents:
diff changeset
   232
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   233
        return true;
06bc494ca11e Initial load
duke
parents:
diff changeset
   234
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   235
06bc494ca11e Initial load
duke
parents:
diff changeset
   236
    private static void validateClassName(String className) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   237
        if (!isValidName(className))
06bc494ca11e Initial load
duke
parents:
diff changeset
   238
            throw new IllegalArgumentException("Invalid class name: " + className);
06bc494ca11e Initial load
duke
parents:
diff changeset
   239
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   240
06bc494ca11e Initial load
duke
parents:
diff changeset
   241
    private static void validatePackageName(String packageName) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   242
        if (packageName.length() > 0 && !isValidName(packageName))
06bc494ca11e Initial load
duke
parents:
diff changeset
   243
            throw new IllegalArgumentException("Invalid packageName name: " + packageName);
06bc494ca11e Initial load
duke
parents:
diff changeset
   244
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   245
06bc494ca11e Initial load
duke
parents:
diff changeset
   246
    public static void testName(String name,
06bc494ca11e Initial load
duke
parents:
diff changeset
   247
                                boolean isValidPackageName,
06bc494ca11e Initial load
duke
parents:
diff changeset
   248
                                boolean isValidClassName)
06bc494ca11e Initial load
duke
parents:
diff changeset
   249
    {
06bc494ca11e Initial load
duke
parents:
diff changeset
   250
        try {
06bc494ca11e Initial load
duke
parents:
diff changeset
   251
            validatePackageName(name);
06bc494ca11e Initial load
duke
parents:
diff changeset
   252
            if (!isValidPackageName)
06bc494ca11e Initial load
duke
parents:
diff changeset
   253
                throw new AssertionError("Invalid package name accepted: " + name);
06bc494ca11e Initial load
duke
parents:
diff changeset
   254
            printAscii("Valid package name: \"%s\"", name);
06bc494ca11e Initial load
duke
parents:
diff changeset
   255
        } catch (IllegalArgumentException e) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   256
            if (isValidPackageName)
06bc494ca11e Initial load
duke
parents:
diff changeset
   257
                throw new AssertionError("Valid package name rejected: " + name);
06bc494ca11e Initial load
duke
parents:
diff changeset
   258
            printAscii("Invalid package name: \"%s\"", name);
06bc494ca11e Initial load
duke
parents:
diff changeset
   259
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   260
        try {
06bc494ca11e Initial load
duke
parents:
diff changeset
   261
            validateClassName(name);
06bc494ca11e Initial load
duke
parents:
diff changeset
   262
            if (!isValidClassName)
06bc494ca11e Initial load
duke
parents:
diff changeset
   263
                throw new AssertionError("Invalid class name accepted: " + name);
06bc494ca11e Initial load
duke
parents:
diff changeset
   264
            printAscii("Valid class name: \"%s\"", name);
06bc494ca11e Initial load
duke
parents:
diff changeset
   265
        } catch (IllegalArgumentException e) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   266
            if (isValidClassName)
06bc494ca11e Initial load
duke
parents:
diff changeset
   267
                throw new AssertionError("Valid class name rejected: " + name);
06bc494ca11e Initial load
duke
parents:
diff changeset
   268
            printAscii("Invalid class name: \"%s\"", name);
06bc494ca11e Initial load
duke
parents:
diff changeset
   269
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   270
    }
1205
b316e32eb90c 6508981: cleanup file separator handling in JavacFileManager
jjg
parents: 815
diff changeset
   271
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   272
    private static void printAscii(String format, Object... args) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   273
        String message;
06bc494ca11e Initial load
duke
parents:
diff changeset
   274
        try {
06bc494ca11e Initial load
duke
parents:
diff changeset
   275
            final String ascii = "US-ASCII";
06bc494ca11e Initial load
duke
parents:
diff changeset
   276
            message = new String(String.format(null, format, args).getBytes(ascii), ascii);
06bc494ca11e Initial load
duke
parents:
diff changeset
   277
        } catch (java.io.UnsupportedEncodingException ex) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   278
            throw new AssertionError(ex);
06bc494ca11e Initial load
duke
parents:
diff changeset
   279
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   280
        System.out.println(message);
06bc494ca11e Initial load
duke
parents:
diff changeset
   281
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   282
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   283
    private final Map<Path, Container> containers = new HashMap<>();
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   284
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   285
    synchronized Container getContainer(Path path) throws IOException {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   286
        Container fs = containers.get(path);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   287
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   288
        if (fs != null) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   289
            return fs;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   290
        }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   291
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   292
        if (fsInfo.isFile(path) && path.equals(Locations.thisSystemModules)) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   293
            containers.put(path, fs = new JRTImageContainer());
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   294
            return fs;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   295
        }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   296
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   297
        Path realPath = fsInfo.getCanonicalFile(path);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   298
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   299
        fs = containers.get(realPath);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   300
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   301
        if (fs != null) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   302
            containers.put(path, fs);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   303
            return fs;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   304
        }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   305
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   306
        BasicFileAttributes attr = null;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   307
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   308
        try {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   309
            attr = Files.readAttributes(realPath, BasicFileAttributes.class);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   310
        } catch (IOException ex) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   311
            //non-existing
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   312
            fs = MISSING_CONTAINER;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   313
        }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   314
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   315
        if (attr != null) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   316
            if (attr.isDirectory()) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   317
                fs = new DirectoryContainer(realPath);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   318
            } else {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   319
                try {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   320
                    fs = new ArchiveContainer(realPath);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   321
                } catch (ProviderNotFoundException | SecurityException ex) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   322
                    throw new IOException(ex);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   323
                }
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   324
            }
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   325
        }
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   326
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   327
        containers.put(realPath, fs);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   328
        containers.put(path, fs);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   329
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   330
        return fs;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   331
    }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   332
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   333
    private interface Container {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   334
        /**
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   335
         * Insert all files in subdirectory subdirectory of container which
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   336
         * match fileKinds into resultList
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   337
         */
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   338
        public abstract void list(Path userPath,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   339
                                  RelativeDirectory subdirectory,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   340
                                  Set<JavaFileObject.Kind> fileKinds,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   341
                                  boolean recurse,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   342
                                  ListBuffer<JavaFileObject> resultList) throws IOException;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   343
        public abstract JavaFileObject getFileObject(Path userPath, RelativeFile name) throws IOException;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   344
        public abstract void close() throws IOException;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   345
    }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   346
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   347
    private static final Container MISSING_CONTAINER =  new Container() {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   348
        @Override
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   349
        public void list(Path userPath,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   350
                         RelativeDirectory subdirectory,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   351
                         Set<JavaFileObject.Kind> fileKinds,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   352
                         boolean recurse,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   353
                         ListBuffer<JavaFileObject> resultList) throws IOException {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   354
        }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   355
        @Override
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   356
        public JavaFileObject getFileObject(Path userPath, RelativeFile name) throws IOException {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   357
            return null;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   358
        }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   359
        @Override
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   360
        public void close() throws IOException {}
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   361
    };
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   362
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   363
    private final class JRTImageContainer implements Container {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   364
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   365
        /**
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   366
         * Insert all files in a subdirectory of the platform image
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   367
         * which match fileKinds into resultList.
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   368
         */
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   369
        @Override
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   370
        public void list(Path userPath,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   371
                         RelativeDirectory subdirectory,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   372
                         Set<JavaFileObject.Kind> fileKinds,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   373
                         boolean recurse,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   374
                         ListBuffer<JavaFileObject> resultList) throws IOException {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   375
            try {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   376
                JRTIndex.Entry e = getJRTIndex().getEntry(subdirectory);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   377
                if (symbolFileEnabled && e.ctSym.hidden)
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   378
                    return;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   379
                for (Path file: e.files.values()) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   380
                    if (fileKinds.contains(getKind(file))) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   381
                        JavaFileObject fe
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   382
                                = PathFileObject.forJRTPath(JavacFileManager.this, file);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   383
                        resultList.append(fe);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   384
                    }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   385
                }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   386
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   387
                if (recurse) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   388
                    for (RelativeDirectory rd: e.subdirs) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   389
                        list(userPath, rd, fileKinds, recurse, resultList);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   390
                    }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   391
                }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   392
            } catch (IOException ex) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   393
                ex.printStackTrace(System.err);
45504
ea7475564d07 8170326: Inconsistencies between code, compiler.properties and comments
jlahoda
parents: 44822
diff changeset
   394
                log.error(Errors.ErrorReadingFile(userPath, getMessage(ex)));
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   395
            }
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   396
        }
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   397
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   398
        @Override
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   399
        public JavaFileObject getFileObject(Path userPath, RelativeFile name) throws IOException {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   400
            JRTIndex.Entry e = getJRTIndex().getEntry(name.dirname());
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   401
            if (symbolFileEnabled && e.ctSym.hidden)
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   402
                return null;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   403
            Path p = e.files.get(name.basename());
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   404
            if (p != null) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   405
                return PathFileObject.forJRTPath(JavacFileManager.this, p);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   406
            } else {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   407
                return null;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   408
            }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   409
        }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   410
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   411
        @Override
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   412
        public void close() throws IOException {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   413
        }
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   414
    }
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   415
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   416
    private synchronized JRTIndex getJRTIndex() {
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   417
        if (jrtIndex == null)
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   418
            jrtIndex = JRTIndex.getSharedInstance();
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   419
        return jrtIndex;
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   420
    }
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   421
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   422
    private JRTIndex jrtIndex;
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   423
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   424
    private final class DirectoryContainer implements Container {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   425
        private final Path directory;
7839
a1ca72d05b20 6999460: Glassfish build with JDK 6 / 7 is 5x-10x slower on Windows than on Linux
jjh
parents: 7335
diff changeset
   426
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   427
        public DirectoryContainer(Path directory) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   428
            this.directory = directory;
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   429
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   430
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   431
        /**
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   432
         * Insert all files in subdirectory subdirectory of directory userPath
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   433
         * which match fileKinds into resultList
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   434
         */
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   435
        @Override
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   436
        public void list(Path userPath,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   437
                         RelativeDirectory subdirectory,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   438
                         Set<JavaFileObject.Kind> fileKinds,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   439
                         boolean recurse,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   440
                         ListBuffer<JavaFileObject> resultList) throws IOException {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   441
            Path d;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   442
            try {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   443
                d = subdirectory.resolveAgainst(userPath);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   444
            } catch (InvalidPathException ignore) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   445
                return ;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   446
            }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   447
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   448
            if (!Files.exists(d)) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   449
               return;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   450
            }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   451
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   452
            if (!caseMapCheck(d, subdirectory)) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   453
                return;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   454
            }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   455
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   456
            java.util.List<Path> files;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   457
            try (Stream<Path> s = Files.list(d)) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   458
                files = (sortFiles == null ? s : s.sorted(sortFiles)).collect(Collectors.toList());
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   459
            } catch (IOException ignore) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   460
                return;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   461
            }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   462
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   463
            for (Path f: files) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   464
                String fname = f.getFileName().toString();
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   465
                if (fname.endsWith("/"))
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   466
                    fname = fname.substring(0, fname.length() - 1);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   467
                if (Files.isDirectory(f)) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   468
                    if (recurse && SourceVersion.isIdentifier(fname)) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   469
                        list(userPath,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   470
                             new RelativeDirectory(subdirectory, fname),
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   471
                             fileKinds,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   472
                             recurse,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   473
                             resultList);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   474
                    }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   475
                } else {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   476
                    if (isValidFile(fname, fileKinds)) {
44566
db270eef83ae 8177332: The presence of a file with a Japanese ShiftJIS name can cause javac to fail
vromero
parents: 44063
diff changeset
   477
                        try {
db270eef83ae 8177332: The presence of a file with a Japanese ShiftJIS name can cause javac to fail
vromero
parents: 44063
diff changeset
   478
                            RelativeFile file = new RelativeFile(subdirectory, fname);
db270eef83ae 8177332: The presence of a file with a Japanese ShiftJIS name can cause javac to fail
vromero
parents: 44063
diff changeset
   479
                            JavaFileObject fe = PathFileObject.forDirectoryPath(JavacFileManager.this,
db270eef83ae 8177332: The presence of a file with a Japanese ShiftJIS name can cause javac to fail
vromero
parents: 44063
diff changeset
   480
                                    file.resolveAgainst(directory), userPath, file);
db270eef83ae 8177332: The presence of a file with a Japanese ShiftJIS name can cause javac to fail
vromero
parents: 44063
diff changeset
   481
                            resultList.append(fe);
db270eef83ae 8177332: The presence of a file with a Japanese ShiftJIS name can cause javac to fail
vromero
parents: 44063
diff changeset
   482
                        } catch (InvalidPathException e) {
db270eef83ae 8177332: The presence of a file with a Japanese ShiftJIS name can cause javac to fail
vromero
parents: 44063
diff changeset
   483
                            throw new IOException("error accessing directory " + directory + e);
db270eef83ae 8177332: The presence of a file with a Japanese ShiftJIS name can cause javac to fail
vromero
parents: 44063
diff changeset
   484
                        }
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   485
                    }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   486
                }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   487
            }
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   488
        }
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   489
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   490
        @Override
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   491
        public JavaFileObject getFileObject(Path userPath, RelativeFile name) throws IOException {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   492
            try {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   493
                Path f = name.resolveAgainst(userPath);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   494
                if (Files.exists(f))
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   495
                    return PathFileObject.forSimplePath(JavacFileManager.this,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   496
                            fsInfo.getCanonicalFile(f), f);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   497
            } catch (InvalidPathException ignore) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   498
            }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   499
            return null;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   500
        }
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   501
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   502
        @Override
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   503
        public void close() throws IOException {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   504
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   505
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   506
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   507
    private final class ArchiveContainer implements Container {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   508
        private final Path archivePath;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   509
        private final FileSystem fileSystem;
43565
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   510
        private final Map<RelativePath, Path> packages;
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   511
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   512
        public ArchiveContainer(Path archivePath) throws IOException, ProviderNotFoundException, SecurityException {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   513
            this.archivePath = archivePath;
37394
c36230ee15d9 8149757: Implement Multi-Release JAR aware JavacFileManager for javac
jjg
parents: 37390
diff changeset
   514
            if (multiReleaseValue != null && archivePath.toString().endsWith(".jar")) {
c36230ee15d9 8149757: Implement Multi-Release JAR aware JavacFileManager for javac
jjg
parents: 37390
diff changeset
   515
                Map<String,String> env = Collections.singletonMap("multi-release", multiReleaseValue);
40513
39b67170b045 8153391: an image created for \"jdk.compiler\" fails to run javac
jlahoda
parents: 38533
diff changeset
   516
                FileSystemProvider jarFSProvider = fsInfo.getJarFSProvider();
39b67170b045 8153391: an image created for \"jdk.compiler\" fails to run javac
jlahoda
parents: 38533
diff changeset
   517
                Assert.checkNonNull(jarFSProvider, "should have been caught before!");
39b67170b045 8153391: an image created for \"jdk.compiler\" fails to run javac
jlahoda
parents: 38533
diff changeset
   518
                this.fileSystem = jarFSProvider.newFileSystem(archivePath, env);
37394
c36230ee15d9 8149757: Implement Multi-Release JAR aware JavacFileManager for javac
jjg
parents: 37390
diff changeset
   519
            } else {
c36230ee15d9 8149757: Implement Multi-Release JAR aware JavacFileManager for javac
jjg
parents: 37390
diff changeset
   520
                this.fileSystem = FileSystems.newFileSystem(archivePath, null);
c36230ee15d9 8149757: Implement Multi-Release JAR aware JavacFileManager for javac
jjg
parents: 37390
diff changeset
   521
            }
43565
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   522
            packages = new HashMap<>();
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   523
            for (Path root : fileSystem.getRootDirectories()) {
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   524
                Files.walkFileTree(root, EnumSet.noneOf(FileVisitOption.class), Integer.MAX_VALUE,
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   525
                        new SimpleFileVisitor<Path>() {
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   526
                            @Override
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   527
                            public FileVisitResult preVisitDirectory(Path dir, BasicFileAttributes attrs) {
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   528
                                if (isValid(dir.getFileName())) {
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   529
                                    packages.put(new RelativeDirectory(root.relativize(dir).toString()), dir);
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   530
                                    return FileVisitResult.CONTINUE;
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   531
                                } else {
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   532
                                    return FileVisitResult.SKIP_SUBTREE;
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   533
                                }
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   534
                            }
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   535
                        });
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   536
            }
7839
a1ca72d05b20 6999460: Glassfish build with JDK 6 / 7 is 5x-10x slower on Windows than on Linux
jjh
parents: 7335
diff changeset
   537
        }
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   538
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   539
        /**
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   540
         * Insert all files in subdirectory subdirectory of this archive
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   541
         * which match fileKinds into resultList
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   542
         */
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   543
        @Override
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   544
        public void list(Path userPath,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   545
                         RelativeDirectory subdirectory,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   546
                         Set<JavaFileObject.Kind> fileKinds,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   547
                         boolean recurse,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   548
                         ListBuffer<JavaFileObject> resultList) throws IOException {
43565
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   549
            Path resolvedSubdirectory = packages.get(subdirectory);
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   550
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   551
            if (resolvedSubdirectory == null)
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   552
                return ;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   553
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   554
            int maxDepth = (recurse ? Integer.MAX_VALUE : 1);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   555
            Set<FileVisitOption> opts = EnumSet.of(FOLLOW_LINKS);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   556
            Files.walkFileTree(resolvedSubdirectory, opts, maxDepth,
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   557
                    new SimpleFileVisitor<Path>() {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   558
                        @Override
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   559
                        public FileVisitResult preVisitDirectory(Path dir, BasicFileAttributes attrs) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   560
                            if (isValid(dir.getFileName())) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   561
                                return FileVisitResult.CONTINUE;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   562
                            } else {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   563
                                return FileVisitResult.SKIP_SUBTREE;
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   564
                            }
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   565
                        }
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   566
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   567
                        @Override
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   568
                        public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   569
                            if (attrs.isRegularFile() && fileKinds.contains(getKind(file.getFileName().toString()))) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   570
                                JavaFileObject fe = PathFileObject.forJarPath(
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   571
                                        JavacFileManager.this, file, archivePath);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   572
                                resultList.append(fe);
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   573
                            }
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   574
                            return FileVisitResult.CONTINUE;
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   575
                        }
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   576
                    });
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   577
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   578
        }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   579
43565
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   580
        private boolean isValid(Path fileName) {
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   581
            if (fileName == null) {
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   582
                return true;
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   583
            } else {
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   584
                String name = fileName.toString();
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   585
                if (name.endsWith("/")) {
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   586
                    name = name.substring(0, name.length() - 1);
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   587
                }
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   588
                return SourceVersion.isIdentifier(name);
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   589
            }
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   590
        }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   591
43565
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   592
        @Override
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   593
        public JavaFileObject getFileObject(Path userPath, RelativeFile name) throws IOException {
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   594
            RelativeDirectory root = name.dirname();
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   595
            Path packagepath = packages.get(root);
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   596
            if (packagepath != null) {
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   597
                Path relpath = packagepath.resolve(name.basename());
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   598
                if (Files.exists(relpath)) {
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   599
                    return PathFileObject.forJarPath(JavacFileManager.this, relpath, userPath);
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   600
                }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   601
            }
43565
266c9503e22f 8171294: Slow compilation with long classpaths under JDK 9
jlahoda
parents: 42827
diff changeset
   602
            return null;
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   603
        }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   604
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   605
        @Override
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   606
        public void close() throws IOException {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   607
            fileSystem.close();
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   608
        }
7839
a1ca72d05b20 6999460: Glassfish build with JDK 6 / 7 is 5x-10x slower on Windows than on Linux
jjh
parents: 7335
diff changeset
   609
    }
37394
c36230ee15d9 8149757: Implement Multi-Release JAR aware JavacFileManager for javac
jjg
parents: 37390
diff changeset
   610
7839
a1ca72d05b20 6999460: Glassfish build with JDK 6 / 7 is 5x-10x slower on Windows than on Linux
jjh
parents: 7335
diff changeset
   611
    /**
37394
c36230ee15d9 8149757: Implement Multi-Release JAR aware JavacFileManager for javac
jjg
parents: 37390
diff changeset
   612
     * container is a directory, a zip file, or a non-existent path.
7839
a1ca72d05b20 6999460: Glassfish build with JDK 6 / 7 is 5x-10x slower on Windows than on Linux
jjh
parents: 7335
diff changeset
   613
     */
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   614
    private boolean isValidFile(String s, Set<JavaFileObject.Kind> fileKinds) {
4548
bc0d5b3c3b2d 6906175: bridge JSR199 and JSR 203 APIs
jjg
parents: 4073
diff changeset
   615
        JavaFileObject.Kind kind = getKind(s);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   616
        return fileKinds.contains(kind);
06bc494ca11e Initial load
duke
parents:
diff changeset
   617
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   618
06bc494ca11e Initial load
duke
parents:
diff changeset
   619
    private static final boolean fileSystemIsCaseSensitive =
06bc494ca11e Initial load
duke
parents:
diff changeset
   620
        File.separatorChar == '/';
06bc494ca11e Initial load
duke
parents:
diff changeset
   621
06bc494ca11e Initial load
duke
parents:
diff changeset
   622
    /** Hack to make Windows case sensitive. Test whether given path
06bc494ca11e Initial load
duke
parents:
diff changeset
   623
     *  ends in a string of characters with the same case as given name.
06bc494ca11e Initial load
duke
parents:
diff changeset
   624
     *  Ignore file separators in both path and name.
06bc494ca11e Initial load
duke
parents:
diff changeset
   625
     */
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   626
    private boolean caseMapCheck(Path f, RelativePath name) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   627
        if (fileSystemIsCaseSensitive) return true;
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   628
        // Note that toRealPath() returns the case-sensitive
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   629
        // spelled file name.
06bc494ca11e Initial load
duke
parents:
diff changeset
   630
        String path;
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   631
        char sep;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   632
        try {
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   633
            path = f.toRealPath(LinkOption.NOFOLLOW_LINKS).toString();
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   634
            sep = f.getFileSystem().getSeparator().charAt(0);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   635
        } catch (IOException ex) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   636
            return false;
06bc494ca11e Initial load
duke
parents:
diff changeset
   637
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   638
        char[] pcs = path.toCharArray();
1205
b316e32eb90c 6508981: cleanup file separator handling in JavacFileManager
jjg
parents: 815
diff changeset
   639
        char[] ncs = name.path.toCharArray();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   640
        int i = pcs.length - 1;
06bc494ca11e Initial load
duke
parents:
diff changeset
   641
        int j = ncs.length - 1;
06bc494ca11e Initial load
duke
parents:
diff changeset
   642
        while (i >= 0 && j >= 0) {
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   643
            while (i >= 0 && pcs[i] == sep) i--;
1205
b316e32eb90c 6508981: cleanup file separator handling in JavacFileManager
jjg
parents: 815
diff changeset
   644
            while (j >= 0 && ncs[j] == '/') j--;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   645
            if (i >= 0 && j >= 0) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   646
                if (pcs[i] != ncs[j]) return false;
06bc494ca11e Initial load
duke
parents:
diff changeset
   647
                i--;
06bc494ca11e Initial load
duke
parents:
diff changeset
   648
                j--;
06bc494ca11e Initial load
duke
parents:
diff changeset
   649
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   650
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   651
        return j < 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
   652
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   653
06bc494ca11e Initial load
duke
parents:
diff changeset
   654
    /** Flush any output resources.
06bc494ca11e Initial load
duke
parents:
diff changeset
   655
     */
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   656
    @Override @DefinedBy(Api.COMPILER)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   657
    public void flush() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   658
        contentCache.clear();
06bc494ca11e Initial load
duke
parents:
diff changeset
   659
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   660
06bc494ca11e Initial load
duke
parents:
diff changeset
   661
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
   662
     * Close the JavaFileManager, releasing resources.
06bc494ca11e Initial load
duke
parents:
diff changeset
   663
     */
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   664
    @Override @DefinedBy(Api.COMPILER)
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   665
    public void close() throws IOException {
35807
2eb1d877da0f 8147801: java.nio.file.ClosedFileSystemException when using Javadoc API's in JDK9
jjg
parents: 34560
diff changeset
   666
        if (deferredCloseTimeout > 0) {
2eb1d877da0f 8147801: java.nio.file.ClosedFileSystemException when using Javadoc API's in JDK9
jjg
parents: 34560
diff changeset
   667
            deferredClose();
2eb1d877da0f 8147801: java.nio.file.ClosedFileSystemException when using Javadoc API's in JDK9
jjg
parents: 34560
diff changeset
   668
            return;
2eb1d877da0f 8147801: java.nio.file.ClosedFileSystemException when using Javadoc API's in JDK9
jjg
parents: 34560
diff changeset
   669
        }
2eb1d877da0f 8147801: java.nio.file.ClosedFileSystemException when using Javadoc API's in JDK9
jjg
parents: 34560
diff changeset
   670
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   671
        locations.close();
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   672
        for (Container container: containers.values()) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   673
            container.close();
35807
2eb1d877da0f 8147801: java.nio.file.ClosedFileSystemException when using Javadoc API's in JDK9
jjg
parents: 34560
diff changeset
   674
        }
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   675
        containers.clear();
35807
2eb1d877da0f 8147801: java.nio.file.ClosedFileSystemException when using Javadoc API's in JDK9
jjg
parents: 34560
diff changeset
   676
        contentCache.clear();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   677
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   678
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   679
    @Override @DefinedBy(Api.COMPILER)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   680
    public ClassLoader getClassLoader(Location location) {
42261
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
   681
        checkNotModuleOrientedLocation(location);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   682
        Iterable<? extends File> path = getLocation(location);
06bc494ca11e Initial load
duke
parents:
diff changeset
   683
        if (path == null)
06bc494ca11e Initial load
duke
parents:
diff changeset
   684
            return null;
22163
3651128c74eb 8030244: Update langtools to use Diamond
briangoetz
parents: 14362
diff changeset
   685
        ListBuffer<URL> lb = new ListBuffer<>();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   686
        for (File f: path) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   687
            try {
06bc494ca11e Initial load
duke
parents:
diff changeset
   688
                lb.append(f.toURI().toURL());
06bc494ca11e Initial load
duke
parents:
diff changeset
   689
            } catch (MalformedURLException e) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   690
                throw new AssertionError(e);
06bc494ca11e Initial load
duke
parents:
diff changeset
   691
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   692
        }
3656
d4e34b76b0c3 6558476: com/sun/tools/javac/Main.compile don't release file handles on return
jjg
parents: 3380
diff changeset
   693
4548
bc0d5b3c3b2d 6906175: bridge JSR199 and JSR 203 APIs
jjg
parents: 4073
diff changeset
   694
        return getClassLoader(lb.toArray(new URL[lb.size()]));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   695
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   696
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   697
    @Override @DefinedBy(Api.COMPILER)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   698
    public Iterable<JavaFileObject> list(Location location,
06bc494ca11e Initial load
duke
parents:
diff changeset
   699
                                         String packageName,
06bc494ca11e Initial load
duke
parents:
diff changeset
   700
                                         Set<JavaFileObject.Kind> kinds,
06bc494ca11e Initial load
duke
parents:
diff changeset
   701
                                         boolean recurse)
06bc494ca11e Initial load
duke
parents:
diff changeset
   702
        throws IOException
06bc494ca11e Initial load
duke
parents:
diff changeset
   703
    {
42261
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
   704
        checkNotModuleOrientedLocation(location);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   705
        // validatePackageName(packageName);
06bc494ca11e Initial load
duke
parents:
diff changeset
   706
        nullCheck(packageName);
06bc494ca11e Initial load
duke
parents:
diff changeset
   707
        nullCheck(kinds);
06bc494ca11e Initial load
duke
parents:
diff changeset
   708
27858
chegar
parents: 27579 27852
diff changeset
   709
        Iterable<? extends Path> path = getLocationAsPaths(location);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   710
        if (path == null)
06bc494ca11e Initial load
duke
parents:
diff changeset
   711
            return List.nil();
1205
b316e32eb90c 6508981: cleanup file separator handling in JavacFileManager
jjg
parents: 815
diff changeset
   712
        RelativeDirectory subdirectory = RelativeDirectory.forPackage(packageName);
22163
3651128c74eb 8030244: Update langtools to use Diamond
briangoetz
parents: 14362
diff changeset
   713
        ListBuffer<JavaFileObject> results = new ListBuffer<>();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   714
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   715
        for (Path directory : path) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   716
            Container container = getContainer(directory);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   717
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   718
            container.list(directory, subdirectory, kinds, recurse, results);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   719
        }
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   720
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   721
        return results.toList();
06bc494ca11e Initial load
duke
parents:
diff changeset
   722
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   723
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   724
    @Override @DefinedBy(Api.COMPILER)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   725
    public String inferBinaryName(Location location, JavaFileObject file) {
42261
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
   726
        checkNotModuleOrientedLocation(location);
29291
076c277565f7 8073550: java* tools: replace obj.getClass hacks with Assert.checkNonNull or Objects.requireNonNull
mcimadamore
parents: 28332
diff changeset
   727
        Objects.requireNonNull(file);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   728
        // Need to match the path semantics of list(location, ...)
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   729
        Iterable<? extends Path> path = getLocationAsPaths(location);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   730
        if (path == null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   731
            return null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   732
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   733
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   734
        if (file instanceof PathFileObject) {
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   735
            return ((PathFileObject) file).inferBinaryName(path);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   736
        } else
06bc494ca11e Initial load
duke
parents:
diff changeset
   737
            throw new IllegalArgumentException(file.getClass().getName());
06bc494ca11e Initial load
duke
parents:
diff changeset
   738
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   739
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   740
    @Override @DefinedBy(Api.COMPILER)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   741
    public boolean isSameFile(FileObject a, FileObject b) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   742
        nullCheck(a);
06bc494ca11e Initial load
duke
parents:
diff changeset
   743
        nullCheck(b);
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   744
        if (a instanceof PathFileObject && b instanceof PathFileObject)
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   745
            return ((PathFileObject) a).isSameFile((PathFileObject) b);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   746
        return a.equals(b);
06bc494ca11e Initial load
duke
parents:
diff changeset
   747
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   748
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   749
    @Override @DefinedBy(Api.COMPILER)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   750
    public boolean hasLocation(Location location) {
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   751
        nullCheck(location);
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   752
        return locations.hasLocation(location);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   753
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   754
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   755
    @Override @DefinedBy(Api.COMPILER)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   756
    public JavaFileObject getJavaFileForInput(Location location,
06bc494ca11e Initial load
duke
parents:
diff changeset
   757
                                              String className,
06bc494ca11e Initial load
duke
parents:
diff changeset
   758
                                              JavaFileObject.Kind kind)
06bc494ca11e Initial load
duke
parents:
diff changeset
   759
        throws IOException
06bc494ca11e Initial load
duke
parents:
diff changeset
   760
    {
42261
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
   761
        checkNotModuleOrientedLocation(location);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   762
        // validateClassName(className);
06bc494ca11e Initial load
duke
parents:
diff changeset
   763
        nullCheck(className);
06bc494ca11e Initial load
duke
parents:
diff changeset
   764
        nullCheck(kind);
06bc494ca11e Initial load
duke
parents:
diff changeset
   765
        if (!sourceOrClass.contains(kind))
6719
1ce993f87850 6502392: Invalid relative names for Filer.createResource and Filer.getResource
jjg
parents: 5847
diff changeset
   766
            throw new IllegalArgumentException("Invalid kind: " + kind);
1205
b316e32eb90c 6508981: cleanup file separator handling in JavacFileManager
jjg
parents: 815
diff changeset
   767
        return getFileForInput(location, RelativeFile.forClass(className, kind));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   768
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   769
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   770
    @Override @DefinedBy(Api.COMPILER)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   771
    public FileObject getFileForInput(Location location,
06bc494ca11e Initial load
duke
parents:
diff changeset
   772
                                      String packageName,
06bc494ca11e Initial load
duke
parents:
diff changeset
   773
                                      String relativeName)
06bc494ca11e Initial load
duke
parents:
diff changeset
   774
        throws IOException
06bc494ca11e Initial load
duke
parents:
diff changeset
   775
    {
42261
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
   776
        checkNotModuleOrientedLocation(location);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   777
        // validatePackageName(packageName);
06bc494ca11e Initial load
duke
parents:
diff changeset
   778
        nullCheck(packageName);
3782
ae62279eeb46 6419701: DefaultFileManager clean up: URI.create
jjg
parents: 3656
diff changeset
   779
        if (!isRelativeUri(relativeName))
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   780
            throw new IllegalArgumentException("Invalid relative name: " + relativeName);
1205
b316e32eb90c 6508981: cleanup file separator handling in JavacFileManager
jjg
parents: 815
diff changeset
   781
        RelativeFile name = packageName.length() == 0
b316e32eb90c 6508981: cleanup file separator handling in JavacFileManager
jjg
parents: 815
diff changeset
   782
            ? new RelativeFile(relativeName)
b316e32eb90c 6508981: cleanup file separator handling in JavacFileManager
jjg
parents: 815
diff changeset
   783
            : new RelativeFile(RelativeDirectory.forPackage(packageName), relativeName);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   784
        return getFileForInput(location, name);
06bc494ca11e Initial load
duke
parents:
diff changeset
   785
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   786
1205
b316e32eb90c 6508981: cleanup file separator handling in JavacFileManager
jjg
parents: 815
diff changeset
   787
    private JavaFileObject getFileForInput(Location location, RelativeFile name) throws IOException {
27858
chegar
parents: 27579 27852
diff changeset
   788
        Iterable<? extends Path> path = getLocationAsPaths(location);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   789
        if (path == null)
06bc494ca11e Initial load
duke
parents:
diff changeset
   790
            return null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   791
27858
chegar
parents: 27579 27852
diff changeset
   792
        for (Path file: path) {
37390
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   793
            JavaFileObject fo = getContainer(file).getFileObject(file, name);
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   794
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   795
            if (fo != null) {
bf1552d6bc16 8150641: Repeated compilation with a long classpath significantly slower on JDK 9
jlahoda
parents: 36526
diff changeset
   796
                return fo;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   797
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   798
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   799
        return null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   800
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   801
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   802
    @Override @DefinedBy(Api.COMPILER)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   803
    public JavaFileObject getJavaFileForOutput(Location location,
06bc494ca11e Initial load
duke
parents:
diff changeset
   804
                                               String className,
06bc494ca11e Initial load
duke
parents:
diff changeset
   805
                                               JavaFileObject.Kind kind,
06bc494ca11e Initial load
duke
parents:
diff changeset
   806
                                               FileObject sibling)
06bc494ca11e Initial load
duke
parents:
diff changeset
   807
        throws IOException
06bc494ca11e Initial load
duke
parents:
diff changeset
   808
    {
42261
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
   809
        checkOutputLocation(location);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   810
        // validateClassName(className);
06bc494ca11e Initial load
duke
parents:
diff changeset
   811
        nullCheck(className);
06bc494ca11e Initial load
duke
parents:
diff changeset
   812
        nullCheck(kind);
06bc494ca11e Initial load
duke
parents:
diff changeset
   813
        if (!sourceOrClass.contains(kind))
6719
1ce993f87850 6502392: Invalid relative names for Filer.createResource and Filer.getResource
jjg
parents: 5847
diff changeset
   814
            throw new IllegalArgumentException("Invalid kind: " + kind);
1205
b316e32eb90c 6508981: cleanup file separator handling in JavacFileManager
jjg
parents: 815
diff changeset
   815
        return getFileForOutput(location, RelativeFile.forClass(className, kind), sibling);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   816
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   817
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   818
    @Override @DefinedBy(Api.COMPILER)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   819
    public FileObject getFileForOutput(Location location,
06bc494ca11e Initial load
duke
parents:
diff changeset
   820
                                       String packageName,
06bc494ca11e Initial load
duke
parents:
diff changeset
   821
                                       String relativeName,
06bc494ca11e Initial load
duke
parents:
diff changeset
   822
                                       FileObject sibling)
06bc494ca11e Initial load
duke
parents:
diff changeset
   823
        throws IOException
06bc494ca11e Initial load
duke
parents:
diff changeset
   824
    {
42261
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
   825
        checkOutputLocation(location);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   826
        // validatePackageName(packageName);
06bc494ca11e Initial load
duke
parents:
diff changeset
   827
        nullCheck(packageName);
3782
ae62279eeb46 6419701: DefaultFileManager clean up: URI.create
jjg
parents: 3656
diff changeset
   828
        if (!isRelativeUri(relativeName))
6719
1ce993f87850 6502392: Invalid relative names for Filer.createResource and Filer.getResource
jjg
parents: 5847
diff changeset
   829
            throw new IllegalArgumentException("Invalid relative name: " + relativeName);
1205
b316e32eb90c 6508981: cleanup file separator handling in JavacFileManager
jjg
parents: 815
diff changeset
   830
        RelativeFile name = packageName.length() == 0
b316e32eb90c 6508981: cleanup file separator handling in JavacFileManager
jjg
parents: 815
diff changeset
   831
            ? new RelativeFile(relativeName)
b316e32eb90c 6508981: cleanup file separator handling in JavacFileManager
jjg
parents: 815
diff changeset
   832
            : new RelativeFile(RelativeDirectory.forPackage(packageName), relativeName);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   833
        return getFileForOutput(location, name, sibling);
06bc494ca11e Initial load
duke
parents:
diff changeset
   834
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   835
06bc494ca11e Initial load
duke
parents:
diff changeset
   836
    private JavaFileObject getFileForOutput(Location location,
1205
b316e32eb90c 6508981: cleanup file separator handling in JavacFileManager
jjg
parents: 815
diff changeset
   837
                                            RelativeFile fileName,
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   838
                                            FileObject sibling)
06bc494ca11e Initial load
duke
parents:
diff changeset
   839
        throws IOException
06bc494ca11e Initial load
duke
parents:
diff changeset
   840
    {
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   841
        Path dir;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   842
        if (location == CLASS_OUTPUT) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   843
            if (getClassOutDir() != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   844
                dir = getClassOutDir();
06bc494ca11e Initial load
duke
parents:
diff changeset
   845
            } else {
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   846
                String baseName = fileName.basename();
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   847
                if (sibling != null && sibling instanceof PathFileObject) {
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   848
                    return ((PathFileObject) sibling).getSibling(baseName);
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   849
                } else {
37944
1153fab98d25 8149843: StandardJavaFileManager should provide a way to get paths from strings
jjg
parents: 37394
diff changeset
   850
                    Path p = getPath(baseName);
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   851
                    Path real = fsInfo.getCanonicalFile(p);
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   852
                    return PathFileObject.forSimplePath(this, real, p);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   853
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
   854
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   855
        } else if (location == SOURCE_OUTPUT) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   856
            dir = (getSourceOutDir() != null ? getSourceOutDir() : getClassOutDir());
06bc494ca11e Initial load
duke
parents:
diff changeset
   857
        } else {
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   858
            Iterable<? extends Path> path = locations.getLocation(location);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   859
            dir = null;
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   860
            for (Path f: path) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   861
                dir = f;
06bc494ca11e Initial load
duke
parents:
diff changeset
   862
                break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   863
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   864
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   865
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   866
        try {
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   867
            if (dir == null) {
37944
1153fab98d25 8149843: StandardJavaFileManager should provide a way to get paths from strings
jjg
parents: 37394
diff changeset
   868
                dir = getPath(System.getProperty("user.dir"));
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   869
            }
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   870
            Path path = fileName.resolveAgainst(fsInfo.getCanonicalFile(dir));
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   871
            return PathFileObject.forDirectoryPath(this, path, dir, fileName);
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   872
        } catch (InvalidPathException e) {
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   873
            throw new IOException("bad filename " + fileName, e);
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   874
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   875
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   876
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   877
    @Override @DefinedBy(Api.COMPILER)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   878
    public Iterable<? extends JavaFileObject> getJavaFileObjectsFromFiles(
06bc494ca11e Initial load
duke
parents:
diff changeset
   879
        Iterable<? extends File> files)
06bc494ca11e Initial load
duke
parents:
diff changeset
   880
    {
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   881
        ArrayList<PathFileObject> result;
1789
7ac8c0815000 6765045: Remove rawtypes warnings from langtools
mcimadamore
parents: 1208
diff changeset
   882
        if (files instanceof Collection<?>)
22163
3651128c74eb 8030244: Update langtools to use Diamond
briangoetz
parents: 14362
diff changeset
   883
            result = new ArrayList<>(((Collection<?>)files).size());
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   884
        else
22163
3651128c74eb 8030244: Update langtools to use Diamond
briangoetz
parents: 14362
diff changeset
   885
            result = new ArrayList<>();
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   886
        for (File f: files) {
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   887
            Objects.requireNonNull(f);
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   888
            Path p = f.toPath();
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   889
            result.add(PathFileObject.forSimplePath(this,
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   890
                    fsInfo.getCanonicalFile(p), p));
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   891
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   892
        return result;
06bc494ca11e Initial load
duke
parents:
diff changeset
   893
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   894
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   895
    @Override @DefinedBy(Api.COMPILER)
28332
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   896
    public Iterable<? extends JavaFileObject> getJavaFileObjectsFromPaths(
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   897
        Iterable<? extends Path> paths)
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   898
    {
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   899
        ArrayList<PathFileObject> result;
28332
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   900
        if (paths instanceof Collection<?>)
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   901
            result = new ArrayList<>(((Collection<?>)paths).size());
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   902
        else
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   903
            result = new ArrayList<>();
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   904
        for (Path p: paths)
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   905
            result.add(PathFileObject.forSimplePath(this,
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
   906
                    fsInfo.getCanonicalFile(p), p));
28332
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   907
        return result;
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   908
    }
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   909
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   910
    @Override @DefinedBy(Api.COMPILER)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   911
    public Iterable<? extends JavaFileObject> getJavaFileObjects(File... files) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   912
        return getJavaFileObjectsFromFiles(Arrays.asList(nullCheck(files)));
06bc494ca11e Initial load
duke
parents:
diff changeset
   913
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   914
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   915
    @Override @DefinedBy(Api.COMPILER)
28332
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   916
    public Iterable<? extends JavaFileObject> getJavaFileObjects(Path... paths) {
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   917
        return getJavaFileObjectsFromPaths(Arrays.asList(nullCheck(paths)));
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   918
    }
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   919
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   920
    @Override @DefinedBy(Api.COMPILER)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   921
    public void setLocation(Location location,
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   922
                            Iterable<? extends File> searchpath)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   923
        throws IOException
06bc494ca11e Initial load
duke
parents:
diff changeset
   924
    {
06bc494ca11e Initial load
duke
parents:
diff changeset
   925
        nullCheck(location);
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   926
        locations.setLocation(location, asPaths(searchpath));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   927
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   928
27579
d1a63c99cdd5 8049367: Modular Run-Time Images
chegar
parents: 27380
diff changeset
   929
    @Override @DefinedBy(Api.COMPILER)
28332
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   930
    public void setLocationFromPaths(Location location,
37944
1153fab98d25 8149843: StandardJavaFileManager should provide a way to get paths from strings
jjg
parents: 37394
diff changeset
   931
                            Collection<? extends Path> searchpath)
28332
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   932
        throws IOException
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   933
    {
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   934
        nullCheck(location);
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   935
        locations.setLocation(location, nullCheck(searchpath));
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   936
    }
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   937
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   938
    @Override @DefinedBy(Api.COMPILER)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   939
    public Iterable<? extends File> getLocation(Location location) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   940
        nullCheck(location);
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   941
        return asFiles(locations.getLocation(location));
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   942
    }
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   943
28332
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   944
    @Override @DefinedBy(Api.COMPILER)
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   945
    public Iterable<? extends Path> getLocationAsPaths(Location location) {
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   946
        nullCheck(location);
10818
e95eb04c68cc 7104039: refactor/cleanup javac Paths class
jjg
parents: 10813
diff changeset
   947
        return locations.getLocation(location);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   948
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   949
44822
2f24758e7ae0 8176327: javac produces wrong module-info
jjg
parents: 44566
diff changeset
   950
    @Override @DefinedBy(Api.COMPILER)
2f24758e7ae0 8176327: javac produces wrong module-info
jjg
parents: 44566
diff changeset
   951
    public boolean contains(Location location, FileObject fo) throws IOException {
2f24758e7ae0 8176327: javac produces wrong module-info
jjg
parents: 44566
diff changeset
   952
        nullCheck(location);
2f24758e7ae0 8176327: javac produces wrong module-info
jjg
parents: 44566
diff changeset
   953
        nullCheck(fo);
2f24758e7ae0 8176327: javac produces wrong module-info
jjg
parents: 44566
diff changeset
   954
        Path p = asPath(fo);
2f24758e7ae0 8176327: javac produces wrong module-info
jjg
parents: 44566
diff changeset
   955
        return locations.contains(location, p);
2f24758e7ae0 8176327: javac produces wrong module-info
jjg
parents: 44566
diff changeset
   956
    }
2f24758e7ae0 8176327: javac produces wrong module-info
jjg
parents: 44566
diff changeset
   957
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   958
    private Path getClassOutDir() {
10818
e95eb04c68cc 7104039: refactor/cleanup javac Paths class
jjg
parents: 10813
diff changeset
   959
        return locations.getOutputLocation(CLASS_OUTPUT);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   960
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   961
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
   962
    private Path getSourceOutDir() {
10818
e95eb04c68cc 7104039: refactor/cleanup javac Paths class
jjg
parents: 10813
diff changeset
   963
        return locations.getOutputLocation(SOURCE_OUTPUT);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   964
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   965
28332
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
   966
    @Override @DefinedBy(Api.COMPILER)
42261
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
   967
    public Location getLocationForModule(Location location, String moduleName) throws IOException {
42814
058fc03646d9 8171005: Fix JavaFileManager.getLocationForModule(Location location, JavaFileObject fo, String pkgName) to work with location == CLASS_OUTPUT
jlahoda
parents: 42261
diff changeset
   968
        checkModuleOrientedOrOutputLocation(location);
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   969
        nullCheck(moduleName);
42815
050370edaade 8072988: Update javax.annotation.processing for modules
jlahoda
parents: 42814
diff changeset
   970
        if (location == SOURCE_OUTPUT && getSourceOutDir() == null)
050370edaade 8072988: Update javax.annotation.processing for modules
jlahoda
parents: 42814
diff changeset
   971
            location = CLASS_OUTPUT;
42261
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
   972
        return locations.getLocationForModule(location, moduleName);
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   973
    }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   974
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   975
    @Override @DefinedBy(Api.COMPILER)
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   976
    public <S> ServiceLoader<S> getServiceLoader(Location location, Class<S> service) throws IOException {
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   977
        nullCheck(location);
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   978
        nullCheck(service);
41033
49af2ecba616 8164742: ServiceConfigurationError on invoke of getServiceLoader method of StandardJavaFileManager
sadayapalam
parents: 40513
diff changeset
   979
        Module.getModule(getClass()).addUses(service);
42261
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
   980
        if (location.isModuleOrientedLocation()) {
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   981
            Collection<Path> paths = locations.getLocation(location);
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   982
            ModuleFinder finder = ModuleFinder.of(paths.toArray(new Path[paths.size()]));
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   983
            Layer bootLayer = Layer.boot();
43767
9cff98a149cb 8173393: Module system implementation refresh (2/2017)
alanb
parents: 43565
diff changeset
   984
            Configuration cf = bootLayer.configuration().resolveAndBind(ModuleFinder.of(), finder, Collections.emptySet());
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   985
            Layer layer = bootLayer.defineModulesWithOneLoader(cf, ClassLoader.getSystemClassLoader());
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   986
            return ServiceLoaderHelper.load(layer, service);
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   987
        } else {
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   988
            return ServiceLoader.load(service, getClassLoader(location));
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   989
        }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   990
    }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   991
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   992
    @Override @DefinedBy(Api.COMPILER)
44063
5f0cf4126949 8175560: Drop String pkgName from javax.tools.JavaFileManager.getLocationForModule(Location location, JavaFileObject fo, String pkgName)
jlahoda
parents: 44019
diff changeset
   993
    public Location getLocationForModule(Location location, JavaFileObject fo) throws IOException {
42814
058fc03646d9 8171005: Fix JavaFileManager.getLocationForModule(Location location, JavaFileObject fo, String pkgName) to work with location == CLASS_OUTPUT
jlahoda
parents: 42261
diff changeset
   994
        checkModuleOrientedOrOutputLocation(location);
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   995
        if (!(fo instanceof PathFileObject))
43772
4e5350b7be75 8173777: Merge javac -Xmodule into javac--patch-module
jlahoda
parents: 43767
diff changeset
   996
            return null;
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
   997
        Path p = Locations.normalize(((PathFileObject) fo).path);
44063
5f0cf4126949 8175560: Drop String pkgName from javax.tools.JavaFileManager.getLocationForModule(Location location, JavaFileObject fo, String pkgName)
jlahoda
parents: 44019
diff changeset
   998
            // need to find p in location
5f0cf4126949 8175560: Drop String pkgName from javax.tools.JavaFileManager.getLocationForModule(Location location, JavaFileObject fo, String pkgName)
jlahoda
parents: 44019
diff changeset
   999
        return locations.getLocationForModule(location, p);
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
  1000
    }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
  1001
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
  1002
    @Override @DefinedBy(Api.COMPILER)
44019
284fa2ebd030 8173914: StandardJavaFileManager.setLocationForModule
jjg
parents: 43772
diff changeset
  1003
    public void setLocationForModule(Location location, String moduleName, Collection<? extends Path> paths)
284fa2ebd030 8173914: StandardJavaFileManager.setLocationForModule
jjg
parents: 43772
diff changeset
  1004
            throws IOException {
284fa2ebd030 8173914: StandardJavaFileManager.setLocationForModule
jjg
parents: 43772
diff changeset
  1005
        nullCheck(location);
284fa2ebd030 8173914: StandardJavaFileManager.setLocationForModule
jjg
parents: 43772
diff changeset
  1006
        checkModuleOrientedOrOutputLocation(location);
284fa2ebd030 8173914: StandardJavaFileManager.setLocationForModule
jjg
parents: 43772
diff changeset
  1007
        locations.setLocationForModule(location, nullCheck(moduleName), nullCheck(paths));
284fa2ebd030 8173914: StandardJavaFileManager.setLocationForModule
jjg
parents: 43772
diff changeset
  1008
    }
284fa2ebd030 8173914: StandardJavaFileManager.setLocationForModule
jjg
parents: 43772
diff changeset
  1009
284fa2ebd030 8173914: StandardJavaFileManager.setLocationForModule
jjg
parents: 43772
diff changeset
  1010
    @Override @DefinedBy(Api.COMPILER)
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
  1011
    public String inferModuleName(Location location) {
42261
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
  1012
        checkNotModuleOrientedLocation(location);
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
  1013
        return locations.inferModuleName(location);
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
  1014
    }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
  1015
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
  1016
    @Override @DefinedBy(Api.COMPILER)
42261
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
  1017
    public Iterable<Set<Location>> listLocationsForModules(Location location) throws IOException {
42814
058fc03646d9 8171005: Fix JavaFileManager.getLocationForModule(Location location, JavaFileObject fo, String pkgName) to work with location == CLASS_OUTPUT
jlahoda
parents: 42261
diff changeset
  1018
        checkModuleOrientedOrOutputLocation(location);
42261
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
  1019
        return locations.listLocationsForModules(location);
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
  1020
    }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
  1021
3b41f1c69604 8142968: Module System implementation
alanb
parents: 36158
diff changeset
  1022
    @Override @DefinedBy(Api.COMPILER)
28332
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
  1023
    public Path asPath(FileObject file) {
34560
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
  1024
        if (file instanceof PathFileObject) {
b6a567b677f7 8059976: Convert JavacFileManager to use java.nio.file internally
jjg
parents: 31506
diff changeset
  1025
            return ((PathFileObject) file).path;
28332
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
  1026
        } else
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
  1027
            throw new IllegalArgumentException(file.getName());
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
  1028
    }
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
  1029
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1030
    /**
14259
fb94a1df0d53 8000208: fix langtools javadoc comment issues
jjg
parents: 10818
diff changeset
  1031
     * Enforces the specification of a "relative" name as used in
fb94a1df0d53 8000208: fix langtools javadoc comment issues
jjg
parents: 10818
diff changeset
  1032
     * {@linkplain #getFileForInput(Location,String,String)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1033
     * getFileForInput}.  This method must follow the rules defined in
06bc494ca11e Initial load
duke
parents:
diff changeset
  1034
     * that method, do not make any changes without consulting the
06bc494ca11e Initial load
duke
parents:
diff changeset
  1035
     * specification.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1036
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1037
    protected static boolean isRelativeUri(URI uri) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1038
        if (uri.isAbsolute())
06bc494ca11e Initial load
duke
parents:
diff changeset
  1039
            return false;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1040
        String path = uri.normalize().getPath();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1041
        if (path.length() == 0 /* isEmpty() is mustang API */)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1042
            return false;
6719
1ce993f87850 6502392: Invalid relative names for Filer.createResource and Filer.getResource
jjg
parents: 5847
diff changeset
  1043
        if (!path.equals(uri.getPath())) // implicitly checks for embedded . and ..
1ce993f87850 6502392: Invalid relative names for Filer.createResource and Filer.getResource
jjg
parents: 5847
diff changeset
  1044
            return false;
7840
dfc4669cbc84 6999891: DefaultFileManager incorrect
jjg
parents: 7839
diff changeset
  1045
        if (path.startsWith("/") || path.startsWith("./") || path.startsWith("../"))
dfc4669cbc84 6999891: DefaultFileManager incorrect
jjg
parents: 7839
diff changeset
  1046
            return false;
dfc4669cbc84 6999891: DefaultFileManager incorrect
jjg
parents: 7839
diff changeset
  1047
        return true;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1048
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1049
3782
ae62279eeb46 6419701: DefaultFileManager clean up: URI.create
jjg
parents: 3656
diff changeset
  1050
    // Convenience method
ae62279eeb46 6419701: DefaultFileManager clean up: URI.create
jjg
parents: 3656
diff changeset
  1051
    protected static boolean isRelativeUri(String u) {
ae62279eeb46 6419701: DefaultFileManager clean up: URI.create
jjg
parents: 3656
diff changeset
  1052
        try {
ae62279eeb46 6419701: DefaultFileManager clean up: URI.create
jjg
parents: 3656
diff changeset
  1053
            return isRelativeUri(new URI(u));
ae62279eeb46 6419701: DefaultFileManager clean up: URI.create
jjg
parents: 3656
diff changeset
  1054
        } catch (URISyntaxException e) {
ae62279eeb46 6419701: DefaultFileManager clean up: URI.create
jjg
parents: 3656
diff changeset
  1055
            return false;
ae62279eeb46 6419701: DefaultFileManager clean up: URI.create
jjg
parents: 3656
diff changeset
  1056
        }
ae62279eeb46 6419701: DefaultFileManager clean up: URI.create
jjg
parents: 3656
diff changeset
  1057
    }
ae62279eeb46 6419701: DefaultFileManager clean up: URI.create
jjg
parents: 3656
diff changeset
  1058
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1059
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
  1060
     * Converts a relative file name to a relative URI.  This is
06bc494ca11e Initial load
duke
parents:
diff changeset
  1061
     * different from File.toURI as this method does not canonicalize
06bc494ca11e Initial load
duke
parents:
diff changeset
  1062
     * the file before creating the URI.  Furthermore, no schema is
06bc494ca11e Initial load
duke
parents:
diff changeset
  1063
     * used.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1064
     * @param file a relative file name
06bc494ca11e Initial load
duke
parents:
diff changeset
  1065
     * @return a relative URI
06bc494ca11e Initial load
duke
parents:
diff changeset
  1066
     * @throws IllegalArgumentException if the file name is not
06bc494ca11e Initial load
duke
parents:
diff changeset
  1067
     * relative according to the definition given in {@link
06bc494ca11e Initial load
duke
parents:
diff changeset
  1068
     * javax.tools.JavaFileManager#getFileForInput}
06bc494ca11e Initial load
duke
parents:
diff changeset
  1069
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1070
    public static String getRelativeName(File file) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1071
        if (!file.isAbsolute()) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1072
            String result = file.getPath().replace(File.separatorChar, '/');
3782
ae62279eeb46 6419701: DefaultFileManager clean up: URI.create
jjg
parents: 3656
diff changeset
  1073
            if (isRelativeUri(result))
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1074
                return result;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1075
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1076
        throw new IllegalArgumentException("Invalid relative path: " + file);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1077
    }
5007
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1078
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1079
    /**
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1080
     * Get a detail message from an IOException.
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1081
     * Most, but not all, instances of IOException provide a non-null result
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1082
     * for getLocalizedMessage().  But some instances return null: in these
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1083
     * cases, fallover to getMessage(), and if even that is null, return the
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1084
     * name of the exception itself.
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1085
     * @param e an IOException
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1086
     * @return a string to include in a compiler diagnostic
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1087
     */
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1088
    public static String getMessage(IOException e) {
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1089
        String s = e.getLocalizedMessage();
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1090
        if (s != null)
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1091
            return s;
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1092
        s = e.getMessage();
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1093
        if (s != null)
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1094
            return s;
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1095
        return e.toString();
28dee2489196 6930076: "null" can incorrectly appear in error message compiler.err.error.reading.file
jjg
parents: 4548
diff changeset
  1096
    }
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1097
42261
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
  1098
    private void checkOutputLocation(Location location) {
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
  1099
        Objects.requireNonNull(location);
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
  1100
        if (!location.isOutputLocation())
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
  1101
            throw new IllegalArgumentException("location is not an output location: " + location.getName());
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
  1102
    }
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
  1103
42814
058fc03646d9 8171005: Fix JavaFileManager.getLocationForModule(Location location, JavaFileObject fo, String pkgName) to work with location == CLASS_OUTPUT
jlahoda
parents: 42261
diff changeset
  1104
    private void checkModuleOrientedOrOutputLocation(Location location) {
42261
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
  1105
        Objects.requireNonNull(location);
42814
058fc03646d9 8171005: Fix JavaFileManager.getLocationForModule(Location location, JavaFileObject fo, String pkgName) to work with location == CLASS_OUTPUT
jlahoda
parents: 42261
diff changeset
  1106
        if (!location.isModuleOrientedLocation() && !location.isOutputLocation())
058fc03646d9 8171005: Fix JavaFileManager.getLocationForModule(Location location, JavaFileObject fo, String pkgName) to work with location == CLASS_OUTPUT
jlahoda
parents: 42261
diff changeset
  1107
            throw new IllegalArgumentException(
058fc03646d9 8171005: Fix JavaFileManager.getLocationForModule(Location location, JavaFileObject fo, String pkgName) to work with location == CLASS_OUTPUT
jlahoda
parents: 42261
diff changeset
  1108
                    "location is not an output location or a module-oriented location: "
058fc03646d9 8171005: Fix JavaFileManager.getLocationForModule(Location location, JavaFileObject fo, String pkgName) to work with location == CLASS_OUTPUT
jlahoda
parents: 42261
diff changeset
  1109
                            + location.getName());
42261
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
  1110
    }
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
  1111
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
  1112
    private void checkNotModuleOrientedLocation(Location location) {
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
  1113
        Objects.requireNonNull(location);
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
  1114
        if (location.isModuleOrientedLocation())
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
  1115
            throw new IllegalArgumentException("location is module-oriented: " + location.getName());
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
  1116
    }
bb52b5514ad5 8163190: Clarify JavaFileManager use of \"module location\"
jjg
parents: 41033
diff changeset
  1117
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1118
    /* Converters between files and paths.
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1119
     * These are temporary until we can update the StandardJavaFileManager API.
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1120
     */
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1121
27858
chegar
parents: 27579 27852
diff changeset
  1122
    private static Iterable<Path> asPaths(final Iterable<? extends File> files) {
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1123
        if (files == null)
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1124
            return null;
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1125
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1126
        return () -> new Iterator<Path>() {
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1127
            Iterator<? extends File> iter = files.iterator();
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1128
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1129
            @Override
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1130
            public boolean hasNext() {
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1131
                return iter.hasNext();
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1132
            }
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1133
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1134
            @Override
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1135
            public Path next() {
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1136
                return iter.next().toPath();
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1137
            }
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1138
        };
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1139
    }
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1140
27858
chegar
parents: 27579 27852
diff changeset
  1141
    private static Iterable<File> asFiles(final Iterable<? extends Path> paths) {
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1142
        if (paths == null)
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1143
            return null;
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1144
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1145
        return () -> new Iterator<File>() {
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1146
            Iterator<? extends Path> iter = paths.iterator();
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1147
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1148
            @Override
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1149
            public boolean hasNext() {
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1150
                return iter.hasNext();
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1151
            }
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1152
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1153
            @Override
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1154
            public File next() {
28332
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
  1155
                try {
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
  1156
                    return iter.next().toFile();
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
  1157
                } catch (UnsupportedOperationException e) {
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
  1158
                    throw new IllegalStateException(e);
cd3ea1087d2b 8059977: StandardJavaFileManager should support java.nio.file.Path
jjg
parents: 27858
diff changeset
  1159
                }
27852
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1160
            }
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1161
        };
2e6ad0e4fe20 8061876: replace java.io.File with java.nio.file.Path (again)
jjg
parents: 27380
diff changeset
  1162
    }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1163
}