01: /*
02: * JBoss, Home of Professional Open Source
03: * Copyright 2005, JBoss Inc., and individual contributors as indicated
04: * by the @authors tag. See the copyright.txt in the distribution for a
05: * full listing of individual contributors.
06: *
07: * This is free software; you can redistribute it and/or modify it
08: * under the terms of the GNU Lesser General Public License as
09: * published by the Free Software Foundation; either version 2.1 of
10: * the License, or (at your option) any later version.
11: *
12: * This software is distributed in the hope that it will be useful,
13: * but WITHOUT ANY WARRANTY; without even the implied warranty of
14: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15: * Lesser General Public License for more details.
16: *
17: * You should have received a copy of the GNU Lesser General Public
18: * License along with this software; if not, write to the Free
19: * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
20: * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
21: */
22:
23: package org.jboss.profiler.jvmti;
24:
25: /**
26: * Interface to get notifications for references on JVMTI
27: * @author csuconic
28: *
29: */
30: public interface JVMTICallBack {
31: public static final int JVMTI_REFERENCE_CLASS = 1;// Reference from an object to its class.
32: public static final int JVMTI_REFERENCE_FIELD = 2;//Reference from an object to the value of one of its instance fields. For references of this kind the referrer_index parameter to the jvmtiObjectReferenceCallback is the index of the the instance field. The index is based on the order of all the object's fields. This includes all fields of the directly declared static and instance fields in the class, and includes all fields (both public and private) fields declared in superclasses and superinterfaces. The index is thus calculated by summing the index of field in the directly declared class (see GetClassFields), with the total number of fields (both public and private) declared in all superclasses and superinterfaces. The index starts at zero.
33: public static final int JVMTI_REFERENCE_ARRAY_ELEMENT = 3;//Reference from an array to one of its elements. For references of this kind the referrer_index parameter to the jvmtiObjectReferenceCallback is the array index.
34: public static final int JVMTI_REFERENCE_CLASS_LOADER = 4;// Reference from a class to its class loader.
35: public static final int JVMTI_REFERENCE_SIGNERS = 5;//Reference from a class to its signers array.
36: public static final int JVMTI_REFERENCE_PROTECTION_DOMAIN = 6;//Reference from a class to its protection domain.
37: public static final int JVMTI_REFERENCE_INTERFACE = 7;//Reference from a class to one of its interfaces.
38: public static final int JVMTI_REFERENCE_STATIC_FIELD = 8;//Reference from a class to the value of one of its static fields. For references of this kind the referrer_index parameter to the jvmtiObjectReferenceCallback is the index of the static field. The index is based on the order of the directly declared static and instance fields in the class (not inherited fields), starting at zero. See GetClassFields.
39: public static final int JVMTI_REFERENCE_CONSTANT_POOL = 9;//Reference from a class to a resolved entry in the constant pool. For references of this kind the referrer_index parameter to the jvmtiObjectReferenceCallback is the index into constant pool table of the class, starting at 1. See The Constant Pool in the Java Virtual Machine Specification.
40: public static final int ROOT_REFERENCE = 10;
41: public static final int THREAD_REFERENCE = 11;
42:
43: /**
44: *JNISignature for this method = (JJJJJB)V
45: * @param referenceHolder A tag id of an object (if -1 means the root)
46: * @param referencedObject A tag id of an object
47: * @param fieldId A tag id for a Field referencing the object. If -1 that means a static reference in a method
48: */
49: public void notifyReference(long referenceHolder,
50: long referencedObject, long classTag, long index,
51: long method, byte referenceType);
52:
53: /** Notifications of loaded classes*/
54: public void notifyClass(long classTag, Class clazz);
55:
56: /** Notifications of loaded classes*/
57: public void notifyObject(long classTag, long objectId, long bytes);
58:
59: }
|