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

📄 classvisitor.java

📁 开源的java 编辑器源代码
💻 JAVA
字号:
/*** * ASM: a very small and fast Java bytecode manipulation framework * Copyright (C) 2000 INRIA, France Telecom * Copyright (C) 2002 France Telecom * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA * * Contact: Eric.Bruneton@rd.francetelecom.com * * Author: Eric Bruneton */package org.objectweb.asm;/** * A visitor to visit a Java class. The methods of this interface must be called * in the following order: <tt>visit</tt> (<tt>visitField</tt> | * <tt>visitMethod</tt> | <tt>visitInnerClass</tt>)* <tt>visitEnd</tt>. */public interface ClassVisitor {  /**   * Visits the header of the class.   *   * @param access the class's access flags (see {@link Constants}). This   *      parameter also indicates if the class is deprecated.   * @param name the internal name of the class (see {@link Type#getInternalName   *      getInternalName}).   * @param superName the internal of name of the super class (see {@link   *      Type#getInternalName getInternalName}). For interfaces, the super   *      class is {@link Object}. May be <tt>null</tt>, but only for the {@link   *      Object java.lang.Object} class.   * @param interfaces the internal names of the class's interfaces (see {@link   *      Type#getInternalName getInternalName}). May be <tt>null</tt>.   * @param sourceFile the name of the source file from which this class was   *      compiled. May be <tt>null</tt>.   */  void visit (    int access,    String name,    String superName,    String[] interfaces,    String sourceFile);  /**   * Visits information about an inner class. This inner class is not   * necessarily a member of the class being visited.   *   * @param name the internal name of an inner class (see {@link   *      Type#getInternalName getInternalName}).   * @param outerName the internal name of the class to which the inner class   *      belongs (see {@link Type#getInternalName getInternalName}). May be   *      <tt>null</tt>.   * @param innerName the (simple) name of the inner class inside its enclosing   *      class. May be <tt>null</tt> for anonymous inner classes.   * @param access the access flags of the inner class as originally declared   *      in the enclosing class.   */  void visitInnerClass (    String name,    String outerName,    String innerName,    int access);  /**   * Visits a field of the class.   *   * @param access the field's access flags (see {@link Constants}). This   *      parameter also indicates if the field is synthetic and/or deprecated.   * @param name the field's name.   * @param desc the field's descriptor (see {@link Type Type}).   * @param value the field's initial value. This parameter, which may be   *      <tt>null</tt> if the field does not have an initial value, must be an   *      {@link java.lang.Integer Integer}, a {@link java.lang.Float Float}, a   *      {@link java.lang.Long Long}, a {@link java.lang.Double Double} or a   *      {@link String String}.   */  void visitField (int access, String name, String desc, Object value);  /**   * Visits a method of the class. This method <i>must</i> return a new   * {@link CodeVisitor CodeVisitor} instance (or <tt>null</tt>) each time it   * is called, i.e., it should not return a previously returned visitor.   *   * @param access the method's access flags (see {@link Constants}). This   *      parameter also indicates if the method is synthetic and/or deprecated.   * @param name the method's name.   * @param desc the method's descriptor (see {@link Type Type}).   * @param exceptions the internal names of the method's exception   *      classes (see {@link Type#getInternalName getInternalName}). May be   *      <tt>null</tt>.   * @return an object to visit the byte code of the method, or <tt>null</tt> if   *      this class visitor is not interested in visiting the code of this   *      method.   */  CodeVisitor visitMethod (    int access,    String name,    String desc,    String[] exceptions);  /**   * Visits the end of the class. This method, which is the last one to be   * called, is used to inform the visitor that all the fields and methods of   * the class have been visited.   */  void visitEnd ();}

⌨️ 快捷键说明

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