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

Side by Side Diff: third_party/WebKit/Source/core/dom/SelectorQuery.h

Issue 1496533003: Implement a simple version of SelectorQuery. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Revert change to SelectorFilter.h Created 5 years 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
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2011, 2013 Apple Inc. All rights reserved. 2 * Copyright (C) 2011, 2013 Apple Inc. All rights reserved.
3 * Copyright (C) 2014 Samsung Electronics. All rights reserved. 3 * Copyright (C) 2014 Samsung Electronics. All rights reserved.
4 * 4 *
5 * Redistribution and use in source and binary forms, with or without 5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions 6 * modification, are permitted provided that the following conditions
7 * are met: 7 * are met:
8 * 8 *
9 * 1. Redistributions of source code must retain the above copyright 9 * 1. Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer. 10 * notice, this list of conditions and the following disclaimer.
(...skipping 17 matching lines...) Expand all
28 #define SelectorQuery_h 28 #define SelectorQuery_h
29 29
30 #include "core/css/CSSSelectorList.h" 30 #include "core/css/CSSSelectorList.h"
31 #include "platform/heap/Handle.h" 31 #include "platform/heap/Handle.h"
32 #include "wtf/HashMap.h" 32 #include "wtf/HashMap.h"
33 #include "wtf/Vector.h" 33 #include "wtf/Vector.h"
34 #include "wtf/text/AtomicStringHash.h" 34 #include "wtf/text/AtomicStringHash.h"
35 35
36 namespace blink { 36 namespace blink {
37 37
38 class CSSSelector;
39 class ContainerNode; 38 class ContainerNode;
40 class Document; 39 class Document;
41 class Element; 40 class Element;
42 class ExceptionState; 41 class ExceptionState;
42 class SelectorMatcher;
43 template <typename NodeType> class StaticNodeTypeList; 43 template <typename NodeType> class StaticNodeTypeList;
44 typedef StaticNodeTypeList<Element> StaticElementList; 44 typedef StaticNodeTypeList<Element> StaticElementList;
45 45
46 class SelectorDataList {
47 DISALLOW_NEW();
48 public:
49 void initialize(const CSSSelectorList&);
50 bool matches(Element&) const;
51 Element* closest(Element&) const;
52 PassRefPtrWillBeRawPtr<StaticElementList> queryAll(ContainerNode& rootNode) const;
53 PassRefPtrWillBeRawPtr<Element> queryFirst(ContainerNode& rootNode) const;
54
55 private:
56 bool canUseFastQuery(const ContainerNode& rootNode) const;
57 bool selectorMatches(const CSSSelector&, Element&, const ContainerNode&) con st;
58
59 template <typename SelectorQueryTrait>
60 void collectElementsByClassName(ContainerNode& rootNode, const AtomicString& className, typename SelectorQueryTrait::OutputType&) const;
61 template <typename SelectorQueryTrait>
62 void collectElementsByTagName(ContainerNode& rootNode, const QualifiedName& tagName, typename SelectorQueryTrait::OutputType&) const;
63
64 template <typename SelectorQueryTrait>
65 void findTraverseRootsAndExecute(ContainerNode& rootNode, typename SelectorQ ueryTrait::OutputType&) const;
66
67 enum MatchTraverseRootState { DoesNotMatchTraverseRoots, MatchesTraverseRoot s };
68 template <typename SelectorQueryTrait>
69 void executeForTraverseRoot(const CSSSelector&, ContainerNode* traverseRoot, MatchTraverseRootState, ContainerNode& rootNode, typename SelectorQueryTrait::O utputType&) const;
70 template <typename SelectorQueryTrait, typename SimpleElementListType>
71 void executeForTraverseRoots(const CSSSelector&, SimpleElementListType& trav erseRoots, MatchTraverseRootState, ContainerNode& rootNode, typename SelectorQue ryTrait::OutputType&) const;
72
73 template <typename SelectorQueryTrait>
74 bool selectorListMatches(ContainerNode& rootNode, Element&, typename Selecto rQueryTrait::OutputType&) const;
75 template <typename SelectorQueryTrait>
76 void executeSlow(ContainerNode& rootNode, typename SelectorQueryTrait::Outpu tType&) const;
77 template <typename SelectorQueryTrait>
78 void executeSlowTraversingShadowTree(ContainerNode& rootNode, typename Selec torQueryTrait::OutputType&) const;
79 template <typename SelectorQueryTrait>
80 void execute(ContainerNode& rootNode, typename SelectorQueryTrait::OutputTyp e&) const;
81 const CSSSelector* selectorForIdLookup(const CSSSelector&) const;
82
83 Vector<const CSSSelector*> m_selectors;
84 bool m_usesDeepCombinatorOrShadowPseudo : 1;
85 bool m_needsUpdatedDistribution : 1;
86 };
87
88 class SelectorQuery { 46 class SelectorQuery {
89 WTF_MAKE_NONCOPYABLE(SelectorQuery); 47 WTF_MAKE_NONCOPYABLE(SelectorQuery);
90 USING_FAST_MALLOC(SelectorQuery); 48 USING_FAST_MALLOC(SelectorQuery);
91 public: 49 public:
92 static PassOwnPtr<SelectorQuery> adopt(CSSSelectorList&); 50 static PassOwnPtr<SelectorQuery> adopt(CSSSelectorList&);
51 ~SelectorQuery();
93 52
94 bool matches(Element&) const; 53 bool matches(Element&) const;
95 Element* closest(Element&) const; 54 Element* closest(Element&) const;
96 PassRefPtrWillBeRawPtr<StaticElementList> queryAll(ContainerNode& rootNode) const; 55 PassRefPtrWillBeRawPtr<StaticElementList> queryAll(ContainerNode& rootNode) const;
97 PassRefPtrWillBeRawPtr<Element> queryFirst(ContainerNode& rootNode) const; 56 Element* queryFirst(ContainerNode& rootNode) const;
98 private: 57 private:
99 explicit SelectorQuery(CSSSelectorList&); 58 explicit SelectorQuery(CSSSelectorList&);
100 59
101 SelectorDataList m_selectors; 60 OwnPtr<SelectorMatcher> m_matcher;
102 CSSSelectorList m_selectorList;
103 }; 61 };
104 62
105 class SelectorQueryCache { 63 class SelectorQueryCache {
106 USING_FAST_MALLOC(SelectorQueryCache); 64 USING_FAST_MALLOC(SelectorQueryCache);
107 public: 65 public:
108 SelectorQuery* add(const AtomicString&, const Document&, ExceptionState&); 66 SelectorQuery* add(const AtomicString&, const Document&, ExceptionState&);
109 void invalidate(); 67 void invalidate();
110 68
111 private: 69 private:
112 HashMap<AtomicString, OwnPtr<SelectorQuery>> m_entries; 70 HashMap<AtomicString, OwnPtr<SelectorQuery>> m_entries;
113 }; 71 };
114 72
115 } 73 }
116 74
117 #endif 75 #endif
OLDNEW
« no previous file with comments | « third_party/WebKit/Source/core/css/SelectorChecker.cpp ('k') | third_party/WebKit/Source/core/dom/SelectorQuery.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698