summaryrefslogtreecommitdiff
path: root/Source/WebCore/html/HTMLNameCollection.cpp
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@lorry>2017-06-27 06:07:23 +0000
committerLorry Tar Creator <lorry-tar-importer@lorry>2017-06-27 06:07:23 +0000
commit1bf1084f2b10c3b47fd1a588d85d21ed0eb41d0c (patch)
tree46dcd36c86e7fbc6e5df36deb463b33e9967a6f7 /Source/WebCore/html/HTMLNameCollection.cpp
parent32761a6cee1d0dee366b885b7b9c777e67885688 (diff)
downloadWebKitGtk-tarball-master.tar.gz
Diffstat (limited to 'Source/WebCore/html/HTMLNameCollection.cpp')
-rw-r--r--Source/WebCore/html/HTMLNameCollection.cpp60
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;
}