a24d924b49a900b1c28b35ce7e936d441fc27910
[WebKit-https.git] / Source / WebCore / css / StyleRule.h
1 /*
2  * (C) 1999-2003 Lars Knoll (knoll@kde.org)
3  * (C) 2002-2003 Dirk Mueller (mueller@kde.org)
4  * Copyright (C) 2002, 2006, 2008, 2012, 2013 Apple Inc. All rights reserved.
5  *
6  * This library is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Library General Public
8  * License as published by the Free Software Foundation; either
9  * version 2 of the License, or (at your option) any later version.
10  *
11  * This library is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  * Library General Public License for more details.
15  *
16  * You should have received a copy of the GNU Library General Public License
17  * along with this library; see the file COPYING.LIB.  If not, write to
18  * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
19  * Boston, MA 02110-1301, USA.
20  */
21
22 #ifndef StyleRule_h
23 #define StyleRule_h
24
25 #include "CSSSelectorList.h"
26 #include "MediaList.h"
27 #include "StyleProperties.h"
28 #include <wtf/RefPtr.h>
29
30 namespace WebCore {
31
32 class CSSRule;
33 class CSSStyleRule;
34 class CSSStyleSheet;
35 class MutableStyleProperties;
36 class StyleProperties;
37
38 class StyleRuleBase : public WTF::RefCountedBase {
39     WTF_MAKE_FAST_ALLOCATED;
40 public:
41     enum Type {
42         Unknown, // Not used.
43         Style,
44         Charset, // Not used. These are internally strings owned by the style sheet.
45         Import,
46         Media,
47         FontFace,
48         Page,
49         Keyframes,
50         Keyframe, // Not used. These are internally non-rule StyleKeyframe objects.
51         Supports = 12,
52 #if ENABLE(CSS_DEVICE_ADAPTATION)
53         Viewport = 15,
54 #endif
55         Region = 16,
56     };
57
58     Type type() const { return static_cast<Type>(m_type); }
59     
60     bool isCharsetRule() const { return type() == Charset; }
61     bool isFontFaceRule() const { return type() == FontFace; }
62     bool isKeyframesRule() const { return type() == Keyframes; }
63     bool isMediaRule() const { return type() == Media; }
64     bool isPageRule() const { return type() == Page; }
65     bool isStyleRule() const { return type() == Style; }
66     bool isRegionRule() const { return type() == Region; }
67     bool isSupportsRule() const { return type() == Supports; }
68 #if ENABLE(CSS_DEVICE_ADAPTATION)
69     bool isViewportRule() const { return type() == Viewport; }
70 #endif
71     bool isImportRule() const { return type() == Import; }
72
73     PassRef<StyleRuleBase> copy() const;
74
75     int sourceLine() const { return m_sourceLine; }
76
77     void deref()
78     {
79         if (derefBase())
80             destroy();
81     }
82
83     // FIXME: There shouldn't be any need for the null parent version.
84     PassRefPtr<CSSRule> createCSSOMWrapper(CSSStyleSheet* parentSheet = 0) const;
85     PassRefPtr<CSSRule> createCSSOMWrapper(CSSRule* parentRule) const;
86
87 protected:
88     StyleRuleBase(Type type, signed sourceLine = 0) : m_type(type), m_sourceLine(sourceLine) { }
89     StyleRuleBase(const StyleRuleBase& o) : WTF::RefCountedBase(), m_type(o.m_type), m_sourceLine(o.m_sourceLine) { }
90
91     ~StyleRuleBase() { }
92
93 private:
94     void destroy();
95     
96     PassRefPtr<CSSRule> createCSSOMWrapper(CSSStyleSheet* parentSheet, CSSRule* parentRule) const;
97
98     unsigned m_type : 5;
99     signed m_sourceLine : 27;
100 };
101
102 class StyleRule : public StyleRuleBase {
103     WTF_MAKE_FAST_ALLOCATED;
104 public:
105     static PassRef<StyleRule> create(int sourceLine, PassRef<StyleProperties> properties)
106     {
107         return adoptRef(*new StyleRule(sourceLine, WTF::move(properties)));
108     }
109     
110     ~StyleRule();
111
112     const CSSSelectorList& selectorList() const { return m_selectorList; }
113     const StyleProperties& properties() const { return m_properties; }
114     MutableStyleProperties& mutableProperties();
115     
116     void parserAdoptSelectorVector(Vector<std::unique_ptr<CSSParserSelector>>& selectors) { m_selectorList.adoptSelectorVector(selectors); }
117     void wrapperAdoptSelectorList(CSSSelectorList& selectors) { m_selectorList = WTF::move(selectors); }
118     void parserAdoptSelectorArray(CSSSelector* selectors) { m_selectorList.adoptSelectorArray(selectors); }
119
120     PassRef<StyleRule> copy() const { return adoptRef(*new StyleRule(*this)); }
121
122     Vector<RefPtr<StyleRule>> splitIntoMultipleRulesWithMaximumSelectorComponentCount(unsigned) const;
123
124     static unsigned averageSizeInBytes();
125
126 private:
127     StyleRule(int sourceLine, PassRef<StyleProperties>);
128     StyleRule(const StyleRule&);
129
130     static PassRef<StyleRule> create(int sourceLine, const Vector<const CSSSelector*>&, PassRef<StyleProperties>);
131
132     Ref<StyleProperties> m_properties;
133     CSSSelectorList m_selectorList;
134 };
135
136 inline const StyleRule* toStyleRule(const StyleRuleBase* rule)
137 {
138     ASSERT_WITH_SECURITY_IMPLICATION(!rule || rule->isStyleRule());
139     return static_cast<const StyleRule*>(rule);
140 }
141
142 class StyleRuleFontFace : public StyleRuleBase {
143 public:
144     static PassRef<StyleRuleFontFace> create(PassRef<StyleProperties> properties) { return adoptRef(*new StyleRuleFontFace(WTF::move(properties))); }
145     
146     ~StyleRuleFontFace();
147
148     const StyleProperties& properties() const { return m_properties; }
149     MutableStyleProperties& mutableProperties();
150
151     PassRef<StyleRuleFontFace> copy() const { return adoptRef(*new StyleRuleFontFace(*this)); }
152
153
154 private:
155     StyleRuleFontFace(PassRef<StyleProperties>);
156     StyleRuleFontFace(const StyleRuleFontFace&);
157
158     Ref<StyleProperties> m_properties;
159 };
160
161 class StyleRulePage : public StyleRuleBase {
162 public:
163     static PassRef<StyleRulePage> create(PassRef<StyleProperties> properties) { return adoptRef(*new StyleRulePage(WTF::move(properties))); }
164
165     ~StyleRulePage();
166
167     const CSSSelector* selector() const { return m_selectorList.first(); }    
168     const StyleProperties& properties() const { return m_properties; }
169     MutableStyleProperties& mutableProperties();
170
171     void parserAdoptSelectorVector(Vector<std::unique_ptr<CSSParserSelector>>& selectors) { m_selectorList.adoptSelectorVector(selectors); }
172     void wrapperAdoptSelectorList(CSSSelectorList& selectors) { m_selectorList = WTF::move(selectors); }
173
174     PassRef<StyleRulePage> copy() const { return adoptRef(*new StyleRulePage(*this)); }
175
176 private:
177     StyleRulePage(PassRef<StyleProperties>);
178     StyleRulePage(const StyleRulePage&);
179     
180     Ref<StyleProperties> m_properties;
181     CSSSelectorList m_selectorList;
182 };
183
184 class StyleRuleGroup : public StyleRuleBase {
185 public:
186     const Vector<RefPtr<StyleRuleBase>>& childRules() const { return m_childRules; }
187     
188     void wrapperInsertRule(unsigned, PassRef<StyleRuleBase>);
189     void wrapperRemoveRule(unsigned);
190     
191 protected:
192     StyleRuleGroup(Type, Vector<RefPtr<StyleRuleBase>>& adoptRule);
193     StyleRuleGroup(const StyleRuleGroup&);
194     
195 private:
196     Vector<RefPtr<StyleRuleBase>> m_childRules;
197 };
198
199 class StyleRuleMedia : public StyleRuleGroup {
200 public:
201     static PassRef<StyleRuleMedia> create(PassRefPtr<MediaQuerySet> media, Vector<RefPtr<StyleRuleBase>>& adoptRules)
202     {
203         return adoptRef(*new StyleRuleMedia(media, adoptRules));
204     }
205
206     MediaQuerySet* mediaQueries() const { return m_mediaQueries.get(); }
207
208     PassRef<StyleRuleMedia> copy() const { return adoptRef(*new StyleRuleMedia(*this)); }
209
210 private:
211     StyleRuleMedia(PassRefPtr<MediaQuerySet>, Vector<RefPtr<StyleRuleBase>>& adoptRules);
212     StyleRuleMedia(const StyleRuleMedia&);
213
214     RefPtr<MediaQuerySet> m_mediaQueries;
215 };
216
217 class StyleRuleSupports : public StyleRuleGroup {
218 public:
219     static PassRef<StyleRuleSupports> create(const String& conditionText, bool conditionIsSupported, Vector<RefPtr<StyleRuleBase>>& adoptRules)
220     {
221         return adoptRef(*new StyleRuleSupports(conditionText, conditionIsSupported, adoptRules));
222     }
223
224     String conditionText() const { return m_conditionText; }
225     bool conditionIsSupported() const { return m_conditionIsSupported; }
226     PassRef<StyleRuleSupports> copy() const { return adoptRef(*new StyleRuleSupports(*this)); }
227
228 private:
229     StyleRuleSupports(const String& conditionText, bool conditionIsSupported, Vector<RefPtr<StyleRuleBase>>& adoptRules);
230     StyleRuleSupports(const StyleRuleSupports&);
231
232     String m_conditionText;
233     bool m_conditionIsSupported;
234 };
235
236 class StyleRuleRegion : public StyleRuleGroup {
237 public:
238     static PassRef<StyleRuleRegion> create(Vector<std::unique_ptr<CSSParserSelector>>* selectors, Vector<RefPtr<StyleRuleBase>>& adoptRules)
239     {
240         return adoptRef(*new StyleRuleRegion(selectors, adoptRules));
241     }
242
243     const CSSSelectorList& selectorList() const { return m_selectorList; }
244
245     PassRef<StyleRuleRegion> copy() const { return adoptRef(*new StyleRuleRegion(*this)); }
246
247 private:
248     StyleRuleRegion(Vector<std::unique_ptr<CSSParserSelector>>*, Vector<RefPtr<StyleRuleBase>>& adoptRules);
249     StyleRuleRegion(const StyleRuleRegion&);
250     
251     CSSSelectorList m_selectorList;
252 };
253
254 #if ENABLE(CSS_DEVICE_ADAPTATION)
255 class StyleRuleViewport : public StyleRuleBase {
256 public:
257     static PassRef<StyleRuleViewport> create(PassRef<StyleProperties> properties) { return adoptRef(*new StyleRuleViewport(WTF::move(properties))); }
258
259     ~StyleRuleViewport();
260
261     const StyleProperties& properties() const { return m_properties.get(); }
262     MutableStyleProperties& mutableProperties();
263
264     PassRef<StyleRuleViewport> copy() const { return adoptRef(*new StyleRuleViewport(*this)); }
265
266 private:
267     StyleRuleViewport(PassRef<StyleProperties>);
268     StyleRuleViewport(const StyleRuleViewport&);
269
270     Ref<StyleProperties> m_properties;
271 };
272 #endif // ENABLE(CSS_DEVICE_ADAPTATION)
273
274 inline const StyleRuleMedia* toStyleRuleMedia(const StyleRuleGroup* rule)
275 {
276     ASSERT_WITH_SECURITY_IMPLICATION(!rule || rule->isMediaRule());
277     return static_cast<const StyleRuleMedia*>(rule);
278 }
279
280 inline const StyleRuleSupports* toStyleRuleSupports(const StyleRuleGroup* rule)
281 {
282     ASSERT_WITH_SECURITY_IMPLICATION(!rule || rule->isSupportsRule());
283     return static_cast<const StyleRuleSupports*>(rule);
284 }
285
286 inline const StyleRuleRegion* toStyleRuleRegion(const StyleRuleGroup* rule)
287 {
288     ASSERT_WITH_SECURITY_IMPLICATION(!rule || rule->isRegionRule());
289     return static_cast<const StyleRuleRegion*>(rule);
290 }
291
292 } // namespace WebCore
293
294 #endif // StyleRule_h