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

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: 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
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 696 matching lines...) Expand 10 before | Expand all | Expand 10 after
878 template <> inline bool isElementOfType<const thisType>(const Element& eleme nt) { return element.predicate; } \ 879 template <> inline bool isElementOfType<const thisType>(const Element& eleme nt) { return element.predicate; } \
879 DEFINE_NODE_TYPE_CASTS(thisType, predicate) 880 DEFINE_NODE_TYPE_CASTS(thisType, predicate)
880 881
881 #define DEFINE_ELEMENT_TYPE_CASTS_WITH_FUNCTION(thisType) \ 882 #define DEFINE_ELEMENT_TYPE_CASTS_WITH_FUNCTION(thisType) \
882 template <> inline bool isElementOfType<const thisType>(const Element& eleme nt) { return is##thisType(element); } \ 883 template <> inline bool isElementOfType<const thisType>(const Element& eleme nt) { return is##thisType(element); } \
883 DEFINE_NODE_TYPE_CASTS_WITH_FUNCTION(thisType) 884 DEFINE_NODE_TYPE_CASTS_WITH_FUNCTION(thisType)
884 885
885 } // namespace 886 } // namespace
886 887
887 #endif 888 #endif
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698