Index: dart_style/lib/src/nesting_level.dart |
diff --git a/dart_style/lib/src/nesting_level.dart b/dart_style/lib/src/nesting_level.dart |
deleted file mode 100644 |
index 4e749836ae31170b1812a4cf3a34319c6d9b520a..0000000000000000000000000000000000000000 |
--- a/dart_style/lib/src/nesting_level.dart |
+++ /dev/null |
@@ -1,78 +0,0 @@ |
-// Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file |
-// for details. All rights reserved. Use of this source code is governed by a |
-// BSD-style license that can be found in the LICENSE file. |
- |
-library dart_style.src.nesting_level; |
- |
-import 'fast_hash.dart'; |
- |
-/// A single level of expression nesting. |
-/// |
-/// When a line is split in the middle of an expression, this tracks the |
-/// context of where in the expression that split occurs. It ensures that the |
-/// [LineSplitter] obeys the expression nesting when deciding what column to |
-/// start lines at when split inside an expression. |
-/// |
-/// Each instance of this represents a single level of expression nesting. If we |
-/// split at to chunks with different levels of nesting, the splitter ensures |
-/// they each get assigned to different columns. |
-/// |
-/// In addition, each level has an indent. This is the number of spaces it is |
-/// indented relative to the outer expression. It's almost always |
-/// [Indent.expression], but cascades are special magic snowflakes and use |
-/// [Indent.cascade]. |
-class NestingLevel extends FastHash { |
- /// The nesting level surrounding this one, or `null` if this is represents |
- /// top level code in a block. |
- NestingLevel get parent => _parent; |
- NestingLevel _parent; |
- |
- /// The number of characters that this nesting level is indented relative to |
- /// the containing level. |
- /// |
- /// Normally, this is [Indent.expression], but cascades use [Indent.cascade]. |
- final int indent; |
- |
- /// The total number of characters of indentation from this level and all of |
- /// its parents, after determining which nesting levels are actually used. |
- /// |
- /// This is only valid during line splitting. |
- int get totalUsedIndent => _totalUsedIndent; |
- int _totalUsedIndent; |
- |
- bool get isNested => _parent != null; |
- |
- NestingLevel() : indent = 0; |
- |
- NestingLevel._(this._parent, this.indent); |
- |
- /// Creates a new deeper level of nesting indented [spaces] more characters |
- /// that the outer level. |
- NestingLevel nest(int spaces) => new NestingLevel._(this, spaces); |
- |
- /// Clears the previously calculated total indent of this nesting level. |
- void clearTotalUsedIndent() { |
- _totalUsedIndent = null; |
- if (_parent != null) _parent.clearTotalUsedIndent(); |
- } |
- |
- /// Calculates the total amount of indentation from this nesting level and |
- /// all of its parents assuming only [usedNesting] levels are in use. |
- void refreshTotalUsedIndent(Set<NestingLevel> usedNesting) { |
- if (_totalUsedIndent != null) return; |
- |
- _totalUsedIndent = 0; |
- |
- if (_parent != null) { |
- _parent.refreshTotalUsedIndent(usedNesting); |
- _totalUsedIndent += _parent.totalUsedIndent; |
- } |
- |
- if (usedNesting.contains(this)) _totalUsedIndent += indent; |
- } |
- |
- String toString() { |
- if (_parent == null) return indent.toString(); |
- return "$parent:$indent"; |
- } |
-} |