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

Side by Side Diff: third_party/WebKit/Source/platform/graphics/paint/PaintChunk.h

Issue 2116693002: PaintChunk::id (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@CommitOnTheWay
Patch Set: - Created 4 years, 5 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 PaintChunk_h 5 #ifndef PaintChunk_h
6 #define PaintChunk_h 6 #define PaintChunk_h
7 7
8 #include "platform/geometry/FloatRect.h" 8 #include "platform/geometry/FloatRect.h"
9 #include "platform/graphics/paint/DisplayItem.h"
9 #include "platform/graphics/paint/PaintChunkProperties.h" 10 #include "platform/graphics/paint/PaintChunkProperties.h"
10 #include "wtf/Allocator.h" 11 #include "wtf/Allocator.h"
12 #include "wtf/Optional.h"
11 #include <iosfwd> 13 #include <iosfwd>
12 14
13 namespace blink { 15 namespace blink {
14 16
15 // A contiguous sequence of drawings with common paint properties. 17 // A contiguous sequence of drawings with common paint properties.
16 // 18 //
17 // This is expected to be owned by the paint artifact which also owns the 19 // This is expected to be owned by the paint artifact which also owns the
18 // related drawings. 20 // related drawings.
19 // 21 //
20 // This is a Slimming Paint v2 class. 22 // This is a Slimming Paint v2 class.
21 struct PaintChunk { 23 struct PaintChunk {
22 DISALLOW_NEW_EXCEPT_PLACEMENT_NEW(); 24 DISALLOW_NEW_EXCEPT_PLACEMENT_NEW();
23 PaintChunk() : beginIndex(0), endIndex(0), knownToBeOpaque(false) { } 25 PaintChunk() : beginIndex(0), endIndex(0), knownToBeOpaque(false) { }
24 PaintChunk(unsigned begin, unsigned end, const PaintChunkProperties& props) 26 PaintChunk(unsigned begin, unsigned end, const DisplayItem::Id* chunkId, con st PaintChunkProperties& props)
25 : beginIndex(begin), endIndex(end), properties(props), knownToBeOpaque(f alse) { } 27 : beginIndex(begin), endIndex(end), properties(props), knownToBeOpaque(f alse)
28 {
29 if (chunkId)
30 id.emplace(*chunkId);
31 }
26 32
27 unsigned size() const 33 unsigned size() const
28 { 34 {
29 ASSERT(endIndex >= beginIndex); 35 ASSERT(endIndex >= beginIndex);
30 return endIndex - beginIndex; 36 return endIndex - beginIndex;
31 } 37 }
32 38
39 // Check if a new PaintChunk (this) created in the latest paint matches an o ld
40 // PaintChunk created in the previous paint.
41 bool idMatches(const PaintChunk& old) const
pdr. 2016/07/15 19:11:28 WDYT about renaming this "bool matches(const Paint
Xianzhu 2016/07/15 23:48:00 Agreed. Done.
42 {
43 // A PaintChunk without an id doesn't match any other PaintChunks.
44 if (!id || !old.id)
45 return false;
46 if (*id != *old.id)
47 return false;
48 #if CHECK_DISPLAY_ITEM_CLIENT_ALIVENESS
49 CHECK(id->client.isAlive());
50 #endif
51 // A chunk whose client is just created should not match any cached chun k,
52 // even if it's id equals the old chunk's id (which may happen if this c hunk's
53 // client is just created at the same address of the old chunk's deleted client).
54 return !id->client.isJustCreated();
55 }
56
33 // Index of the first drawing in this chunk. 57 // Index of the first drawing in this chunk.
34 unsigned beginIndex; 58 unsigned beginIndex;
35 59
36 // Index of the first drawing not in this chunk, so that there are 60 // Index of the first drawing not in this chunk, so that there are
37 // |endIndex - beginIndex| drawings in the chunk. 61 // |endIndex - beginIndex| drawings in the chunk.
38 unsigned endIndex; 62 unsigned endIndex;
39 63
64 // Identifier of this chunk. If it has a value, it should be unique.
65 // It's used to match a new chunk to a cached old chunk to track changes of chunk
66 // contents, so the id should be stable across document cycles.
67 // If the contents of the chunk can't be cached (e.g. it's created when Pain tController
68 // is skipping cache, normally because display items can't be uniquely ident ified),
69 // id is nullopt so that the chunk won't match any other chunk.
70 Optional<DisplayItem::Id> id;
pdr. 2016/07/15 19:11:28 WDYT of adding "using Id = DisplayItem::Id;" here
Xianzhu 2016/07/15 23:48:00 Agreed. Done.
71
40 // The paint properties which apply to this chunk. 72 // The paint properties which apply to this chunk.
41 PaintChunkProperties properties; 73 PaintChunkProperties properties;
42 74
43 // The total bounds of this paint chunk's contents. 75 // The total bounds of this paint chunk's contents.
44 FloatRect bounds; 76 FloatRect bounds;
45 77
46 // True if the bounds are filled entirely with opaque contents. 78 // True if the bounds are filled entirely with opaque contents.
47 bool knownToBeOpaque; 79 bool knownToBeOpaque;
48 }; 80 };
49 81
50 inline bool operator==(const PaintChunk& a, const PaintChunk& b) 82 inline bool operator==(const PaintChunk& a, const PaintChunk& b)
51 { 83 {
52 return a.beginIndex == b.beginIndex 84 return a.beginIndex == b.beginIndex
53 && a.endIndex == b.endIndex 85 && a.endIndex == b.endIndex
86 && a.id == b.id
54 && a.properties == b.properties 87 && a.properties == b.properties
55 && a.bounds == b.bounds 88 && a.bounds == b.bounds
56 && a.knownToBeOpaque == b.knownToBeOpaque; 89 && a.knownToBeOpaque == b.knownToBeOpaque;
57 } 90 }
58 91
59 inline bool operator!=(const PaintChunk& a, const PaintChunk& b) 92 inline bool operator!=(const PaintChunk& a, const PaintChunk& b)
60 { 93 {
61 return !(a == b); 94 return !(a == b);
62 } 95 }
63 96
64 // Redeclared here to avoid ODR issues. 97 // Redeclared here to avoid ODR issues.
65 // See platform/testing/PaintPrinters.h. 98 // See platform/testing/PaintPrinters.h.
66 void PrintTo(const PaintChunk&, std::ostream*); 99 void PrintTo(const PaintChunk&, std::ostream*);
67 100
68 } // namespace blink 101 } // namespace blink
69 102
70 #endif // PaintChunk_h 103 #endif // PaintChunk_h
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698