diff options
author | mbelshe@chromium.org <mbelshe@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-08-25 21:07:12 +0000 |
---|---|---|
committer | mbelshe@chromium.org <mbelshe@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-08-25 21:07:12 +0000 |
commit | 8e7f82c04b00baa250ab70c3871c11640794269b (patch) | |
tree | e76a4311612cedcc50f388c2c14831c13d447fb8 /webkit/extensions/v8/benchmarking_extension.cc | |
parent | 895044f91ab417ddaf19f5e176d744cc76f866bb (diff) | |
download | chromium_src-8e7f82c04b00baa250ab70c3871c11640794269b.zip chromium_src-8e7f82c04b00baa250ab70c3871c11640794269b.tar.gz chromium_src-8e7f82c04b00baa250ab70c3871c11640794269b.tar.bz2 |
Move the chromium.Interval to chrome.Interval as part of the benchmarking
extension. This means that users will need to use --enable-benchmarking
to access it. It really shouldn't be part of the exposed API.
BUG=none
TEST=none
Review URL: http://codereview.chromium.org/3126029
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@57386 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/extensions/v8/benchmarking_extension.cc')
-rw-r--r-- | webkit/extensions/v8/benchmarking_extension.cc | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/webkit/extensions/v8/benchmarking_extension.cc b/webkit/extensions/v8/benchmarking_extension.cc index 31bb080..1a30968 100644 --- a/webkit/extensions/v8/benchmarking_extension.cc +++ b/webkit/extensions/v8/benchmarking_extension.cc @@ -4,6 +4,7 @@ #include "base/command_line.h" #include "base/stats_table.h" +#include "base/time.h" #include "net/http/http_network_layer.h" #include "third_party/WebKit/WebKit/chromium/public/WebCache.h" #include "webkit/extensions/v8/benchmarking_extension.h" @@ -45,6 +46,26 @@ class BenchmarkingWrapper : public v8::Extension { " native function IsSingleProcess();" " return IsSingleProcess();" "};" + "chrome.Interval = function() {" + " var start_ = 0;" + " var stop_ = 0;" + " native function HiResTime();" + " this.start = function() {" + " stop_ = 0;" + " start_ = HiResTime();" + " };" + " this.stop = function() {" + " stop_ = HiResTime();" + " if (start_ == 0)" + " stop_ = 0;" + " };" + " this.microseconds = function() {" + " var stop = stop_;" + " if (stop == 0 && start_ != 0)" + " stop = HiResTime();" + " return Math.ceil(stop - start_);" + " };" + "}" ) {} virtual v8::Handle<v8::FunctionTemplate> GetNativeFunction( @@ -59,7 +80,10 @@ class BenchmarkingWrapper : public v8::Extension { return v8::FunctionTemplate::New(GetCounter); } else if (name->Equals(v8::String::New("IsSingleProcess"))) { return v8::FunctionTemplate::New(IsSingleProcess); + } else if (name->Equals(v8::String::New("HiResTime"))) { + return v8::FunctionTemplate::New(HiResTime); } + return v8::Handle<v8::FunctionTemplate>(); } @@ -99,6 +123,11 @@ class BenchmarkingWrapper : public v8::Extension { static v8::Handle<v8::Value> IsSingleProcess(const v8::Arguments& args) { return v8::Boolean::New(webkit_glue::IsSingleProcess()); } + + static v8::Handle<v8::Value> HiResTime(const v8::Arguments& args) { + return v8::Number::New( + static_cast<double>(base::TimeTicks::HighResNow().ToInternalValue())); + } }; v8::Extension* BenchmarkingExtension::Get() { |