Remove some unnecessary branches from LiveNodeList traversal
[WebKit-https.git] / Source / WebCore / dom / LiveNodeList.cpp
1 /*
2  * Copyright (C) 1999 Lars Knoll (knoll@kde.org)
3  *           (C) 1999 Antti Koivisto (koivisto@kde.org)
4  *           (C) 2001 Dirk Mueller (mueller@kde.org)
5  * Copyright (C) 2004, 2006, 2007, 2008, 2010, 2013 Apple Inc. All rights reserved.
6  *
7  * This library is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Library General Public
9  * License as published by the Free Software Foundation; either
10  * version 2 of the License, or (at your option) any later version.
11  *
12  * This library is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15  * Library General Public License for more details.
16  *
17  * You should have received a copy of the GNU Library General Public License
18  * along with this library; see the file COPYING.LIB.  If not, write to
19  * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
20  * Boston, MA 02110-1301, USA.
21  */
22
23 #include "config.h"
24 #include "LiveNodeList.h"
25
26 #include "ClassNodeList.h"
27 #include "Element.h"
28 #include "ElementTraversal.h"
29 #include "HTMLCollection.h"
30 #include "TagNodeList.h"
31
32 namespace WebCore {
33
34 LiveNodeList::LiveNodeList(ContainerNode& ownerNode, Type type, NodeListInvalidationType invalidationType, NodeListRootType rootType)
35     : m_ownerNode(ownerNode)
36     , m_rootType(rootType)
37     , m_invalidationType(invalidationType)
38     , m_type(static_cast<unsigned>(type))
39 {
40     ASSERT(m_rootType == static_cast<unsigned>(rootType));
41     ASSERT(m_invalidationType == static_cast<unsigned>(invalidationType));
42     ASSERT(m_type == static_cast<unsigned>(type));
43 }
44
45 LiveNodeList::~LiveNodeList()
46 {
47 }
48
49
50 Node* LiveNodeList::namedItem(const AtomicString& elementId) const
51 {
52     // FIXME: Why doesn't this look into the name attribute like HTMLCollection::namedItem does?
53     Node& rootNode = this->rootNode();
54
55     if (rootNode.inDocument()) {
56         Element* element = rootNode.treeScope().getElementById(elementId);
57         if (element && nodeMatches(element) && element->isDescendantOf(&rootNode))
58             return element;
59         if (!element)
60             return nullptr;
61         // In the case of multiple nodes with the same name, just fall through.
62     }
63
64     unsigned length = this->length();
65     for (unsigned i = 0; i < length; i++) {
66         Node* node = item(i);
67         if (!node->isElementNode())
68             continue;
69         Element* element = toElement(node);
70         // FIXME: This should probably be using getIdAttribute instead of idForStyleResolution.
71         if (element->hasID() && element->idForStyleResolution() == elementId)
72             return node;
73     }
74
75     return nullptr;
76 }
77
78 } // namespace WebCore