|
reSIProcate/stack
9694
|
00001 #include "resip/stack/TimeAccumulate.hxx" 00002 #include "rutil/Logger.hxx" 00003 00004 #define RESIPROCATE_SUBSYSTEM resip::Subsystem::STATS 00005 00006 using namespace resip; 00007 00008 resip::Mutex TimeAccumulate::mMutex; 00009 00010 TimeAccumulate::TimeMap TimeAccumulate::mTimes; 00011 00012 void 00013 TimeAccumulate::dump() 00014 { 00015 Lock lock(mMutex); 00016 WarningLog(<< "Accumulated times -------------------------:"); 00017 for (TimeMap::const_iterator i = TimeAccumulate::mTimes.begin(); 00018 i != TimeAccumulate::mTimes.end(); i++) 00019 { 00020 if (i->second.totalTime) 00021 { 00022 WarningLog(<< i->first << " = " << i->second.totalTime/1000.0 00023 << " seconds for " << i->second.count 00024 << " at " << i->second.count / (i->second.totalTime/1000.0) << " per second"); 00025 } 00026 } 00027 } 00028 00029 void 00030 TimeAccumulate::clear() 00031 { 00032 Lock lock(mMutex); 00033 00034 for (TimeMap::iterator i = TimeAccumulate::mTimes.begin(); 00035 i != TimeAccumulate::mTimes.end(); i++) 00036 { 00037 i->second.count = 0; 00038 i->second.totalTime = 0; 00039 } 00040 } 00041 00042 /* ==================================================================== 00043 * The Vovida Software License, Version 1.0 00044 * 00045 * Copyright (c) 2000 Vovida Networks, Inc. All rights reserved. 00046 * 00047 * Redistribution and use in source and binary forms, with or without 00048 * modification, are permitted provided that the following conditions 00049 * are met: 00050 * 00051 * 1. Redistributions of source code must retain the above copyright 00052 * notice, this list of conditions and the following disclaimer. 00053 * 00054 * 2. Redistributions in binary form must reproduce the above copyright 00055 * notice, this list of conditions and the following disclaimer in 00056 * the documentation and/or other materials provided with the 00057 * distribution. 00058 * 00059 * 3. The names "VOCAL", "Vovida Open Communication Application Library", 00060 * and "Vovida Open Communication Application Library (VOCAL)" must 00061 * not be used to endorse or promote products derived from this 00062 * software without prior written permission. For written 00063 * permission, please contact vocal@vovida.org. 00064 * 00065 * 4. Products derived from this software may not be called "VOCAL", nor 00066 * may "VOCAL" appear in their name, without prior written 00067 * permission of Vovida Networks, Inc. 00068 * 00069 * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED 00070 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 00071 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE AND 00072 * NON-INFRINGEMENT ARE DISCLAIMED. IN NO EVENT SHALL VOVIDA 00073 * NETWORKS, INC. OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT DAMAGES 00074 * IN EXCESS OF $1,000, NOR FOR ANY INDIRECT, INCIDENTAL, SPECIAL, 00075 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 00076 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 00077 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY 00078 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 00079 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE 00080 * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH 00081 * DAMAGE. 00082 * 00083 * ==================================================================== 00084 * 00085 * This software consists of voluntary contributions made by Vovida 00086 * Networks, Inc. and many individuals on behalf of Vovida Networks, 00087 * Inc. For more information on Vovida Networks, Inc., please see 00088 * <http://www.vovida.org/>. 00089 * 00090 */
1.7.5.1