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

Side by Side Diff: include/private/GrAuditTrail.h

Issue 1579193002: Convert GrAuditTrail to use scoped frames (Closed) Base URL: https://skia.googlesource.com/skia.git@audittrail-2-wireupbatchnames-andbounds
Patch Set: typo Created 4 years, 11 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
« no previous file with comments | « no previous file | src/gpu/GrAuditTrail.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright 2016 Google Inc. 2 * Copyright 2016 Google Inc.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license that can be 4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file. 5 * found in the LICENSE file.
6 */ 6 */
7 7
8 #ifndef GrAuditTrail_DEFINED 8 #ifndef GrAuditTrail_DEFINED
9 #define GrAuditTrail_DEFINED 9 #define GrAuditTrail_DEFINED
10 10
11 #include "GrConfig.h" 11 #include "GrConfig.h"
12 #include "SkRect.h" 12 #include "SkRect.h"
13 #include "SkString.h" 13 #include "SkString.h"
14 #include "SkTArray.h" 14 #include "SkTArray.h"
15 15
16 /* 16 /*
17 * GrAuditTrail collects a list of draw ops, detailed information about those op s, and can dump them 17 * GrAuditTrail collects a list of draw ops, detailed information about those op s, and can dump them
18 * to json. 18 * to json.
19 */ 19 */
20 class GrAuditTrail { 20 class GrAuditTrail {
21 public: 21 public:
22 void addOp(const SkString& name) { 22 GrAuditTrail() : fUniqueID(0) {}
23
24 class AutoFrame {
25 public:
26 AutoFrame(GrAuditTrail* auditTrail, const char* name)
27 : fAuditTrail(auditTrail) {
28 if (GR_BATCH_DEBUGGING_OUTPUT) {
29 fAuditTrail->pushFrame(name);
30 }
31 }
32
33 ~AutoFrame() {
34 if (GR_BATCH_DEBUGGING_OUTPUT) {
35 fAuditTrail->popFrame();
36 }
37 }
38
39 private:
40 GrAuditTrail* fAuditTrail;
41 };
42
43 void pushFrame(const char* name) {
23 SkASSERT(GR_BATCH_DEBUGGING_OUTPUT); 44 SkASSERT(GR_BATCH_DEBUGGING_OUTPUT);
24 fOps.push_back().fName = name; 45 Frame* frame;
46 if (fStack.empty()) {
47 frame = &fFrames.push_back();
48 } else {
49 frame = &fStack.back()->fChildren.push_back();
50 }
51
52 frame->fUniqueID = fUniqueID++;
53 frame->fName = name;
54 fStack.push_back(frame);
25 } 55 }
26 56
27 void addBatch(const SkString& name, const SkRect& bounds) { 57 void popFrame() {
28 SkASSERT(GR_BATCH_DEBUGGING_OUTPUT); 58 SkASSERT(GR_BATCH_DEBUGGING_OUTPUT);
29 Op::Batch& batch = fOps.back().fBatches.push_back(); 59 fStack.pop_back();
60 }
61
62 void addBatch(const char* name, const SkRect& bounds) {
63 // TODO when every internal callsite pushes a frame, we can add the asse rt
64 SkASSERT(GR_BATCH_DEBUGGING_OUTPUT /*&& !fStack.empty()*/);
65 Frame::Batch& batch = fStack.back()->fBatches.push_back();
30 batch.fName = name; 66 batch.fName = name;
31 batch.fBounds = bounds; 67 batch.fBounds = bounds;
32 } 68 }
33 69
34 SkString toJson() const; 70 SkString toJson() const;
35 71
36 void reset() { SkASSERT(GR_BATCH_DEBUGGING_OUTPUT); fOps.reset(); } 72 void reset() { SkASSERT(GR_BATCH_DEBUGGING_OUTPUT && fStack.empty()); fFrame s.reset(); }
37 73
38 private: 74 private:
39 struct Op { 75 struct Frame {
40 SkString toJson() const; 76 SkString toJson() const;
41 struct Batch { 77 struct Batch {
42 SkString toJson() const; 78 SkString toJson() const;
43 SkString fName; 79 const char* fName;
44 SkRect fBounds; 80 SkRect fBounds;
45 }; 81 };
46 82
47 SkString fName; 83 const char* fName;
84 // TODO combine these into a single array
bsalomon 2016/01/12 19:51:13 Is this in order to preserve the sequence?
48 SkTArray<Batch> fBatches; 85 SkTArray<Batch> fBatches;
86 SkTArray<Frame> fChildren;
87 uint64_t fUniqueID;
49 }; 88 };
50 89
51 SkTArray<Op> fOps; 90 SkTArray<Frame> fFrames;
91 SkTArray<Frame*> fStack;
92 uint64_t fUniqueID;
52 }; 93 };
53 94
54 #define GR_AUDIT_TRAIL_INVOKE_GUARD(invoke, ...) \ 95 #define GR_AUDIT_TRAIL_INVOKE_GUARD(invoke, ...) \
55 if (GR_BATCH_DEBUGGING_OUTPUT) { \ 96 if (GR_BATCH_DEBUGGING_OUTPUT) { \
56 invoke(__VA_ARGS__); \ 97 invoke(__VA_ARGS__); \
57 } 98 }
58 99
59 #define GR_AUDIT_TRAIL_ADDOP(audit_trail, opname) \ 100 #define GR_AUDIT_TRAIL_AUTO_FRAME(audit_trail, framename) \
60 GR_AUDIT_TRAIL_INVOKE_GUARD(audit_trail->addOp, opname); 101 GrAuditTrail::AutoFrame SK_MACRO_APPEND_LINE(auto_frame)(audit_trail, framen ame);
61 102
62 #define GR_AUDIT_TRAIL_RESET(audit_trail) \ 103 #define GR_AUDIT_TRAIL_RESET(audit_trail) \
63 GR_AUDIT_TRAIL_INVOKE_GUARD(audit_trail->reset); 104 GR_AUDIT_TRAIL_INVOKE_GUARD(audit_trail->reset);
64 105
65 #define GR_AUDIT_TRAIL_ADDBATCH(audit_trail, batchname, bounds) \ 106 #define GR_AUDIT_TRAIL_ADDBATCH(audit_trail, batchname, bounds) \
66 GR_AUDIT_TRAIL_INVOKE_GUARD(audit_trail->addBatch, SkString(batchname), boun ds); 107 GR_AUDIT_TRAIL_INVOKE_GUARD(audit_trail->addBatch, batchname, bounds);
67 108
68 #endif 109 #endif
OLDNEW
« no previous file with comments | « no previous file | src/gpu/GrAuditTrail.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698