Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(13)

Side by Side Diff: content/browser/process_resource_usage_impl.cc

Issue 972083002: Report utility process JS memory in task manager. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@v8-pac-oop
Patch Set: Redesign. Created 5 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "content/browser/process_resource_usage_impl.h"
6
7 #include "base/bind.h"
8 #include "base/logging.h"
9
10 namespace content {
11
12 // static
13 scoped_ptr<ProcessResourceUsage> ProcessResourceUsage::Create(
14 ResourceUsageReporterPtr service) {
15 return make_scoped_ptr(new ProcessResourceUsageImpl(service.Pass()));
16 }
17
18 ProcessResourceUsageImpl::ProcessResourceUsageImpl(
19 ResourceUsageReporterPtr service)
20 : service_(service.Pass()),
21 update_in_progress_(false) {
22 }
23
24 ProcessResourceUsageImpl::~ProcessResourceUsageImpl() {
25 DCHECK(thread_checker_.CalledOnValidThread());
26 }
27
28 void ProcessResourceUsageImpl::Refresh() {
29 DCHECK(thread_checker_.CalledOnValidThread());
30 if (!update_in_progress_ && service_) {
31 update_in_progress_ = true;
32 service_->GetUsageData(
33 base::Bind(&ProcessResourceUsageImpl::OnRefreshDone,
34 base::Unretained(this)));
35 }
36 }
37
38 void ProcessResourceUsageImpl::OnRefreshDone(ResourceUsageDataPtr data) {
39 DCHECK(thread_checker_.CalledOnValidThread());
40 update_in_progress_ = false;
41 stats_ = data.Pass();
42 }
43
44 bool ProcessResourceUsageImpl::ReportsV8MemoryStats() const {
45 DCHECK(thread_checker_.CalledOnValidThread());
46 if (stats_)
47 return stats_->reports_v8_stats;
48 return false;
49 }
50
51 size_t ProcessResourceUsageImpl::GetV8MemoryAllocated() const {
52 DCHECK(thread_checker_.CalledOnValidThread());
53 if (stats_ && stats_->reports_v8_stats)
54 return stats_->v8_memory_allocated;
55 return 0;
56 }
57
58 size_t ProcessResourceUsageImpl::GetV8MemoryUsed() const {
59 DCHECK(thread_checker_.CalledOnValidThread());
60 if (stats_ && stats_->reports_v8_stats)
61 return stats_->v8_memory_used;
62 return 0;
63 }
64
65 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698