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

Side by Side Diff: base/trace_event/memory_dump_provider.h

Issue 1262333005: [tracing] Introduce MemoryDumpArgs to enable light and heavy dumps (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Win and android fix. Created 5 years, 4 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
1 // Copyright 2015 The Chromium Authors. All rights reserved. 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 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef BASE_TRACE_EVENT_MEMORY_DUMP_PROVIDER_H_ 5 #ifndef BASE_TRACE_EVENT_MEMORY_DUMP_PROVIDER_H_
6 #define BASE_TRACE_EVENT_MEMORY_DUMP_PROVIDER_H_ 6 #define BASE_TRACE_EVENT_MEMORY_DUMP_PROVIDER_H_
7 7
8 #include "base/base_export.h" 8 #include "base/base_export.h"
9 #include "base/macros.h" 9 #include "base/macros.h"
10 10
11 namespace base { 11 namespace base {
12 namespace trace_event { 12 namespace trace_event {
13 13
14 class ProcessMemoryDump; 14 class ProcessMemoryDump;
15 15
16 struct MemoryDumpArgs {
petrcermak 2015/07/31 13:23:01 Could you please explain the relationship between
ssid 2015/07/31 15:14:33 Hm, the MemoryDumpRequestArgs is used to request a
petrcermak 2015/08/03 10:12:35 OK, this makes sense. Thanks for the explanation.
17 enum LevelOfDetail { LEVEL_OF_DETAIL_LOW, LEVEL_OF_DETAIL_HIGH };
18
19 explicit MemoryDumpArgs(const LevelOfDetail level) : level_of_detail(level) {}
20
21 LevelOfDetail level_of_detail;
petrcermak 2015/07/31 13:23:01 const?
ssid 2015/07/31 15:14:33 Done.
22 };
23
16 // The contract interface that memory dump providers must implement. 24 // The contract interface that memory dump providers must implement.
17 class BASE_EXPORT MemoryDumpProvider { 25 class BASE_EXPORT MemoryDumpProvider {
18 public: 26 public:
19 // Called by the MemoryDumpManager when generating memory dumps. 27 // Called by the MemoryDumpManager when generating memory dumps.
20 // The embedder should return true if the |pmd| was successfully populated, 28 // The embedder should return true if the |pmd| was successfully populated,
21 // false if something went wrong and the dump should be considered invalid. 29 // false if something went wrong and the dump should be considered invalid.
22 // (Note, the MemoryDumpManager has a fail-safe logic which will disable the 30 // (Note, the MemoryDumpManager has a fail-safe logic which will disable the
23 // MemoryDumpProvider for the entire trace session if it fails consistently). 31 // MemoryDumpProvider for the entire trace session if it fails consistently).
24 virtual bool OnMemoryDump(ProcessMemoryDump* pmd) = 0; 32 virtual bool OnMemoryDump(const MemoryDumpArgs& args,
33 ProcessMemoryDump* pmd) = 0;
25 34
26 protected: 35 protected:
27 MemoryDumpProvider() {} 36 MemoryDumpProvider() {}
28 virtual ~MemoryDumpProvider() {} 37 virtual ~MemoryDumpProvider() {}
29 38
30 DISALLOW_COPY_AND_ASSIGN(MemoryDumpProvider); 39 DISALLOW_COPY_AND_ASSIGN(MemoryDumpProvider);
31 }; 40 };
32 41
33 } // namespace trace_event 42 } // namespace trace_event
34 } // namespace base 43 } // namespace base
35 44
36 #endif // BASE_TRACE_EVENT_MEMORY_DUMP_PROVIDER_H_ 45 #endif // BASE_TRACE_EVENT_MEMORY_DUMP_PROVIDER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698