OLD | NEW |
1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2014, 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 dart_style.src.chunk; | 5 library dart_style.src.chunk; |
6 | 6 |
7 import 'fast_hash.dart'; | 7 import 'fast_hash.dart'; |
8 import 'nesting.dart'; | 8 import 'nesting_level.dart'; |
9 import 'rule/rule.dart'; | 9 import 'rule/rule.dart'; |
10 | 10 |
11 /// Tracks where a selection start or end point may appear in some piece of | 11 /// Tracks where a selection start or end point may appear in some piece of |
12 /// text. | 12 /// text. |
13 abstract class Selection { | 13 abstract class Selection { |
14 /// The chunk of text. | 14 /// The chunk of text. |
15 String get text; | 15 String get text; |
16 | 16 |
17 /// The offset from the beginning of [text] where the selection starts, or | 17 /// The offset from the beginning of [text] where the selection starts, or |
18 /// `null` if the selection does not start within this chunk. | 18 /// `null` if the selection does not start within this chunk. |
(...skipping 105 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
124 /// However, this getter does not expose that. It will return `false` if the | 124 /// However, this getter does not expose that. It will return `false` if the |
125 /// chunk is still indeterminate. | 125 /// chunk is still indeterminate. |
126 bool get isDouble => _isDouble != null ? _isDouble : false; | 126 bool get isDouble => _isDouble != null ? _isDouble : false; |
127 bool _isDouble; | 127 bool _isDouble; |
128 | 128 |
129 /// If `true`, then the line after this chunk should always be at column | 129 /// If `true`, then the line after this chunk should always be at column |
130 /// zero regardless of any indentation or expression nesting. | 130 /// zero regardless of any indentation or expression nesting. |
131 /// | 131 /// |
132 /// Used for multi-line strings and commented out code. | 132 /// Used for multi-line strings and commented out code. |
133 bool get flushLeft => _flushLeft; | 133 bool get flushLeft => _flushLeft; |
134 bool _flushLeft; | 134 bool _flushLeft = false; |
| 135 |
| 136 /// If `true`, then the line after this chunk and its contained block should |
| 137 /// be flush left. |
| 138 bool get flushLeftAfter { |
| 139 if (blockChunks.isEmpty) return _flushLeft; |
| 140 |
| 141 return blockChunks.last.flushLeftAfter; |
| 142 } |
135 | 143 |
136 /// Whether this chunk should append an extra space if it does not split. | 144 /// Whether this chunk should append an extra space if it does not split. |
137 /// | 145 /// |
138 /// This is `true`, for example, in a chunk that ends with a ",". | 146 /// This is `true`, for example, in a chunk that ends with a ",". |
139 bool get spaceWhenUnsplit => _spaceWhenUnsplit; | 147 bool get spaceWhenUnsplit => _spaceWhenUnsplit; |
140 bool _spaceWhenUnsplit = false; | 148 bool _spaceWhenUnsplit = false; |
141 | 149 |
142 /// Whether this chunk marks the end of a range of chunks that can be line | 150 /// Whether this chunk marks the end of a range of chunks that can be line |
143 /// split independently of the following chunks. | 151 /// split independently of the following chunks. |
144 bool get canDivide { | 152 bool get canDivide { |
(...skipping 141 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
286 static const singleElementList = 2; | 294 static const singleElementList = 2; |
287 | 295 |
288 /// Splitting the internals of literal block arguments. | 296 /// Splitting the internals of literal block arguments. |
289 /// | 297 /// |
290 /// Used to prefer splitting at the argument boundary over splitting the | 298 /// Used to prefer splitting at the argument boundary over splitting the |
291 /// block contents. | 299 /// block contents. |
292 static const splitBlocks = 2; | 300 static const splitBlocks = 2; |
293 | 301 |
294 /// Splitting before a type argument or type parameter. | 302 /// Splitting before a type argument or type parameter. |
295 static const typeArgument = 4; | 303 static const typeArgument = 4; |
296 | |
297 /// The cost of a single character that goes past the page limit. | |
298 /// | |
299 /// This cost is high to ensure any solution that fits in the page is | |
300 /// preferred over one that does not. | |
301 static const overflowChar = 1000; | |
302 } | 304 } |
303 | 305 |
304 /// The in-progress state for a [Span] that has been started but has not yet | 306 /// The in-progress state for a [Span] that has been started but has not yet |
305 /// been completed. | 307 /// been completed. |
306 class OpenSpan { | 308 class OpenSpan { |
307 /// Index of the first chunk contained in this span. | 309 /// Index of the first chunk contained in this span. |
308 int get start => _start; | 310 int get start => _start; |
309 int _start; | 311 int _start; |
310 | 312 |
311 /// The cost applied when the span is split across multiple lines or `null` | 313 /// The cost applied when the span is split across multiple lines or `null` |
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
357 /// output. This way, commented out chunks of code do not get erroneously | 359 /// output. This way, commented out chunks of code do not get erroneously |
358 /// re-indented. | 360 /// re-indented. |
359 final bool flushLeft; | 361 final bool flushLeft; |
360 | 362 |
361 /// Whether this comment is an inline block comment. | 363 /// Whether this comment is an inline block comment. |
362 bool get isInline => linesBefore == 0 && !isLineComment; | 364 bool get isInline => linesBefore == 0 && !isLineComment; |
363 | 365 |
364 SourceComment(this.text, this.linesBefore, | 366 SourceComment(this.text, this.linesBefore, |
365 {this.isLineComment, this.flushLeft}); | 367 {this.isLineComment, this.flushLeft}); |
366 } | 368 } |
OLD | NEW |