| 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 dace110e0ca03824d0f01b4d5e44cc34064d2308..a5b72f4b54a38305cc3aff2d5325f8551e71db17 100644
|
| --- a/test/unittests/compiler/node-test-utils.cc
|
| +++ b/test/unittests/compiler/node-test-utils.cc
|
| @@ -1330,6 +1330,27 @@ class IsStoreMatcher final : public NodeMatcher {
|
| const Matcher<Node*> control_matcher_;
|
| };
|
|
|
| +class IsStackSlotMatcher final : public NodeMatcher {
|
| + public:
|
| + explicit IsStackSlotMatcher(const Matcher<MachineRepresentation>& rep_matcher)
|
| + : NodeMatcher(IrOpcode::kStackSlot), rep_matcher_(rep_matcher) {}
|
| +
|
| + void DescribeTo(std::ostream* os) const final {
|
| + NodeMatcher::DescribeTo(os);
|
| + *os << " whose rep (";
|
| + rep_matcher_.DescribeTo(os);
|
| + *os << ")";
|
| + }
|
| +
|
| + bool MatchAndExplain(Node* node, MatchResultListener* listener) const final {
|
| + return (NodeMatcher::MatchAndExplain(node, listener) &&
|
| + PrintMatchAndExplain(OpParameter<MachineRepresentation>(node),
|
| + "rep", rep_matcher_, listener));
|
| + }
|
| +
|
| + private:
|
| + const Matcher<MachineRepresentation> rep_matcher_;
|
| +};
|
|
|
| class IsToNumberMatcher final : public NodeMatcher {
|
| public:
|
| @@ -2123,6 +2144,9 @@ Matcher<Node*> IsStore(const Matcher<StoreRepresentation>& rep_matcher,
|
| effect_matcher, control_matcher));
|
| }
|
|
|
| +Matcher<Node*> IsStackSlot(const Matcher<MachineRepresentation>& rep_matcher) {
|
| + return MakeMatcher(new IsStackSlotMatcher(rep_matcher));
|
| +}
|
|
|
| Matcher<Node*> IsToNumber(const Matcher<Node*>& base_matcher,
|
| const Matcher<Node*>& context_matcher,
|
|
|