summaryrefslogtreecommitdiffstats
path: root/Source/WebKit/android/WebCoreSupport/V8Counters.cpp
blob: d164f9a918dc73a5256765101a5233ee9d0851ec (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
/*
 * Copyright 2010, The Android Open Source Project
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *  * Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 *  * Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ``AS IS'' AND ANY
 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */


#ifdef ANDROID_INSTRUMENT

#define LOG_TAG "WebCore"

#include "config.h"
#include "V8Counters.h"

#include "NotImplemented.h"
#include <utils/Log.h>
#include <wtf/text/CString.h>
#include <wtf/text/StringHash.h>

#if USE(V8)

namespace WebCore {

V8Counters::Counter::Counter(bool isHistogram)
    : m_count(0), m_sampleTotal(0), m_isHistogram(isHistogram) { }

void V8Counters::Counter::addSample(int sample)
{
  m_count++;
  m_sampleTotal += sample;
}

HashMap<String, V8Counters::Counter*> V8Counters::m_counters;

// static
int* V8Counters::counterForName(const char* name)
{
    Counter* counter = m_counters.get(name);
    if (!counter) {
        counter = new Counter(false);
        m_counters.add(name, counter);
    }
    return *counter;
}

// static
void* V8Counters::createHistogram(const char* name, int min, int max,
        size_t buckets)
{
    Counter* counter = new Counter(true);
    m_counters.add(name, counter);
    return counter;
}

// static
void V8Counters::addHistogramSample(void* histogram, int sample)
{
    Counter* counter = reinterpret_cast<Counter*>(histogram);
    counter->addSample(sample);
}

// static
void V8Counters::initCounters()
{
    static bool isInitialized = false;
    if (!isInitialized) {
        v8::V8::SetCounterFunction(counterForName);
        v8::V8::SetCreateHistogramFunction(createHistogram);
        v8::V8::SetAddHistogramSampleFunction(addHistogramSample);
        isInitialized = true;
    }
}

// static
void V8Counters::dumpCounters()
{
    LOGD("+----------------------------------------+-------------+\n");
    LOGD("| Name                                   | Value       |\n");
    LOGD("+----------------------------------------+-------------+\n");
    typedef HashMap<String, V8Counters::Counter*>::iterator CounterIterator;
    for (CounterIterator iter = m_counters.begin(); iter != m_counters.end(); ++iter) {
        Counter* counter = iter->second;
        if (counter->isHistogram()) {
            LOGD("| c:%-36s | %11i |\n", iter->first.latin1().data(), counter->count());
            LOGD("| t:%-36s | %11i |\n", iter->first.latin1().data(), counter->sampleTotal());
          } else {
            LOGD("| %-38s | %11i |\n", iter->first.latin1().data(), counter->count());
          }
    }
    LOGD("+----------------------------------------+-------------+\n");
}

}

#endif // ANDROID_INSTRUMENT

#endif // USE(V8)