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

Side by Side Diff: Source/core/css/CSSRegion.h

Issue 38943008: Explore the possibility of implementing the CSS Region interface. Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Created 7 years, 1 month 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 /* 1 /*
2 * Copyright (C) 2013 Adobe Systems Incorporated. All rights reserved. 2 * Copyright (C) 2013 Adobe Systems Incorporated. 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 * 7 *
8 * 1. Redistributions of source code must retain the above 8 * 1. Redistributions of source code must retain the above
9 * copyright notice, this list of conditions and the following 9 * copyright notice, this list of conditions and the following
10 * disclaimer. 10 * disclaimer.
11 * 2. Redistributions in binary form must reproduce the above 11 * 2. Redistributions in binary form must reproduce the above
12 * copyright notice, this list of conditions and the following 12 * copyright notice, this list of conditions and the following
13 * disclaimer in the documentation and/or other materials 13 * disclaimer in the documentation and/or other materials
14 * provided with the distribution. 14 * provided with the distribution.
15 * 15 *
16 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER "AS IS" AND ANY 16 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER "AS IS" AND ANY
17 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 17 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER BE 19 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER BE
20 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, 20 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
21 * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 21 * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
22 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 22 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
23 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 23 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR 24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
25 * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF 25 * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
26 * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 26 * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27 * SUCH DAMAGE. 27 * SUCH DAMAGE.
28 */ 28 */
29 29
30 #ifndef CSSFilterRule_h 30 #ifndef CSSRegion_h
31 #define CSSFilterRule_h 31 #define CSSRegion_h
32 32
33 #include "core/css/CSSRule.h" 33 #include "core/dom/Element.h"
34 #include "core/dom/Range.h"
35
36 #include "wtf/RefCounted.h"
37 #include "wtf/RefPtr.h"
34 38
35 namespace WebCore { 39 namespace WebCore {
36 40
37 class CSSStyleDeclaration; 41 class Range;
38 class StyleRuleFilter; 42 class RenderRegion;
39 class StyleRuleCSSStyleDeclaration;
40 43
41 class CSSFilterRule : public CSSRule { 44 class CSSRegion : public RefCounted<CSSRegion> {
42 public: 45 public:
43 static PassRefPtr<CSSFilterRule> create(StyleRuleFilter* rule, CSSStyleSheet * sheet) { return adoptRef(new CSSFilterRule(rule, sheet)); } 46 static PassRefPtr<CSSRegion> create(const RenderRegion* region)
Inactive 2013/10/25 17:48:50 Would be nice to use a reference instead of a poin
47 {
48 return adoptRef(new CSSRegion(region));
49 }
44 50
45 virtual ~CSSFilterRule(); 51 static const AtomicString& webkitRegionOverset(const Element* element)
Inactive 2013/10/25 17:48:50 Would be nice to use a reference instead of a poin
52 {
53 return element->webkitRegionOverset();
54 }
46 55
47 virtual CSSRule::Type type() const OVERRIDE { return WEBKIT_FILTER_RULE; } 56 static Vector<RefPtr<Range>> webkitGetRegionFlowRanges(const Element* elemen t)
Inactive 2013/10/25 17:48:50 '>>' do we support C++11 on all platforms now?
Inactive 2013/10/25 17:48:50 Would be nice to use a reference instead of a poin
48 virtual String cssText() const OVERRIDE; 57 {
49 virtual void reattach(StyleRuleBase*) OVERRIDE; 58 return element->webkitGetRegionFlowRanges();
59 }
50 60
51 CSSStyleDeclaration* style() const; 61 const RenderRegion* region()
Inactive 2013/10/25 17:48:50 This getter could be const and return a reference.
62 {
63 return m_region;
64 }
52 65
53 private: 66 private:
54 CSSFilterRule(StyleRuleFilter*, CSSStyleSheet* parent); 67 CSSRegion(const RenderRegion* region)
68 : m_region(region)
69 {
55 70
56 RefPtr<StyleRuleFilter> m_filterRule; 71 }
57 mutable RefPtr<StyleRuleCSSStyleDeclaration> m_propertiesCSSOMWrapper; 72
73 const RenderRegion* m_region;
abarth-chromium 2013/10/25 16:56:20 How are the lifetimes of CSSRegion and RenderRegio
58 }; 74 };
59 75
60 } 76 } // namespace WebCore
61 77
62 78 #endif // CSSRegion_h
63 #endif // CSSFilterRule_h
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698