| OLD | NEW | 
|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 CC_DEBUG_DEVTOOLS_INSTRUMENTATION_H_ | 5 #ifndef CC_DEBUG_DEVTOOLS_INSTRUMENTATION_H_ | 
| 6 #define CC_DEBUG_DEVTOOLS_INSTRUMENTATION_H_ | 6 #define CC_DEBUG_DEVTOOLS_INSTRUMENTATION_H_ | 
| 7 | 7 | 
| 8 #include "base/debug/trace_event.h" | 8 #include "base/debug/trace_event.h" | 
| 9 | 9 | 
| 10 namespace cc { | 10 namespace cc { | 
| 11 namespace devtools_instrumentation { | 11 namespace devtools_instrumentation { | 
| 12 | 12 | 
| 13 namespace internal { | 13 namespace internal { | 
| 14 const char kCategory[] = "cc,devtools"; | 14 const char kCategory[] = "cc,devtools"; | 
| 15 const char kLayerId[] = "layerId"; | 15 const char kLayerId[] = "layerId"; | 
|  | 16 const char kLayerTreeId[] = "layerTreeId"; | 
| 16 } | 17 } | 
| 17 | 18 | 
| 18 const char kPaintLayer[] = "PaintLayer"; | 19 const char kPaintLayer[] = "PaintLayer"; | 
| 19 const char kRasterTask[] = "RasterTask"; | 20 const char kRasterTask[] = "RasterTask"; | 
| 20 const char kImageDecodeTask[] = "ImageDecodeTask"; | 21 const char kImageDecodeTask[] = "ImageDecodeTask"; | 
| 21 const char kPaintSetup[] = "PaintSetup"; | 22 const char kPaintSetup[] = "PaintSetup"; | 
|  | 23 const char kUpdateLayer[] = "UpdateLayer"; | 
| 22 | 24 | 
| 23 class ScopedLayerTask { | 25 class ScopedLayerTask { | 
| 24  public: | 26  public: | 
| 25   explicit ScopedLayerTask(const char* event_name, int layer_id) | 27   ScopedLayerTask(const char* event_name, int layer_id) | 
| 26     : event_name_(event_name) { | 28     : event_name_(event_name) { | 
| 27     TRACE_EVENT_BEGIN1(internal::kCategory, event_name_, | 29     TRACE_EVENT_BEGIN1(internal::kCategory, event_name_, | 
| 28         internal::kLayerId, layer_id); | 30         internal::kLayerId, layer_id); | 
| 29   } | 31   } | 
| 30   ~ScopedLayerTask() { | 32   ~ScopedLayerTask() { | 
| 31     TRACE_EVENT_END0(internal::kCategory, event_name_); | 33     TRACE_EVENT_END0(internal::kCategory, event_name_); | 
| 32   } | 34   } | 
| 33  private: | 35  private: | 
| 34   const char* event_name_; | 36   const char* event_name_; | 
|  | 37 | 
|  | 38   DISALLOW_COPY_AND_ASSIGN(ScopedLayerTask); | 
|  | 39 }; | 
|  | 40 | 
|  | 41 class ScopedLayerTreeTask { | 
|  | 42  public: | 
|  | 43   ScopedLayerTreeTask(const char* event_name, | 
|  | 44                       int layer_id, | 
|  | 45                       uint64 tree_id) | 
|  | 46     : event_name_(event_name) { | 
|  | 47     TRACE_EVENT_BEGIN2(internal::kCategory, event_name_, | 
|  | 48         internal::kLayerId, layer_id, internal::kLayerTreeId, tree_id); | 
|  | 49   } | 
|  | 50   ~ScopedLayerTreeTask() { | 
|  | 51     TRACE_EVENT_END0(internal::kCategory, event_name_); | 
|  | 52   } | 
|  | 53  private: | 
|  | 54   const char* event_name_; | 
|  | 55 | 
|  | 56   DISALLOW_COPY_AND_ASSIGN(ScopedLayerTreeTask); | 
| 35 }; | 57 }; | 
| 36 | 58 | 
| 37 struct ScopedLayerObjectTracker | 59 struct ScopedLayerObjectTracker | 
| 38     : public base::debug::TraceScopedTrackableObject<int> { | 60     : public base::debug::TraceScopedTrackableObject<int> { | 
| 39   explicit ScopedLayerObjectTracker(int layer_id) | 61   explicit ScopedLayerObjectTracker(int layer_id) | 
| 40       : base::debug::TraceScopedTrackableObject<int>( | 62       : base::debug::TraceScopedTrackableObject<int>( | 
| 41             internal::kCategory, | 63             internal::kCategory, | 
| 42             internal::kLayerId, | 64             internal::kLayerId, | 
| 43             layer_id) { | 65             layer_id) { | 
| 44   } | 66   } | 
| 45 | 67 | 
|  | 68  private: | 
| 46   DISALLOW_COPY_AND_ASSIGN(ScopedLayerObjectTracker); | 69   DISALLOW_COPY_AND_ASSIGN(ScopedLayerObjectTracker); | 
| 47 }; | 70 }; | 
| 48 | 71 | 
| 49 }  // namespace devtools_instrumentation | 72 }  // namespace devtools_instrumentation | 
| 50 }  // namespace cc | 73 }  // namespace cc | 
| 51 | 74 | 
| 52 #endif  // CC_DEBUG_DEVTOOLS_INSTRUMENTATION_H_ | 75 #endif  // CC_DEBUG_DEVTOOLS_INSTRUMENTATION_H_ | 
| OLD | NEW | 
|---|