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

Side by Side Diff: Source/core/dom/Element.h

Issue 298253009: Add iterator object to iterate efficiently over an Element's attributes (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Rebase Created 6 years, 6 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
« no previous file with comments | « Source/core/dom/DatasetDOMStringMap.cpp ('k') | Source/core/dom/Element.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright (C) 1999 Lars Knoll (knoll@kde.org) 2 * Copyright (C) 1999 Lars Knoll (knoll@kde.org)
3 * (C) 1999 Antti Koivisto (koivisto@kde.org) 3 * (C) 1999 Antti Koivisto (koivisto@kde.org)
4 * (C) 2001 Peter Kelly (pmk@post.com) 4 * (C) 2001 Peter Kelly (pmk@post.com)
5 * (C) 2001 Dirk Mueller (mueller@kde.org) 5 * (C) 2001 Dirk Mueller (mueller@kde.org)
6 * Copyright (C) 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2013 Appl e Inc. All rights reserved. 6 * Copyright (C) 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2013 Appl e Inc. All rights reserved.
7 * 7 *
8 * This library is free software; you can redistribute it and/or 8 * This library is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU Library General Public 9 * modify it under the terms of the GNU Library General Public
10 * License as published by the Free Software Foundation; either 10 * License as published by the Free Software Foundation; either
(...skipping 151 matching lines...) Expand 10 before | Expand all | Expand 10 after
162 bool shouldIgnoreAttributeCase() const; 162 bool shouldIgnoreAttributeCase() const;
163 163
164 // Call this to get the value of the id attribute for style resolution purpo ses. 164 // Call this to get the value of the id attribute for style resolution purpo ses.
165 // The value will already be lowercased if the document is in compatibility mode, 165 // The value will already be lowercased if the document is in compatibility mode,
166 // so this function is not suitable for non-style uses. 166 // so this function is not suitable for non-style uses.
167 const AtomicString& idForStyleResolution() const; 167 const AtomicString& idForStyleResolution() const;
168 168
169 // Internal methods that assume the existence of attribute storage, one shou ld use hasAttributes() 169 // Internal methods that assume the existence of attribute storage, one shou ld use hasAttributes()
170 // before calling them. This is not a trivial getter and its return value sh ould be cached for 170 // before calling them. This is not a trivial getter and its return value sh ould be cached for
171 // performance. 171 // performance.
172 AttributeIteratorAccessor attributesIterator() const { return elementData()- >attributesIterator(); }
172 size_t attributeCount() const; 173 size_t attributeCount() const;
173 const Attribute& attributeItem(unsigned index) const; 174 const Attribute& attributeItem(unsigned index) const;
174 const Attribute* getAttributeItem(const QualifiedName&) const; 175 const Attribute* getAttributeItem(const QualifiedName&) const;
175 size_t getAttributeItemIndex(const QualifiedName& name) const { return eleme ntData()->getAttributeItemIndex(name); } 176 size_t getAttributeItemIndex(const QualifiedName& name) const { return eleme ntData()->getAttributeItemIndex(name); }
176 size_t getAttributeItemIndex(const AtomicString& name, bool shouldIgnoreAttr ibuteCase) const { return elementData()->getAttributeItemIndex(name, shouldIgnor eAttributeCase); } 177 size_t getAttributeItemIndex(const AtomicString& name, bool shouldIgnoreAttr ibuteCase) const { return elementData()->getAttributeItemIndex(name, shouldIgnor eAttributeCase); }
177 178
178 void scrollIntoView(bool alignToTop = true); 179 void scrollIntoView(bool alignToTop = true);
179 void scrollIntoViewIfNeeded(bool centerIfNeeded = true); 180 void scrollIntoViewIfNeeded(bool centerIfNeeded = true);
180 181
181 void scrollByLines(int lines); 182 void scrollByLines(int lines);
(...skipping 691 matching lines...) Expand 10 before | Expand all | Expand 10 after
873 template <> inline bool isElementOfType<const thisType>(const Element& eleme nt) { return element.predicate; } \ 874 template <> inline bool isElementOfType<const thisType>(const Element& eleme nt) { return element.predicate; } \
874 DEFINE_NODE_TYPE_CASTS(thisType, predicate) 875 DEFINE_NODE_TYPE_CASTS(thisType, predicate)
875 876
876 #define DEFINE_ELEMENT_TYPE_CASTS_WITH_FUNCTION(thisType) \ 877 #define DEFINE_ELEMENT_TYPE_CASTS_WITH_FUNCTION(thisType) \
877 template <> inline bool isElementOfType<const thisType>(const Element& eleme nt) { return is##thisType(element); } \ 878 template <> inline bool isElementOfType<const thisType>(const Element& eleme nt) { return is##thisType(element); } \
878 DEFINE_NODE_TYPE_CASTS_WITH_FUNCTION(thisType) 879 DEFINE_NODE_TYPE_CASTS_WITH_FUNCTION(thisType)
879 880
880 } // namespace 881 } // namespace
881 882
882 #endif 883 #endif
OLDNEW
« no previous file with comments | « Source/core/dom/DatasetDOMStringMap.cpp ('k') | Source/core/dom/Element.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698