summaryrefslogtreecommitdiffstats
path: root/webkit/extensions
diff options
context:
space:
mode:
Diffstat (limited to 'webkit/extensions')
-rw-r--r--webkit/extensions/v8/benchmarking_extension.cc36
1 files changed, 29 insertions, 7 deletions
diff --git a/webkit/extensions/v8/benchmarking_extension.cc b/webkit/extensions/v8/benchmarking_extension.cc
index e2e926d..501d483 100644
--- a/webkit/extensions/v8/benchmarking_extension.cc
+++ b/webkit/extensions/v8/benchmarking_extension.cc
@@ -4,6 +4,7 @@
#include "config.h"
#include "Cache.h"
+#include "base/stats_table.h"
#include "webkit/extensions/v8/benchmarking_extension.h"
#include "webkit/glue/webkit_glue.h"
@@ -15,20 +16,25 @@ class BenchmarkingWrapper : public v8::Extension {
public:
BenchmarkingWrapper() :
v8::Extension(kBenchmarkingExtensionName,
- "if (typeof(chromium) == 'undefined') {"
- " chromium = {};"
+ "if (typeof(chrome) == 'undefined') {"
+ " chrome = {};"
"};"
- "if (typeof(chromium.benchmarking) == 'undefined') {"
- " chromium.benchmarking = {};"
+ "if (typeof(chrome.benchmarking) == 'undefined') {"
+ " chrome.benchmarking = {};"
"};"
- "chromium.benchmarking.clearCache = function() {"
+ "chrome.benchmarking.clearCache = function() {"
" native function ClearCache();"
" ClearCache();"
"};"
- "chromium.benchmarking.closeConnections = function() {"
+ "chrome.benchmarking.closeConnections = function() {"
" native function CloseConnections();"
" CloseConnections();"
- "};") {}
+ "};"
+ "chrome.benchmarking.counter = function(name) {"
+ " native function GetCounter();"
+ " return GetCounter(name);"
+ "};"
+ ) {}
virtual v8::Handle<v8::FunctionTemplate> GetNativeFunction(
v8::Handle<v8::String> name) {
@@ -36,6 +42,8 @@ class BenchmarkingWrapper : public v8::Extension {
return v8::FunctionTemplate::New(CloseConnections);
} else if (name->Equals(v8::String::New("ClearCache"))) {
return v8::FunctionTemplate::New(ClearCache);
+ } else if (name->Equals(v8::String::New("GetCounter"))) {
+ return v8::FunctionTemplate::New(GetCounter);
}
return v8::Handle<v8::FunctionTemplate>();
}
@@ -54,6 +62,20 @@ class BenchmarkingWrapper : public v8::Extension {
WebCore::cache()->setDisabled(false);
return v8::Undefined();
}
+
+ static v8::Handle<v8::Value> GetCounter(const v8::Arguments& args) {
+ if (!args.Length() || !args[0]->IsString())
+ return v8::Undefined();
+
+ // Extract the name argument
+ char name[256];
+ name[0] = 'c';
+ name[1] = ':';
+ args[0]->ToString()->WriteAscii(&name[2], 0, sizeof(name) - 3);
+
+ int counter = StatsTable::current()->GetCounterValue(name);
+ return v8::Integer::New(counter);
+ }
};
v8::Extension* BenchmarkingExtension::Get() {