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

Side by Side Diff: pkg/matcher/lib/src/operator_matchers.dart

Issue 313563002: pkg/matcher: Reverting 36881,36896 while investigating dart2js checked crash (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 6 years, 6 months 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 | Annotate | Revision Log
« no previous file with comments | « pkg/matcher/lib/src/numeric_matchers.dart ('k') | pkg/matcher/lib/src/pretty_print.dart » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 library matcher.operator_matchers; 5 part of matcher;
6 6
7 import 'core_matchers.dart'; 7 /**
8 import 'expect.dart'; 8 * This returns a matcher that inverts [matcher] to its logical negation.
9 import 'interfaces.dart'; 9 */
10
11 /// This returns a matcher that inverts [matcher] to its logical negation.
12 Matcher isNot(matcher) => new _IsNot(wrapMatcher(matcher)); 10 Matcher isNot(matcher) => new _IsNot(wrapMatcher(matcher));
13 11
14 class _IsNot extends Matcher { 12 class _IsNot extends Matcher {
15 final Matcher _matcher; 13 final Matcher _matcher;
16 14
17 const _IsNot(Matcher this._matcher); 15 const _IsNot(Matcher this._matcher);
18 16
19 bool matches(item, Map matchState) => !_matcher.matches(item, matchState); 17 bool matches(item, Map matchState) => !_matcher.matches(item, matchState);
20 18
21 Description describe(Description description) => 19 Description describe(Description description) =>
22 description.add('not ').addDescriptionOf(_matcher); 20 description.add('not ').addDescriptionOf(_matcher);
23 } 21 }
24 22
25 /// This returns a matcher that matches if all of the matchers passed as 23 /**
26 /// arguments (up to 7) match. Instead of passing the matchers separately 24 * This returns a matcher that matches if all of the matchers passed as
27 /// they can be passed as a single List argument. 25 * arguments (up to 7) match. Instead of passing the matchers separately
28 /// Any argument that is not a matcher is implicitly wrapped in a 26 * they can be passed as a single List argument.
29 /// Matcher to check for equality. 27 * Any argument that is not a matcher is implicitly wrapped in a
28 * Matcher to check for equality.
29 */
30 Matcher allOf(arg0, 30 Matcher allOf(arg0,
31 [arg1 = null, 31 [arg1 = null,
32 arg2 = null, 32 arg2 = null,
33 arg3 = null, 33 arg3 = null,
34 arg4 = null, 34 arg4 = null,
35 arg5 = null, 35 arg5 = null,
36 arg6 = null]) { 36 arg6 = null]) {
37 return new _AllOf(_wrapArgs(arg0, arg1, arg2, arg3, arg4, arg5, arg6)); 37 if (arg0 is List) {
38 expect(arg1, isNull);
39 expect(arg2, isNull);
40 expect(arg3, isNull);
41 expect(arg4, isNull);
42 expect(arg5, isNull);
43 expect(arg6, isNull);
44 for (int i = 0; i < arg0.length; i++) {
45 arg0[i] = wrapMatcher(arg0[i]);
46 }
47 return new _AllOf(arg0);
48 } else {
49 List matchers = new List();
50 if (arg0 != null) {
51 matchers.add(wrapMatcher(arg0));
52 }
53 if (arg1 != null) {
54 matchers.add(wrapMatcher(arg1));
55 }
56 if (arg2 != null) {
57 matchers.add(wrapMatcher(arg2));
58 }
59 if (arg3 != null) {
60 matchers.add(wrapMatcher(arg3));
61 }
62 if (arg4 != null) {
63 matchers.add(wrapMatcher(arg4));
64 }
65 if (arg5 != null) {
66 matchers.add(wrapMatcher(arg5));
67 }
68 if (arg6 != null) {
69 matchers.add(wrapMatcher(arg6));
70 }
71 return new _AllOf(matchers);
72 }
38 } 73 }
39 74
40 class _AllOf extends Matcher { 75 class _AllOf extends Matcher {
41 final List<Matcher> _matchers; 76 final Iterable<Matcher> _matchers;
42 77
43 const _AllOf(this._matchers); 78 const _AllOf(this._matchers);
44 79
45 bool matches(item, Map matchState) { 80 bool matches(item, Map matchState) {
46 for (var matcher in _matchers) { 81 for (var matcher in _matchers) {
47 if (!matcher.matches(item, matchState)) { 82 if (!matcher.matches(item, matchState)) {
48 addStateInfo(matchState, {'matcher': matcher}); 83 addStateInfo(matchState, {'matcher': matcher});
49 return false; 84 return false;
50 } 85 }
51 } 86 }
52 return true; 87 return true;
53 } 88 }
54 89
55 Description describeMismatch(item, Description mismatchDescription, 90 Description describeMismatch(item, Description mismatchDescription,
56 Map matchState, bool verbose) { 91 Map matchState, bool verbose) {
57 var matcher = matchState['matcher']; 92 var matcher = matchState['matcher'];
58 matcher.describeMismatch(item, mismatchDescription, 93 matcher.describeMismatch(item, mismatchDescription,
59 matchState['state'], verbose); 94 matchState['state'], verbose);
60 return mismatchDescription; 95 return mismatchDescription;
61 } 96 }
62 97
63 Description describe(Description description) => 98 Description describe(Description description) =>
64 description.addAll('(', ' and ', ')', _matchers); 99 description.addAll('(', ' and ', ')', _matchers);
65 } 100 }
66 101
67 /// Matches if any of the given matchers evaluate to true. The 102 /**
68 /// arguments can be a set of matchers as separate parameters 103 * Matches if any of the given matchers evaluate to true. The
69 /// (up to 7), or a List of matchers. 104 * arguments can be a set of matchers as separate parameters
70 /// 105 * (up to 7), or a List of matchers.
71 /// The matchers are evaluated from left to right using short-circuit 106 *
72 /// evaluation, so evaluation stops as soon as a matcher returns true. 107 * The matchers are evaluated from left to right using short-circuit
73 /// 108 * evaluation, so evaluation stops as soon as a matcher returns true.
74 /// Any argument that is not a matcher is implicitly wrapped in a 109 *
75 /// Matcher to check for equality. 110 * Any argument that is not a matcher is implicitly wrapped in a
111 * Matcher to check for equality.
112 */
76 113
77 Matcher anyOf(arg0, 114 Matcher anyOf(arg0,
78 [arg1 = null, 115 [arg1 = null,
79 arg2 = null, 116 arg2 = null,
80 arg3 = null, 117 arg3 = null,
81 arg4 = null, 118 arg4 = null,
82 arg5 = null, 119 arg5 = null,
83 arg6 = null]) { 120 arg6 = null]) {
84 return new _AnyOf(_wrapArgs(arg0, arg1, arg2, arg3, arg4, arg5, arg6)); 121 if (arg0 is List) {
122 expect(arg1, isNull);
123 expect(arg2, isNull);
124 expect(arg3, isNull);
125 expect(arg4, isNull);
126 expect(arg5, isNull);
127 expect(arg6, isNull);
128 for (int i = 0; i < arg0.length; i++) {
129 arg0[i] = wrapMatcher(arg0[i]);
130 }
131 return new _AnyOf(arg0);
132 } else {
133 List matchers = new List();
134 if (arg0 != null) {
135 matchers.add(wrapMatcher(arg0));
136 }
137 if (arg1 != null) {
138 matchers.add(wrapMatcher(arg1));
139 }
140 if (arg2 != null) {
141 matchers.add(wrapMatcher(arg2));
142 }
143 if (arg3 != null) {
144 matchers.add(wrapMatcher(arg3));
145 }
146 if (arg4 != null) {
147 matchers.add(wrapMatcher(arg4));
148 }
149 if (arg5 != null) {
150 matchers.add(wrapMatcher(arg5));
151 }
152 if (arg6 != null) {
153 matchers.add(wrapMatcher(arg6));
154 }
155 return new _AnyOf(matchers);
156 }
85 } 157 }
86 158
87 class _AnyOf extends Matcher { 159 class _AnyOf extends Matcher {
88 final List<Matcher> _matchers; 160 final Iterable<Matcher> _matchers;
89 161
90 const _AnyOf(this._matchers); 162 const _AnyOf(this._matchers);
91 163
92 bool matches(item, Map matchState) { 164 bool matches(item, Map matchState) {
93 for (var matcher in _matchers) { 165 for (var matcher in _matchers) {
94 if (matcher.matches(item, matchState)) { 166 if (matcher.matches(item, matchState)) {
95 return true; 167 return true;
96 } 168 }
97 } 169 }
98 return false; 170 return false;
99 } 171 }
100 172
101 Description describe(Description description) => 173 Description describe(Description description) =>
102 description.addAll('(', ' or ', ')', _matchers); 174 description.addAll('(', ' or ', ')', _matchers);
103 } 175 }
104 176
105 List<Matcher> _wrapArgs(arg0, arg1, arg2, arg3, arg4, arg5, arg6) {
106 if (arg0 is List) {
107 // TODO(kevmoo) throw a more helpful error here if any of these args is
108 // not null
109 expect(arg1, isNull);
110 expect(arg2, isNull);
111 expect(arg3, isNull);
112 expect(arg4, isNull);
113 expect(arg5, isNull);
114 expect(arg6, isNull);
115
116 return arg0.map((a) => wrapMatcher(a)).toList();
117 }
118
119 List matchers = new List();
120 if (arg0 != null) {
121 matchers.add(wrapMatcher(arg0));
122 }
123 if (arg1 != null) {
124 matchers.add(wrapMatcher(arg1));
125 }
126 if (arg2 != null) {
127 matchers.add(wrapMatcher(arg2));
128 }
129 if (arg3 != null) {
130 matchers.add(wrapMatcher(arg3));
131 }
132 if (arg4 != null) {
133 matchers.add(wrapMatcher(arg4));
134 }
135 if (arg5 != null) {
136 matchers.add(wrapMatcher(arg5));
137 }
138 if (arg6 != null) {
139 matchers.add(wrapMatcher(arg6));
140 }
141 return matchers;
142 }
OLDNEW
« no previous file with comments | « pkg/matcher/lib/src/numeric_matchers.dart ('k') | pkg/matcher/lib/src/pretty_print.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698