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

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

Issue 18311002: Partial implementation of CSSVariablesMap for CSS Variables CSSOM (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Minor optimisation to clearVariables Created 7 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 | Annotate | Revision Log
OLDNEW
(Empty)
1 /*
2 * Copyright (C) 2013 Google Inc. All rights reserved.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
6 * met:
7 *
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above
11 * copyright notice, this list of conditions and the following disclaimer
12 * in the documentation and/or other materials provided with the
13 * distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
18 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
19 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
20 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
21 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
25 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 */
27
28 #ifndef CSSVariablesMap_h
29 #define CSSVariablesMap_h
30
31 #include "RuntimeEnabledFeatures.h"
32 #include "core/css/CSSStyleDeclaration.h"
33 #include "wtf/RefCounted.h"
34 #include "wtf/text/WTFString.h"
35
36 namespace WebCore {
37
38 typedef int ExceptionCode;
39
40 class CSSVariablesMap : public RefCounted<CSSVariablesMap> {
41 public:
42 virtual ~CSSVariablesMap() { }
43
44 static PassRefPtr<CSSVariablesMap> create(CSSStyleDeclaration* styleDeclarat ion)
45 {
46 // FIXME: Recycle existing CSSVariablesMaps for CSSStyleDeclarations.
47 return adoptRef(new CSSVariablesMap(styleDeclaration));
48 }
49
50 unsigned size() const
51 {
52 return m_styleDeclaration->variableCount();
53 }
54
55 String get(const AtomicString& name) const
56 {
57 return m_styleDeclaration->variableValue(name);
58 }
59
60 bool has(const AtomicString& name) const
61 {
62 return !get(name).isEmpty();
63 }
64
65 void set(const AtomicString& name, const String& value, ExceptionCode& ec) c onst
66 {
67 m_styleDeclaration->setVariableValue(name, value, ec);
68 }
69
70 bool deleteImpl(const AtomicString& name) const
esprehn 2013/07/10 02:42:11 Just call it remove() ?
alancutter (OOO until 2018) 2013/07/10 11:18:13 Done.
71 {
72 return m_styleDeclaration->removeVariable(name);
73 }
74
75 void clear(ExceptionCode& ec) const
76 {
77 return m_styleDeclaration->clearVariables(ec);
78 }
79
80 private:
81 explicit CSSVariablesMap(CSSStyleDeclaration* styleDeclaration)
82 : m_styleDeclaration(styleDeclaration)
83 {
84 ASSERT(RuntimeEnabledFeatures::cssVariablesEnabled());
85 }
86
87 RefPtr<CSSStyleDeclaration> m_styleDeclaration;
88 };
89
90 } // namespace WebCore
91
92 #endif // CSSVariablesMap_h
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698