Main Page   Class Hierarchy   Alphabetical List   Compound List   File List   Compound Members  

monThreadMethod.cpp

00001 /*
00002  *                         Sun Public License Notice
00003  *
00004  * The contents of this file are subject to the Sun Public License
00005  * Version 1.0 (the "License"); you may not use this file except
00006  * in compliance with the License. A copy of the License is available
00007  * at http://www.sun.com/
00008  *
00009  * The Original Code is the Java Profiler module.  The Initial Developers
00010  * of the Original Code are Jan Stola, Pavel Vacha, Michal Pise, Petr Luner,
00011  * Lukas Petru and Marek Przeczek.
00012  *
00013  * Portions created by Jan Stola are Copyright (C) 2000-2001.
00014  * All Rights Reserved.
00015  *
00016  * Portions created by Pavel Vacha are Copyright (C) 2000-2001.
00017  * All Rights Reserved.
00018  *
00019  * Portions created by Michal Pise are Copyright (C) 2000-2001.
00020  * All Rights Reserved.
00021  *
00022  * Portions created by Petr Luner are Copyright (C) 2000-2001.
00023  * All Rights Reserved.
00024  *
00025  * Portions created by Lukas Petru are Copyright (C) 2000-2001.
00026  * All Rights Reserved.
00027  *
00028  * Portions created by Marek Przeczek are Copyright (C) 2000-2001.
00029  * All Rights Reserved.
00030  *
00031  * Contributors: Jan Stola, Pavel Vacha, Michal Pise, Petr Luner,
00032  *               Lukas Petru and Marek Przeczek.
00033  */
00034 
00035 #include "../mon/monThreadMethod.h"
00036 #include "../shared/method.h"
00037 #include "../prof/prof.h"
00038 #include "../mon/monThreadTrace.h"
00039 
00040 #ifdef USE_ALLOCATOR
00041 Allocator MonThreadMethod::_allocator;
00042 #endif
00043 
00044 void MonThreadMethod::addMonStat(jlong addHits, jlong addTime) {
00045 
00046         MonStatData::addMonStat(addHits, addTime);
00047         method->addMonStat(addHits, addTime);
00048 }
00049 
00050 void MonThreadMethod::deactivate() {
00051 
00052         Prof::prof().activeMonThreadMethods.removeNoRehash(this); 
00053 
00054         MonThreadTrace* tt = threadTraces.first();
00055         while (tt) { 
00056                 tt->deactivate();
00057                 tt = threadTraces.next(tt);
00058         }
00059 }
00060 
00061 const MonThreadMethodKey& MonThreadMethod::getKey( MonThreadMethodKey& key) {
00062                 
00063         thread->getKey( key.envId);
00064         method->getKey( key.methodId);
00065 
00066         return key;
00067 }
00068 
00069 int MonThreadMethod::operator==( const MonThreadMethodKey& key) {
00070         
00071         return (*thread == key.envId) && (*method == key.methodId);
00072 }
00073 
00074 int MonThreadMethod::hashKey( const MonThreadMethodKey& key) {
00075 
00076         return Thread::hashKey( key.envId) ^ Method::hashKey( key.methodId);
00077 }
00078 
00079 int MonThreadMethod::isActive() {
00080 
00081         return (method->isActive() && thread->isActive());
00082 }
00083 
00084 void MonThreadMethod::setUnchanged() {
00085                 
00086         IdObject::setUnchanged();
00087         clearDataChanged();
00088 }

Generated on Mon Jan 28 14:53:26 2002 for Java Profiler Dynamic Library by doxygen1.2.11.1 written by Dimitri van Heesch, © 1997-2001