📄 reflectorloader.java
字号:
/* * $Id: ReflectorLoader.java,v 1.1 2006/05/30 18:27:48 blackdrag Exp $ * * Copyright 2003 (C) Jochen Theodorou. All Rights Reserved. * * Redistribution and use of this software and associated documentation * ("Software"), with or without modification, are permitted provided that the * following conditions are met: 1. Redistributions of source code must retain * copyright statements and notices. Redistributions must also contain a copy * of this document. 2. Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the distribution. 3. * The name "groovy" must not be used to endorse or promote products derived * from this Software without prior written permission of The Codehaus. For * written permission, please contact info@codehaus.org. 4. Products derived * from this Software may not be called "groovy" nor may "groovy" appear in * their names without prior written permission of The Codehaus. "groovy" is a * registered trademark of The Codehaus. 5. Due credit should be given to The * Codehaus - http://groovy.codehaus.org/ * * THIS SOFTWARE IS PROVIDED BY THE CODEHAUS AND CONTRIBUTORS ``AS IS'' AND ANY * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL THE CODEHAUS OR ITS CONTRIBUTORS BE LIABLE FOR * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH * DAMAGE. * */package org.codehaus.groovy.runtime;import java.security.ProtectionDomain;/** * Reflector creation helper. This class is used to define the Refloctor classes. * For each ClassLoader such a Loader will be created by the MetaClass. * The only special about this loader is, that it knows the class Reflector, * which is the base class of all runtime created Reflectors. * * @author <a href="mailto:blackdrag@gmx.org">Jochen Theodorou</a> * @version $Revision: 1.1 $ */public class ReflectorLoader extends ClassLoader { /** * returns the Reflector class. * * @return the Reflector class if the name matches * @throws ClassNotFoundException if the name is not matching Reflector * @see Reflector */ protected Class findClass(String name) throws ClassNotFoundException { if (delegatationLoader==null) return super.loadClass(name); return delegatationLoader.loadClass(name); } /** * helper method to define Reflector classes * @param name of the Reflector * @param bytecode the bytecode * @param domain the protection domain * @return the generated class */ public Class defineClass(String name, byte[] bytecode, ProtectionDomain domain) { Class c = defineClass(name, bytecode, 0, bytecode.length, domain); resolveClass(c); return c; } /** * creates a RelfectorLoader. * @param parent the parent loader. This should never be null! */ public ReflectorLoader(ClassLoader parent) { super(parent!=null?parent:getSystemClassLoader()); delegatationLoader = getClass().getClassLoader(); } private ClassLoader delegatationLoader; }
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -