src/share/classes/com/sun/tools/javac/file/RegularFileObject.java

Mon, 12 Sep 2011 11:39:08 -0700

author
jjg
date
Mon, 12 Sep 2011 11:39:08 -0700
changeset 1080
edd7d9bd32dd
parent 581
f2fdd52e4e87
child 2037
36e342dd57e2
permissions
-rw-r--r--

7068451: Regression: javac compiles fixed sources against previous, not current, version of generated sources
Reviewed-by: mcimadamore

jjg@57 1 /*
jjg@1080 2 * Copyright (c) 2005, 2011, Oracle and/or its affiliates. All rights reserved.
jjg@57 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
jjg@57 4 *
jjg@57 5 * This code is free software; you can redistribute it and/or modify it
jjg@57 6 * under the terms of the GNU General Public License version 2 only, as
ohair@554 7 * published by the Free Software Foundation. Oracle designates this
jjg@57 8 * particular file as subject to the "Classpath" exception as provided
ohair@554 9 * by Oracle in the LICENSE file that accompanied this code.
jjg@57 10 *
jjg@57 11 * This code is distributed in the hope that it will be useful, but WITHOUT
jjg@57 12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
jjg@57 13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
jjg@57 14 * version 2 for more details (a copy is included in the LICENSE file that
jjg@57 15 * accompanied this code).
jjg@57 16 *
jjg@57 17 * You should have received a copy of the GNU General Public License version
jjg@57 18 * 2 along with this work; if not, write to the Free Software Foundation,
jjg@57 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
jjg@57 20 *
ohair@554 21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
ohair@554 22 * or visit www.oracle.com if you need additional information or have any
ohair@554 23 * questions.
jjg@57 24 */
jjg@57 25
jjg@57 26 package com.sun.tools.javac.file;
jjg@57 27
jjg@57 28 import java.io.File;
jjg@57 29 import java.io.FileInputStream;
jjg@57 30 import java.io.FileOutputStream;
jjg@57 31 import java.io.IOException;
jjg@57 32 import java.io.InputStream;
jjg@57 33 import java.io.OutputStream;
jjg@57 34 import java.io.OutputStreamWriter;
jjg@57 35 import java.io.Writer;
jjg@424 36 import java.lang.ref.Reference;
jjg@424 37 import java.lang.ref.SoftReference;
jjg@57 38 import java.net.URI;
jjg@57 39 import java.nio.ByteBuffer;
jjg@57 40 import java.nio.CharBuffer;
jjg@57 41 import java.nio.charset.CharsetDecoder;
jjg@57 42 import javax.tools.JavaFileObject;
jjg@57 43
jjg@57 44 /**
jjg@57 45 * A subclass of JavaFileObject representing regular files.
jjg@333 46 *
jjg@581 47 * <p><b>This is NOT part of any supported API.
jjg@333 48 * If you write code that depends on this, you do so at your own risk.
jjg@333 49 * This code and its internal interfaces are subject to change or
jjg@333 50 * deletion without notice.</b>
jjg@57 51 */
jjg@57 52 class RegularFileObject extends BaseFileObject {
jjg@57 53
jjg@57 54 /** Have the parent directories been created?
jjg@57 55 */
jjg@57 56 private boolean hasParents = false;
jjg@57 57 private String name;
jjg@424 58 final File file;
jjg@424 59 private Reference<File> absFileRef;
jjg@57 60
jjg@57 61 public RegularFileObject(JavacFileManager fileManager, File f) {
jjg@57 62 this(fileManager, f.getName(), f);
jjg@57 63 }
jjg@57 64
jjg@57 65 public RegularFileObject(JavacFileManager fileManager, String name, File f) {
jjg@57 66 super(fileManager);
jjg@57 67 if (f.isDirectory()) {
jjg@57 68 throw new IllegalArgumentException("directories not supported");
jjg@57 69 }
jjg@57 70 this.name = name;
jjg@424 71 this.file = f;
jjg@57 72 }
jjg@57 73
jjg@415 74 @Override
jjg@415 75 public URI toUri() {
jjg@424 76 return file.toURI().normalize();
jjg@415 77 }
jjg@415 78
jjg@415 79 @Override
jjg@415 80 public String getName() {
jjg@424 81 return file.getPath();
jjg@415 82 }
jjg@415 83
jjg@415 84 @Override
jjg@415 85 public String getShortName() {
jjg@415 86 return name;
jjg@415 87 }
jjg@415 88
jjg@415 89 @Override
jjg@415 90 public JavaFileObject.Kind getKind() {
jjg@415 91 return getKind(name);
jjg@415 92 }
jjg@415 93
jjg@415 94 @Override
jjg@57 95 public InputStream openInputStream() throws IOException {
jjg@424 96 return new FileInputStream(file);
jjg@57 97 }
jjg@57 98
jjg@400 99 @Override
jjg@57 100 public OutputStream openOutputStream() throws IOException {
jjg@1080 101 fileManager.flushCache(this);
jjg@57 102 ensureParentDirectoriesExist();
jjg@424 103 return new FileOutputStream(file);
jjg@57 104 }
jjg@57 105
jjg@57 106 @Override
jjg@57 107 public CharBuffer getCharContent(boolean ignoreEncodingErrors) throws IOException {
jjg@57 108 CharBuffer cb = fileManager.getCachedContent(this);
jjg@57 109 if (cb == null) {
jjg@424 110 InputStream in = new FileInputStream(file);
jjg@57 111 try {
jjg@57 112 ByteBuffer bb = fileManager.makeByteBuffer(in);
jjg@57 113 JavaFileObject prev = fileManager.log.useSource(this);
jjg@57 114 try {
jjg@57 115 cb = fileManager.decode(bb, ignoreEncodingErrors);
jjg@57 116 } finally {
jjg@57 117 fileManager.log.useSource(prev);
jjg@57 118 }
jjg@57 119 fileManager.recycleByteBuffer(bb);
jjg@57 120 if (!ignoreEncodingErrors) {
jjg@57 121 fileManager.cache(this, cb);
jjg@57 122 }
jjg@57 123 } finally {
jjg@57 124 in.close();
jjg@57 125 }
jjg@57 126 }
jjg@57 127 return cb;
jjg@57 128 }
jjg@57 129
jjg@57 130 @Override
jjg@415 131 public Writer openWriter() throws IOException {
jjg@1080 132 fileManager.flushCache(this);
jjg@415 133 ensureParentDirectoriesExist();
jjg@424 134 return new OutputStreamWriter(new FileOutputStream(file), fileManager.getEncodingName());
jjg@415 135 }
jjg@415 136
jjg@415 137 @Override
jjg@415 138 public long getLastModified() {
jjg@424 139 return file.lastModified();
jjg@415 140 }
jjg@415 141
jjg@415 142 @Override
jjg@415 143 public boolean delete() {
jjg@424 144 return file.delete();
jjg@415 145 }
jjg@415 146
jjg@415 147 @Override
jjg@415 148 protected CharsetDecoder getDecoder(boolean ignoreEncodingErrors) {
jjg@415 149 return fileManager.getDecoder(fileManager.getEncodingName(), ignoreEncodingErrors);
jjg@415 150 }
jjg@415 151
jjg@415 152 @Override
jjg@415 153 protected String inferBinaryName(Iterable<? extends File> path) {
jjg@424 154 String fPath = file.getPath();
jjg@415 155 //System.err.println("RegularFileObject " + file + " " +r.getPath());
jjg@415 156 for (File dir: path) {
jjg@415 157 //System.err.println("dir: " + dir);
jjg@415 158 String dPath = dir.getPath();
jjg@415 159 if (dPath.length() == 0)
jjg@415 160 dPath = System.getProperty("user.dir");
jjg@415 161 if (!dPath.endsWith(File.separator))
jjg@415 162 dPath += File.separator;
jjg@415 163 if (fPath.regionMatches(true, 0, dPath, 0, dPath.length())
jjg@415 164 && new File(fPath.substring(0, dPath.length())).equals(new File(dPath))) {
jjg@415 165 String relativeName = fPath.substring(dPath.length());
jjg@415 166 return removeExtension(relativeName).replace(File.separatorChar, '.');
jjg@415 167 }
jjg@415 168 }
jjg@415 169 return null;
jjg@415 170 }
jjg@415 171
jjg@415 172 @Override
jjg@415 173 public boolean isNameCompatible(String cn, JavaFileObject.Kind kind) {
jjg@415 174 cn.getClass();
jjg@415 175 // null check
jjg@415 176 if (kind == Kind.OTHER && getKind() != kind) {
jjg@415 177 return false;
jjg@415 178 }
jjg@415 179 String n = cn + kind.extension;
jjg@415 180 if (name.equals(n)) {
jjg@415 181 return true;
jjg@415 182 }
jjg@415 183 if (name.equalsIgnoreCase(n)) {
jjg@415 184 try {
jjg@415 185 // allow for Windows
jjg@424 186 return file.getCanonicalFile().getName().equals(n);
jjg@415 187 } catch (IOException e) {
jjg@415 188 }
jjg@415 189 }
jjg@415 190 return false;
jjg@415 191 }
jjg@415 192
jjg@415 193 private void ensureParentDirectoriesExist() throws IOException {
jjg@415 194 if (!hasParents) {
jjg@424 195 File parent = file.getParentFile();
jjg@415 196 if (parent != null && !parent.exists()) {
jjg@415 197 if (!parent.mkdirs()) {
jjg@415 198 if (!parent.exists() || !parent.isDirectory()) {
jjg@415 199 throw new IOException("could not create parent directories");
jjg@415 200 }
jjg@415 201 }
jjg@415 202 }
jjg@415 203 hasParents = true;
jjg@415 204 }
jjg@415 205 }
jjg@415 206
jjg@424 207 /**
jjg@424 208 * Check if two file objects are equal.
jjg@424 209 * Two RegularFileObjects are equal if the absolute paths of the underlying
jjg@424 210 * files are equal.
jjg@424 211 */
jjg@415 212 @Override
jjg@57 213 public boolean equals(Object other) {
jjg@424 214 if (this == other)
jjg@424 215 return true;
jjg@424 216
jjg@424 217 if (!(other instanceof RegularFileObject))
jjg@57 218 return false;
jjg@424 219
jjg@57 220 RegularFileObject o = (RegularFileObject) other;
jjg@424 221 return getAbsoluteFile().equals(o.getAbsoluteFile());
jjg@57 222 }
jjg@57 223
jjg@57 224 @Override
jjg@57 225 public int hashCode() {
jjg@424 226 return getAbsoluteFile().hashCode();
jjg@424 227 }
jjg@424 228
jjg@424 229 private File getAbsoluteFile() {
jjg@424 230 File absFile = (absFileRef == null ? null : absFileRef.get());
jjg@424 231 if (absFile == null) {
jjg@424 232 absFile = file.getAbsoluteFile();
jjg@424 233 absFileRef = new SoftReference<File>(absFile);
jjg@424 234 }
jjg@424 235 return absFile;
jjg@57 236 }
jjg@57 237 }

mercurial