Release 1.6.4
[yazpp-moved-to-github.git] / src / timestat.cpp
1 /* This file is part of the yazpp toolkit.
2  * Copyright (C) Index Data 
3  * All rights reserved.
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions are met:
6  *
7  *     * Redistributions of source code must retain the above copyright
8  *       notice, this list of conditions and the following disclaimer.
9  *     * Redistributions in binary form must reproduce the above copyright
10  *       notice, this list of conditions and the following disclaimer in the
11  *       documentation and/or other materials provided with the distribution.
12  *     * Neither the name of Index Data nor the names of its contributors
13  *       may be used to endorse or promote products derived from this
14  *       software without specific prior written permission.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND ANY
17  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19  * DISCLAIMED. IN NO EVENT SHALL THE REGENTS AND CONTRIBUTORS BE LIABLE FOR ANY
20  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
21  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
22  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
23  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26  */
27
28 #if HAVE_CONFIG_H
29 #include <config.h>
30 #endif
31 #include <yazpp/timestat.h>
32 #include <time.h>
33
34 using namespace yazpp_1;
35
36 class TimeStat::Rep {
37     friend class TimeStat;
38     time_t sec;   // time of most recent bucket
39     int *bucket;
40     int ptr;
41     int size;
42 };
43
44 TimeStat::TimeStat(int sz)
45 {
46     m_p = new Rep;
47     m_p->sec = 0;
48     m_p->size = sz;
49     m_p->bucket = new int[m_p->size];
50     m_p->ptr = 0;
51 }
52
53 TimeStat::~TimeStat()
54 {
55     delete [] m_p->bucket;
56     delete m_p;
57 }
58
59 int TimeStat::get_total()
60 {
61     add_bytes(0);
62     int bw = 0;
63     int i;
64     for (i = 0; i < m_p->size; i++)
65         bw += m_p->bucket[i];
66     return bw;
67 }
68
69 void TimeStat::add_bytes(int b)
70 {
71     time_t now = time(0);
72
73     if (now >= m_p->sec)
74     {
75         int d = now - m_p->sec;
76         if (d > m_p->size)
77             d = m_p->size;
78         while (--d >= 0)
79         {
80             if (++m_p->ptr == m_p->size)
81                 m_p->ptr = 0;
82             m_p->bucket[m_p->ptr] = 0;
83         }
84         m_p->bucket[m_p->ptr] += b;
85     }
86     m_p->sec = now;
87 }
88
89 /*
90  * Local variables:
91  * c-basic-offset: 4
92  * c-file-style: "Stroustrup"
93  * indent-tabs-mode: nil
94  * End:
95  * vim: shiftwidth=4 tabstop=8 expandtab
96  */
97