src/share/classes/sun/rmi/rmic/iiop/Util.java

Thu, 24 May 2018 16:41:12 +0800

author
aoqi
date
Thu, 24 May 2018 16:41:12 +0800
changeset 1410
9c913ea7e4a1
parent 748
6845b95cba6b
permissions
-rw-r--r--

Merge

aoqi@0 1 /*
aoqi@0 2 * Copyright (c) 1999, 2007, Oracle and/or its affiliates. All rights reserved.
aoqi@0 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
aoqi@0 4 *
aoqi@0 5 * This code is free software; you can redistribute it and/or modify it
aoqi@0 6 * under the terms of the GNU General Public License version 2 only, as
aoqi@0 7 * published by the Free Software Foundation. Oracle designates this
aoqi@0 8 * particular file as subject to the "Classpath" exception as provided
aoqi@0 9 * by Oracle in the LICENSE file that accompanied this code.
aoqi@0 10 *
aoqi@0 11 * This code is distributed in the hope that it will be useful, but WITHOUT
aoqi@0 12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
aoqi@0 13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
aoqi@0 14 * version 2 for more details (a copy is included in the LICENSE file that
aoqi@0 15 * accompanied this code).
aoqi@0 16 *
aoqi@0 17 * You should have received a copy of the GNU General Public License version
aoqi@0 18 * 2 along with this work; if not, write to the Free Software Foundation,
aoqi@0 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
aoqi@0 20 *
aoqi@0 21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
aoqi@0 22 * or visit www.oracle.com if you need additional information or have any
aoqi@0 23 * questions.
aoqi@0 24 */
aoqi@0 25
aoqi@0 26 /*
aoqi@0 27 * Licensed Materials - Property of IBM
aoqi@0 28 * RMI-IIOP v1.0
aoqi@0 29 * Copyright IBM Corp. 1998 1999 All Rights Reserved
aoqi@0 30 *
aoqi@0 31 */
aoqi@0 32
aoqi@0 33 package sun.rmi.rmic.iiop;
aoqi@0 34
aoqi@0 35 import java.io.File;
aoqi@0 36 import sun.tools.java.Identifier;
aoqi@0 37
aoqi@0 38 import com.sun.corba.se.impl.util.PackagePrefixChecker;
aoqi@0 39
aoqi@0 40 /**
aoqi@0 41 * Util provides static utility methods used by other rmic classes.
aoqi@0 42 * @author Bryan Atsatt
aoqi@0 43 */
aoqi@0 44
aoqi@0 45 public final class Util implements sun.rmi.rmic.Constants {
aoqi@0 46
aoqi@0 47
aoqi@0 48 public static String packagePrefix(){ return PackagePrefixChecker.packagePrefix();}
aoqi@0 49
aoqi@0 50
aoqi@0 51 /**
aoqi@0 52 * Return the directory that should be used for output for a given
aoqi@0 53 * class.
aoqi@0 54 * @param theClass The fully qualified name of the class.
aoqi@0 55 * @param rootDir The directory to use as the root of the
aoqi@0 56 * package heirarchy. May be null, in which case the current
aoqi@0 57 * working directory is used as the root.
aoqi@0 58 */
aoqi@0 59 private static File getOutputDirectoryFor(Identifier theClass,
aoqi@0 60 File rootDir,
aoqi@0 61 BatchEnvironment env,
aoqi@0 62 boolean idl ) {
aoqi@0 63 File outputDir = null;
aoqi@0 64 String className = theClass.getFlatName().toString().replace('.', SIGC_INNERCLASS);
aoqi@0 65 String qualifiedClassName = className;
aoqi@0 66 String packagePath = null;
aoqi@0 67 String packageName = theClass.getQualifier().toString();
aoqi@0 68 //Shift package names for stubs generated for interfaces.
aoqi@0 69 /*if(type.isInterface())*/
aoqi@0 70 packageName = correctPackageName(packageName, idl, env.getStandardPackage());
aoqi@0 71 //Done.
aoqi@0 72 if (packageName.length() > 0) {
aoqi@0 73 qualifiedClassName = packageName + "." + className;
aoqi@0 74 packagePath = packageName.replace('.', File.separatorChar);
aoqi@0 75 }
aoqi@0 76
aoqi@0 77 // Do we have a root directory?
aoqi@0 78
aoqi@0 79 if (rootDir != null) {
aoqi@0 80
aoqi@0 81 // Yes, do we have a package name?
aoqi@0 82
aoqi@0 83 if (packagePath != null) {
aoqi@0 84
aoqi@0 85 // Yes, so use it as the root. Open the directory...
aoqi@0 86
aoqi@0 87 outputDir = new File(rootDir, packagePath);
aoqi@0 88
aoqi@0 89 // Make sure the directory exists...
aoqi@0 90
aoqi@0 91 ensureDirectory(outputDir,env);
aoqi@0 92
aoqi@0 93 } else {
aoqi@0 94
aoqi@0 95 // Default package, so use root as output dir...
aoqi@0 96
aoqi@0 97 outputDir = rootDir;
aoqi@0 98 }
aoqi@0 99 } else {
aoqi@0 100
aoqi@0 101 // No root directory. Get the current working directory...
aoqi@0 102
aoqi@0 103 String workingDirPath = System.getProperty("user.dir");
aoqi@0 104 File workingDir = new File(workingDirPath);
aoqi@0 105
aoqi@0 106 // Do we have a package name?
aoqi@0 107
aoqi@0 108 if (packagePath == null) {
aoqi@0 109
aoqi@0 110 // No, so use working directory...
aoqi@0 111
aoqi@0 112 outputDir = workingDir;
aoqi@0 113
aoqi@0 114 } else {
aoqi@0 115
aoqi@0 116 // Yes, so use working directory as the root...
aoqi@0 117
aoqi@0 118 outputDir = new File(workingDir, packagePath);
aoqi@0 119
aoqi@0 120 // Make sure the directory exists...
aoqi@0 121
aoqi@0 122 ensureDirectory(outputDir,env);
aoqi@0 123 }
aoqi@0 124 }
aoqi@0 125
aoqi@0 126 // Finally, return the directory...
aoqi@0 127
aoqi@0 128 return outputDir;
aoqi@0 129 }
aoqi@0 130
aoqi@0 131 public static File getOutputDirectoryForIDL(Identifier theClass,
aoqi@0 132 File rootDir,
aoqi@0 133 BatchEnvironment env) {
aoqi@0 134 return getOutputDirectoryFor(theClass, rootDir, env, true);
aoqi@0 135 }
aoqi@0 136
aoqi@0 137 public static File getOutputDirectoryForStub(Identifier theClass,
aoqi@0 138 File rootDir,
aoqi@0 139 BatchEnvironment env) {
aoqi@0 140 return getOutputDirectoryFor(theClass, rootDir, env, false);
aoqi@0 141 }
aoqi@0 142
aoqi@0 143 private static void ensureDirectory (File dir, BatchEnvironment env) {
aoqi@0 144 if (!dir.exists()) {
aoqi@0 145 dir.mkdirs();
aoqi@0 146 if (!dir.exists()) {
aoqi@0 147 env.error(0,"rmic.cannot.create.dir",dir.getAbsolutePath());
aoqi@0 148 throw new InternalError();
aoqi@0 149 }
aoqi@0 150 }
aoqi@0 151 }
aoqi@0 152
aoqi@0 153 public static String correctPackageName(
aoqi@0 154 String p, boolean idl, boolean standardPackage){
aoqi@0 155 if (idl){
aoqi@0 156 return p;
aoqi@0 157 } else {
aoqi@0 158 if (standardPackage) {
aoqi@0 159 return p;
aoqi@0 160 } else {
aoqi@0 161 return PackagePrefixChecker.correctPackageName(p);
aoqi@0 162 }
aoqi@0 163 }
aoqi@0 164 }
aoqi@0 165
aoqi@0 166 public static boolean isOffendingPackage(String p){
aoqi@0 167 return PackagePrefixChecker.isOffendingPackage(p);
aoqi@0 168 }
aoqi@0 169
aoqi@0 170 public static boolean hasOffendingPrefix(String p){
aoqi@0 171 return PackagePrefixChecker.hasOffendingPrefix(p);
aoqi@0 172 }
aoqi@0 173
aoqi@0 174 }

mercurial