reSIProcate/stack  9694
TimeAccumulate.cxx
Go to the documentation of this file.
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  */