diff options
author | Lorry Tar Creator <lorry-tar-importer@lorry> | 2017-06-27 06:07:23 +0000 |
---|---|---|
committer | Lorry Tar Creator <lorry-tar-importer@lorry> | 2017-06-27 06:07:23 +0000 |
commit | 1bf1084f2b10c3b47fd1a588d85d21ed0eb41d0c (patch) | |
tree | 46dcd36c86e7fbc6e5df36deb463b33e9967a6f7 /Source/WebCore/html/HTMLNameCollection.cpp | |
parent | 32761a6cee1d0dee366b885b7b9c777e67885688 (diff) | |
download | WebKitGtk-tarball-master.tar.gz |
webkitgtk-2.16.5HEADwebkitgtk-2.16.5master
Diffstat (limited to 'Source/WebCore/html/HTMLNameCollection.cpp')
-rw-r--r-- | Source/WebCore/html/HTMLNameCollection.cpp | 60 |
1 files changed, 25 insertions, 35 deletions
diff --git a/Source/WebCore/html/HTMLNameCollection.cpp b/Source/WebCore/html/HTMLNameCollection.cpp index 50eda4826..6e203aefb 100644 --- a/Source/WebCore/html/HTMLNameCollection.cpp +++ b/Source/WebCore/html/HTMLNameCollection.cpp @@ -24,8 +24,11 @@ #include "HTMLNameCollection.h" #include "Element.h" +#include "HTMLAppletElement.h" #include "HTMLDocument.h" +#include "HTMLEmbedElement.h" #include "HTMLFormElement.h" +#include "HTMLIFrameElement.h" #include "HTMLImageElement.h" #include "HTMLNames.h" #include "HTMLObjectElement.h" @@ -36,59 +39,46 @@ namespace WebCore { using namespace HTMLNames; -HTMLNameCollection::HTMLNameCollection(Document& document, CollectionType type, const AtomicString& name) - : HTMLCollection(document, type) - , m_name(name) +bool WindowNameCollection::elementMatchesIfNameAttributeMatch(const Element& element) { + return is<HTMLImageElement>(element) || is<HTMLFormElement>(element) || is<HTMLAppletElement>(element) + || is<HTMLEmbedElement>(element) || is<HTMLObjectElement>(element); } -HTMLNameCollection::~HTMLNameCollection() -{ - ASSERT(type() == WindowNamedItems || type() == DocumentNamedItems); - - document().nodeLists()->removeCachedCollection(this, m_name); -} - -bool WindowNameCollection::nodeMatchesIfNameAttributeMatch(Element* element) -{ - return isHTMLImageElement(element) || isHTMLFormElement(element) || element->hasTagName(appletTag) - || element->hasTagName(embedTag) || element->hasTagName(objectTag); -} - -bool WindowNameCollection::nodeMatches(Element* element, const AtomicStringImpl* name) +bool WindowNameCollection::elementMatches(const Element& element, const AtomicStringImpl* name) { // Find only images, forms, applets, embeds and objects by name, but anything by id - if (nodeMatchesIfNameAttributeMatch(element) && element->getNameAttribute().impl() == name) + if (elementMatchesIfNameAttributeMatch(element) && element.getNameAttribute().impl() == name) return true; - return element->getIdAttribute().impl() == name; + return element.getIdAttribute().impl() == name; } -bool DocumentNameCollection::nodeMatchesIfIdAttributeMatch(Element* element) +bool DocumentNameCollection::elementMatchesIfIdAttributeMatch(const Element& element) { // FIXME: we need to fix HTMLImageElement to update the hash map for us when name attribute has been removed. - return element->hasTagName(appletTag) || (element->hasTagName(objectTag) && toHTMLObjectElement(element)->isDocNamedItem()) - || (isHTMLImageElement(element) && element->hasName()); + return is<HTMLAppletElement>(element) || (is<HTMLObjectElement>(element) && downcast<HTMLObjectElement>(element).isDocNamedItem()) + || (is<HTMLImageElement>(element) && element.hasName()); } -bool DocumentNameCollection::nodeMatchesIfNameAttributeMatch(Element* element) +bool DocumentNameCollection::elementMatchesIfNameAttributeMatch(const Element& element) { - return isHTMLFormElement(element) || element->hasTagName(embedTag) || element->hasTagName(iframeTag) - || element->hasTagName(appletTag) || (element->hasTagName(objectTag) && toHTMLObjectElement(element)->isDocNamedItem()) - || isHTMLImageElement(element); + return is<HTMLFormElement>(element) || is<HTMLEmbedElement>(element) || is<HTMLIFrameElement>(element) + || is<HTMLAppletElement>(element) || (is<HTMLObjectElement>(element) && downcast<HTMLObjectElement>(element).isDocNamedItem()) + || is<HTMLImageElement>(element); } -bool DocumentNameCollection::nodeMatches(Element* element, const AtomicStringImpl* name) +bool DocumentNameCollection::elementMatches(const Element& element, const AtomicStringImpl* name) { // Find images, forms, applets, embeds, objects and iframes by name, applets and object by id, and images by id // but only if they have a name attribute (this very strange rule matches IE) - if (isHTMLFormElement(element) || element->hasTagName(embedTag) || element->hasTagName(iframeTag)) - return element->getNameAttribute().impl() == name; - if (element->hasTagName(appletTag)) - return element->getNameAttribute().impl() == name || element->getIdAttribute().impl() == name; - if (element->hasTagName(objectTag)) - return (element->getNameAttribute().impl() == name || element->getIdAttribute().impl() == name) && toHTMLObjectElement(element)->isDocNamedItem(); - if (isHTMLImageElement(element)) - return element->getNameAttribute().impl() == name || (element->getIdAttribute().impl() == name && element->hasName()); + if (is<HTMLFormElement>(element) || is<HTMLEmbedElement>(element) || is<HTMLIFrameElement>(element)) + return element.getNameAttribute().impl() == name; + if (is<HTMLAppletElement>(element)) + return element.getNameAttribute().impl() == name || element.getIdAttribute().impl() == name; + if (is<HTMLObjectElement>(element)) + return (element.getNameAttribute().impl() == name || element.getIdAttribute().impl() == name) && downcast<HTMLObjectElement>(element).isDocNamedItem(); + if (is<HTMLImageElement>(element)) + return element.getNameAttribute().impl() == name || (element.getIdAttribute().impl() == name && element.hasName()); return false; } |