Remove old autovect-branch by moving to "dead" directory.
[official-gcc.git] / old-autovect-branch / libjava / classpath / gnu / classpath / jdwp / event / ClassPrepareEvent.java
blob22cede0c50a138e735b58eda03fa31839394de8a
1 /* ClassPrepareEvent.java -- An event specifying that a class has been
2 prepared by the virtual machine
3 Copyright (C) 2005 Free Software Foundation
5 This file is part of GNU Classpath.
7 GNU Classpath is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2, or (at your option)
10 any later version.
12 GNU Classpath is distributed in the hope that it will be useful, but
13 WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with GNU Classpath; see the file COPYING. If not, write to the
19 Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
20 02110-1301 USA.
22 Linking this library statically or dynamically with other modules is
23 making a combined work based on this library. Thus, the terms and
24 conditions of the GNU General Public License cover the whole
25 combination.
27 As a special exception, the copyright holders of this library give you
28 permission to link this library with independent modules to produce an
29 executable, regardless of the license terms of these independent
30 modules, and to copy and distribute the resulting executable under
31 terms of your choice, provided that you also meet, for each linked
32 terms of your choice, provided that you also meet, for each linked
33 independent module, the terms and conditions of the license of that
34 module. An independent module is a module which is not derived from
35 or based on this library. If you modify this library, you may extend
36 this exception to your version of the library, but you are not
37 obligated to do so. If you do not wish to do so, delete this
38 exception statement from your version. */
41 package gnu.classpath.jdwp.event;
43 import gnu.classpath.jdwp.JdwpConstants;
44 import gnu.classpath.jdwp.VMIdManager;
45 import gnu.classpath.jdwp.id.ReferenceTypeId;
46 import gnu.classpath.jdwp.id.ThreadId;
47 import gnu.classpath.jdwp.util.JdwpString;
48 import gnu.classpath.jdwp.util.Signature;
50 import java.io.DataOutputStream;
51 import java.io.IOException;
53 /**
54 * "Notification of a class prepare in the target VM. See the JVM
55 * specification for a definition of class preparation. Class prepare
56 * events are not generated for primtiive classes (for example,
57 * <code>java.lang.Integer.TYPE</code>)." -- JDWP 1.4.2
59 * @author Keith Seitz (keiths@redhat.com)
61 public class ClassPrepareEvent
62 extends Event
64 // The thread in which this event occurred
65 private Thread _thread;
67 // The class that was prepared
68 private Class _class;
70 // Prepare flags
71 private int _status;
73 /**
74 * Class has been verified
76 public static final int STATUS_VERIFIED
77 = JdwpConstants.ClassStatus.VERIFIED;
79 /**
80 * Class has been prepared
82 public static final int STATUS_PREPARED
83 = JdwpConstants.ClassStatus.PREPARED;
85 /**
86 * Class has been initialized
88 public static final int STATUS_INITIALIZED
89 = JdwpConstants.ClassStatus.INITIALIZED;
91 /**
92 * Error preparing class
94 public static final int STATUS_ERROR
95 = JdwpConstants.ClassStatus.ERROR;
97 /**
98 * Constructs a new <code>ClassPrepareEvent</code>
100 * @param thread thread in which event occurred
101 * @param clazz class which was prepared
102 * @param flags prepare status flags
104 public ClassPrepareEvent (Thread thread, Class clazz, int flags)
106 super (JdwpConstants.EventKind.CLASS_PREPARE);
107 _thread = thread;
108 _class = clazz;
109 _status = flags;
113 * Returns a specific filtering parameter for this event.
114 * Valid types are thread and class.
116 * @param type the type of parameter desired
117 * @returns the desired parameter or <code>null</code>
119 public Object getParameter (Class type)
121 if (type == ThreadId.class)
122 return _thread;
123 else if (type == ReferenceTypeId.class)
124 return _class;
126 return null;
130 * Writes the event to the given stream
132 * @param outStream the output stream to write the event to
134 protected void _writeData (DataOutputStream outStream)
135 throws IOException
137 VMIdManager idm = VMIdManager.getDefault();
138 ThreadId tid = (ThreadId) idm.getObjectId (_thread);
139 ReferenceTypeId rid = idm.getReferenceTypeId (_class);
141 tid.write (outStream);
142 rid.writeTagged (outStream);
143 JdwpString.writeString (outStream,
144 Signature.computeClassSignature (_class));
145 outStream.writeInt (_status);