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 713a4bc440889231b58a93f42e8490898c1442b7..8428dcc2592317146ff33ec668d4a62ad4fe8c25 100644 |
--- a/test/unittests/compiler/node-test-utils.cc |
+++ b/test/unittests/compiler/node-test-utils.cc |
@@ -1858,6 +1858,84 @@ class IsJSCallMatcher final : public NodeMatcher { |
const Matcher<Node*> control_matcher_; |
}; |
+ |
+class CreateClosureParametersMatcher final |
+ : public MatcherInterface<CreateClosureParameters*> { |
+ public: |
+ explicit CreateClosureParametersMatcher(CreateClosureParameters* parameters) |
+ : parameters_(parameters) {} |
+ |
+ void DescribeTo(::std::ostream* os) const final { |
+ *os << "is a CreateClosureParameters instance"; |
+ } |
+ |
+ bool MatchAndExplain(CreateClosureParameters* parameters, |
+ MatchResultListener* listener) const override { |
+ if (parameters == NULL) { |
+ *listener << "which is NULL"; |
+ return false; |
+ } |
+ if (*parameters->shared_info() != *parameters_->shared_info()) { |
+ *listener << "whose shared function info is " |
+ << *parameters->shared_info() << " but should have been " |
+ << *parameters_->shared_info(); |
+ return false; |
+ } |
+ if (parameters->pretenure() != parameters_->pretenure()) { |
+ *listener << "whose tenured flag is " << parameters->pretenure() |
+ << " but should have been " << parameters_->pretenure(); |
+ return false; |
+ } |
+ return true; |
+ } |
+ |
+ private: |
+ CreateClosureParameters* parameters_; |
+}; |
+ |
+ |
+class IsCreateClosureMatcher final : public NodeMatcher { |
+ public: |
+ IsCreateClosureMatcher( |
+ const Matcher<CreateClosureParameters*>& parameters_matcher, |
+ const Matcher<Node*>& effect_matcher, |
+ const Matcher<Node*>& control_matcher) |
+ : NodeMatcher(IrOpcode::Value::kJSCreateClosure), |
+ parameters_matcher_(parameters_matcher), |
+ effect_matcher_(effect_matcher), |
+ control_matcher_(control_matcher) {} |
+ |
+ void DescribeTo(std::ostream* os) const final { |
+ NodeMatcher::DescribeTo(os); |
+ *os << " whose value ("; |
+ parameters_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 { |
+ if (!NodeMatcher::MatchAndExplain(node, listener)) { |
+ return false; |
+ } |
+ CreateClosureParameters parameters = |
+ OpParameter<CreateClosureParameters>(node); |
+ return (PrintMatchAndExplain(¶meters, "value", parameters_matcher_, |
Michael Starzinger
2015/11/23 11:18:38
Instead of going through extra lengths of making t
oth
2015/11/24 12:29:36
Done.
|
+ listener) && |
+ PrintMatchAndExplain(NodeProperties::GetEffectInput(node), "effect", |
+ effect_matcher_, listener) && |
+ PrintMatchAndExplain(NodeProperties::GetControlInput(node), |
+ "control", control_matcher_, listener)); |
+ } |
+ |
+ private: |
+ const Matcher<CreateClosureParameters*> parameters_matcher_; |
+ const Matcher<Node*> effect_matcher_; |
+ const Matcher<Node*> control_matcher_; |
+}; |
+ |
} // namespace |
@@ -2535,6 +2613,21 @@ Matcher<Node*> IsJSCallRuntime(std::vector<Matcher<Node*>> value_matchers, |
} |
+Matcher<CreateClosureParameters*> IsCreateClosureParameters( |
+ CreateClosureParameters* parameters) { |
+ return MakeMatcher(new CreateClosureParametersMatcher(parameters)); |
+} |
+ |
+ |
+Matcher<Node*> IsCreateClosure( |
+ const Matcher<CreateClosureParameters*>& parameters_matcher, |
+ const Matcher<Node*>& effect_matcher, |
+ const Matcher<Node*>& control_matcher) { |
+ return MakeMatcher(new IsCreateClosureMatcher( |
+ parameters_matcher, effect_matcher, control_matcher)); |
+} |
+ |
+ |
#define IS_BINOP_MATCHER(Name) \ |
Matcher<Node*> Is##Name(const Matcher<Node*>& lhs_matcher, \ |
const Matcher<Node*>& rhs_matcher) { \ |