/* * Javassist, a Java-bytecode translator toolkit. * Copyright (C) 1999-2003 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.*; /** * 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: * *

* *

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) */ 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 a class file. */ public InputStream openClassfile(String classname) { if(this.classname.equals(classname)) return new ByteArrayInputStream(classfile); else return null; } }