All Downloads are FREE. Search and download functionalities are using the official Maven repository.

javassist.ByteArrayClassPath Maven / Gradle / Ivy

There is a newer version: 3.0.0.Alpha1
Show newest version
/*
 * Javassist, a Java-bytecode translator toolkit.
 * Copyright (C) 1999-2007 Shigeru Chiba. All Rights Reserved.
 *
 * The contents of this file are subject to the Mozilla Public License Version
 * 1.1 (the "License"); you may not use this file except in compliance with
 * the License.  Alternatively, the contents of this file may be used under
 * the terms of the GNU Lesser General Public License Version 2.1 or later.
 *
 * Software distributed under the License is distributed on an "AS IS" basis,
 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
 * for the specific language governing rights and limitations under the
 * License.
 */

package javassist;

import java.io.*;
import java.net.URL;
import java.net.MalformedURLException;

/**
 * A ByteArrayClassPath contains bytes that is served as
 * a class file to a ClassPool.  It is useful to convert
 * a byte array to a CtClass object.
 *
 * 

For example, if you want to convert a byte array b * into a CtClass object representing the class with a name * classname, then do as following: * *

     * ClassPool cp = ClassPool.getDefault();
     * cp.insertClassPath(new ByteArrayClassPath(classname, b));
     * CtClass cc = cp.get(classname);
     * 
* *

The ClassPool object cp uses the created * ByteArrayClassPath object as the source of the class file. * *

A ByteArrayClassPath must be instantiated for every * class. It contains only a single class file. * * @see javassist.ClassPath * @see ClassPool#insertClassPath(ClassPath) * @see ClassPool#appendClassPath(ClassPath) * @see ClassPool#makeClass(InputStream) */ public class ByteArrayClassPath implements ClassPath { protected String classname; protected byte[] classfile; /* * Creates a ByteArrayClassPath containing the given * bytes. * * @param name a fully qualified class name * @param classfile the contents of a class file. */ public ByteArrayClassPath(String name, byte[] classfile) { this.classname = name; this.classfile = classfile; } /** * Closes this class path. */ public void close() {} public String toString() { return "byte[]:" + classname; } /** * Opens the class file. */ public InputStream openClassfile(String classname) { if(this.classname.equals(classname)) return new ByteArrayInputStream(classfile); else return null; } /** * Obtains the URL. */ public URL find(String classname) { if(this.classname.equals(classname)) { String cname = classname.replace('.', '/') + ".class"; try { // return new File(cname).toURL(); return new URL("file:/ByteArrayClassPath/" + cname); } catch (MalformedURLException e) {} } return null; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy