OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2012 Apple Inc. All rights reserved. | 2 * Copyright (C) 2012 Apple Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
6 * are met: | 6 * are met: |
7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
(...skipping 18 matching lines...) Expand all Loading... |
29 #include "platform/heap/Handle.h" | 29 #include "platform/heap/Handle.h" |
30 #include "wtf/HashSet.h" | 30 #include "wtf/HashSet.h" |
31 #include "wtf/Vector.h" | 31 #include "wtf/Vector.h" |
32 #include "wtf/text/StringImpl.h" | 32 #include "wtf/text/StringImpl.h" |
33 | 33 |
34 namespace blink { | 34 namespace blink { |
35 | 35 |
36 class Document; | 36 class Document; |
37 class Node; | 37 class Node; |
38 class StyleSheetContents; | 38 class StyleSheetContents; |
| 39 class TreeScope; |
39 | 40 |
40 class StyleSheetInvalidationAnalysis { | 41 class StyleSheetInvalidationAnalysis { |
41 STACK_ALLOCATED(); | 42 STACK_ALLOCATED(); |
42 public: | 43 public: |
43 StyleSheetInvalidationAnalysis(const WillBeHeapVector<RawPtrWillBeMember<Sty
leSheetContents>>&); | 44 StyleSheetInvalidationAnalysis(const TreeScope&, const WillBeHeapVector<RawP
trWillBeMember<StyleSheetContents>>&); |
44 | 45 |
45 bool dirtiesAllStyle() const { return m_dirtiesAllStyle; } | 46 bool dirtiesAllStyle() const { return m_dirtiesAllStyle; } |
46 void invalidateStyle(Document&); | 47 void invalidateStyle(); |
47 | 48 |
48 private: | 49 private: |
49 | 50 |
50 void analyzeStyleSheet(StyleSheetContents*); | 51 void analyzeStyleSheet(StyleSheetContents*); |
51 | 52 |
52 bool m_dirtiesAllStyle; | 53 const TreeScope& m_treeScope; |
53 HashSet<StringImpl*> m_idScopes; | 54 HashSet<StringImpl*> m_idScopes; |
54 HashSet<StringImpl*> m_classScopes; | 55 HashSet<StringImpl*> m_classScopes; |
55 WillBeHeapVector<RawPtrWillBeMember<Node>, 8> m_scopingNodes; | 56 |
| 57 bool m_dirtiesAllStyle = false; |
| 58 bool m_hasDistributedRules = false; |
56 }; | 59 }; |
57 | 60 |
58 } | 61 } |
59 | 62 |
60 #endif | 63 #endif |
OLD | NEW |