Index: test/unittests/compiler/node-test-utils.cc |
diff --git a/test/unittests/compiler/node-test-utils.cc b/test/unittests/compiler/node-test-utils.cc |
index bfb9c06960c0424db611e33a32217dbd96882af4..ea34bd97d69e07735c34010ad44f0150673b3875 100644 |
--- a/test/unittests/compiler/node-test-utils.cc |
+++ b/test/unittests/compiler/node-test-utils.cc |
@@ -1404,6 +1404,7 @@ class IsUnopMatcher final : public NodeMatcher { |
const Matcher<Node*> input_matcher_; |
}; |
+ |
class IsParameterMatcher final : public NodeMatcher { |
public: |
explicit IsParameterMatcher(const Matcher<int>& index_matcher) |
@@ -1425,6 +1426,60 @@ class IsParameterMatcher final : public NodeMatcher { |
const Matcher<int> index_matcher_; |
}; |
+ |
+// TODO(mythria): Check if we can use the same matcher for Load and Store |
+class IsJSLoadNamedMatcher final : public NodeMatcher { |
+ public: |
+ IsJSLoadNamedMatcher(const Matcher<Handle<Name>>& name_matcher, |
+ const Matcher<Node*>& object_value_matcher, |
+ const Matcher<Node*>& feedback_vector_matcher, |
+ const Matcher<Node*>& effect_matcher, |
+ const Matcher<Node*>& control_matcher) |
+ : NodeMatcher(IrOpcode::kJSLoadNamed), |
+ name_matcher_(name_matcher), |
+ object_value_matcher_(object_value_matcher), |
+ feedback_vector_matcher_(feedback_vector_matcher), |
+ effect_matcher_(effect_matcher), |
+ control_matcher_(control_matcher) {} |
+ |
+ void DescribeTo(std::ostream* os) const final { |
+ NodeMatcher::DescribeTo(os); |
+ *os << " whose object ("; |
+ object_value_matcher_.DescribeTo(os); |
+ *os << "), name ("; |
+ name_matcher_.DescribeTo(os); |
+ *os << "), feedback vector ("; |
+ feedback_vector_matcher_.DescribeTo(os); |
+ *os << "), effect ("; |
+ effect_matcher_.DescribeTo(os); |
+ *os << "), and control ("; |
+ control_matcher_.DescribeTo(os); |
+ *os << ")"; |
+ } |
+ |
+ bool MatchAndExplain(Node* node, MatchResultListener* listener) const final { |
+ return (NodeMatcher::MatchAndExplain(node, listener) && |
+ PrintMatchAndExplain(OpParameter<const NamedAccess>(node).name(), |
+ "Name", name_matcher_, listener) && |
+ PrintMatchAndExplain(NodeProperties::GetValueInput(node, 0), |
+ "object", object_value_matcher_, listener) && |
+ PrintMatchAndExplain(NodeProperties::GetValueInput(node, 1), |
+ "feedback vector", feedback_vector_matcher_, |
+ listener) && |
+ PrintMatchAndExplain(NodeProperties::GetEffectInput(node), "effect", |
+ effect_matcher_, listener) && |
+ PrintMatchAndExplain(NodeProperties::GetControlInput(node), |
+ "control", control_matcher_, listener)); |
+ } |
+ |
+ private: |
+ const Matcher<Handle<Name>> name_matcher_; |
+ const Matcher<Node*> object_value_matcher_; |
+ const Matcher<Node*> feedback_vector_matcher_; |
+ const Matcher<Node*> effect_matcher_; |
+ const Matcher<Node*> control_matcher_; |
+}; |
+ |
} // namespace |
@@ -1998,6 +2053,17 @@ Matcher<Node*> IsLoadFramePointer() { |
} |
+Matcher<Node*> IsJSLoadNamed(const Handle<Name> name, |
+ const Matcher<Node*>& object_value_matcher, |
+ const Matcher<Node*>& feedback_vector_matcher, |
+ const Matcher<Node*>& effect_matcher, |
+ const Matcher<Node*>& control_matcher) { |
+ return MakeMatcher(new IsJSLoadNamedMatcher(name, object_value_matcher, |
+ feedback_vector_matcher, |
+ effect_matcher, control_matcher)); |
+} |
+ |
+ |
#define IS_BINOP_MATCHER(Name) \ |
Matcher<Node*> Is##Name(const Matcher<Node*>& lhs_matcher, \ |
const Matcher<Node*>& rhs_matcher) { \ |