⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 locator.java

📁 java ant的源码!非常值得看的源码
💻 JAVA
📖 第 1 页 / 共 2 页
字号:
/* *  Licensed to the Apache Software Foundation (ASF) under one or more *  contributor license agreements.  See the NOTICE file distributed with *  this work for additional information regarding copyright ownership. *  The ASF licenses this file to You under the Apache License, Version 2.0 *  (the "License"); you may not use this file except in compliance with *  the License.  You may obtain a copy of the License at * *      http://www.apache.org/licenses/LICENSE-2.0 * *  Unless required by applicable law or agreed to in writing, software *  distributed under the License is distributed on an "AS IS" BASIS, *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *  See the License for the specific language governing permissions and *  limitations under the License. * */package org.apache.tools.ant.launch;import java.net.MalformedURLException;import java.net.URL;import java.io.File;import java.io.FilenameFilter;import java.io.ByteArrayOutputStream;import java.io.UnsupportedEncodingException;import java.text.CharacterIterator;import java.text.StringCharacterIterator;import java.util.Locale;/** * The Locator is a utility class which is used to find certain items * in the environment. * * @since Ant 1.6 */public final class Locator {    /**     * encoding used to represent URIs     */    public static final String URI_ENCODING = "UTF-8";    // stolen from org.apache.xerces.impl.XMLEntityManager#getUserDir()    // of the Xerces-J team    // which ASCII characters need to be escaped    private static boolean[] gNeedEscaping = new boolean[128];    // the first hex character if a character needs to be escaped    private static char[] gAfterEscaping1 = new char[128];    // the second hex character if a character needs to be escaped    private static char[] gAfterEscaping2 = new char[128];    private static char[] gHexChs = {'0', '1', '2', '3', '4', '5', '6', '7',                                     '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'};    // initialize the above 3 arrays    static {        for (int i = 0; i <= 0x1f; i++) {            gNeedEscaping[i] = true;            gAfterEscaping1[i] = gHexChs[i >> 4];            gAfterEscaping2[i] = gHexChs[i & 0xf];        }        gNeedEscaping[0x7f] = true;        gAfterEscaping1[0x7f] = '7';        gAfterEscaping2[0x7f] = 'F';        char[] escChs = {' ', '<', '>', '#', '%', '"', '{', '}',                         '|', '\\', '^', '~', '[', ']', '`'};        int len = escChs.length;        char ch;        for (int i = 0; i < len; i++) {            ch = escChs[i];            gNeedEscaping[ch] = true;            gAfterEscaping1[ch] = gHexChs[ch >> 4];            gAfterEscaping2[ch] = gHexChs[ch & 0xf];        }    }    /**     * Not instantiable     */    private Locator() {    }    /**     * Find the directory or jar file the class has been loaded from.     *     * @param c the class whose location is required.     * @return the file or jar with the class or null if we cannot     *         determine the location.     *     * @since Ant 1.6     */    public static File getClassSource(Class c) {        String classResource = c.getName().replace('.', '/') + ".class";        return getResourceSource(c.getClassLoader(), classResource);    }    /**     * Find the directory or jar a given resource has been loaded from.     *     * @param c the classloader to be consulted for the source.     * @param resource the resource whose location is required.     *     * @return the file with the resource source or null if     *         we cannot determine the location.     *     * @since Ant 1.6     */    public static File getResourceSource(ClassLoader c, String resource) {        if (c == null) {            c = Locator.class.getClassLoader();        }        URL url = null;        if (c == null) {            url = ClassLoader.getSystemResource(resource);        } else {            url = c.getResource(resource);        }        if (url != null) {            String u = url.toString();            if (u.startsWith("jar:file:")) {                int pling = u.indexOf("!");                String jarName = u.substring(4, pling);                return new File(fromURI(jarName));            } else if (u.startsWith("file:")) {                int tail = u.indexOf(resource);                String dirName = u.substring(0, tail);                return new File(fromURI(dirName));            }        }        return null;    }    /**     * Constructs a file path from a <code>file:</code> URI.     *     * <p>Will be an absolute path if the given URI is absolute.</p>     *     * <p>Prior to Java 1.4,     * swallows '%' that are not followed by two characters.</p>     *     * See <a href="http://www.w3.org/TR/xml11/#dt-sysid">dt-sysid</a>     * which makes some mention of how     * characters not supported by URI Reference syntax should be escaped.     *     * @param uri the URI designating a file in the local filesystem.     * @return the local file system path for the file.     * @throws IllegalArgumentException if the URI is malformed or not a legal file: URL     * @since Ant 1.6     */    public static String fromURI(String uri) {        // #8031: first try Java 1.4.        Class uriClazz = null;        try {            uriClazz = Class.forName("java.net.URI");        } catch (ClassNotFoundException cnfe) {            // Fine, Java 1.3 or earlier, do it by hand.        }        // Also check for properly formed URIs. Ant formerly recommended using        // nonsense URIs such as "file:./foo.xml" in XML includes. You shouldn't        // do that (just "foo.xml" is correct) but for compatibility we special-case        // things when the path is not absolute, and fall back to the old parsing behavior.        if (uriClazz != null && uri.startsWith("file:/")) {            try {                java.lang.reflect.Method createMethod                    = uriClazz.getMethod("create", new Class[] {String.class});                Object uriObj = createMethod.invoke(null, new Object[] {uri});                java.lang.reflect.Constructor fileConst                    = File.class.getConstructor(new Class[] {uriClazz});                File f = (File) fileConst.newInstance(new Object[] {uriObj});                return f.getAbsolutePath();            } catch (java.lang.reflect.InvocationTargetException e) {                Throwable e2 = e.getTargetException();                if (e2 instanceof IllegalArgumentException) {                    // Bad URI, pass this on.                    throw (IllegalArgumentException) e2;                } else {                    // Unexpected target exception? Should not happen.                    e2.printStackTrace();                }            } catch (Exception e) {                // Reflection problems? Should not happen, debug.                e.printStackTrace();            }        }        // Fallback method for Java 1.3 or earlier.        URL url = null;        try {            url = new URL(uri);        } catch (MalformedURLException emYouEarlEx) {            // Ignore malformed exception        }        if (url == null || !("file".equals(url.getProtocol()))) {            throw new IllegalArgumentException("Can only handle valid file: URIs");        }        StringBuffer buf = new StringBuffer(url.getHost());        if (buf.length() > 0) {            buf.insert(0, File.separatorChar).insert(0, File.separatorChar);        }        String file = url.getFile();        int queryPos = file.indexOf('?');        buf.append((queryPos < 0) ? file : file.substring(0, queryPos));        uri = buf.toString().replace('/', File.separatorChar);        if (File.pathSeparatorChar == ';' && uri.startsWith("\\") && uri.length() > 2            && Character.isLetter(uri.charAt(1)) && uri.lastIndexOf(':') > -1) {            uri = uri.substring(1);        }        String path = null;        try {            path = decodeUri(uri);            String cwd = System.getProperty("user.dir");            int posi = cwd.indexOf(":");            if ((posi > 0) && path.startsWith(File.separator)) {               path = cwd.substring(0, posi + 1) + path;            }        } catch (UnsupportedEncodingException exc) {            // not sure whether this is clean, but this method is            // declared not to throw exceptions.            throw new IllegalStateException("Could not convert URI to path: "                                            + exc.getMessage());        }        return path;    }    /**     * Decodes an Uri with % characters.     * The URI is escaped     * @param uri String with the uri possibly containing % characters.     * @return The decoded Uri     * @throws UnsupportedEncodingException if UTF-8 is not available

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -