| OLD | NEW |
| 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 // This file contains the node classes for the internal representations of YAML | 5 // This file contains the node classes for the internal representations of YAML |
| 6 // documents. These nodes are used for both the serialization tree and the | 6 // documents. These nodes are used for both the serialization tree and the |
| 7 // representation graph. | 7 // representation graph. |
| 8 | 8 |
| 9 /** A tag that indicates the type of a YAML node. */ | 9 /** A tag that indicates the type of a YAML node. */ |
| 10 class _Tag { | 10 class _Tag { |
| (...skipping 128 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 139 * Returns the canonical serialization of the value of the scalar. If the | 139 * Returns the canonical serialization of the value of the scalar. If the |
| 140 * value isn't given, the result of this will be "null". | 140 * value isn't given, the result of this will be "null". |
| 141 */ | 141 */ |
| 142 String get canonicalContent { | 142 String get canonicalContent { |
| 143 if (value == null || value is bool || value is int) return '$value'; | 143 if (value == null || value is bool || value is int) return '$value'; |
| 144 | 144 |
| 145 if (value is num) { | 145 if (value is num) { |
| 146 // 20 is the maximum value for this argument, which we use since YAML | 146 // 20 is the maximum value for this argument, which we use since YAML |
| 147 // doesn't specify a maximum. | 147 // doesn't specify a maximum. |
| 148 return value.toStringAsExponential(20). | 148 return value.toStringAsExponential(20). |
| 149 replaceFirst(const RegExp("0+e"), "e"); | 149 replaceFirst(new RegExp("0+e"), "e"); |
| 150 } | 150 } |
| 151 | 151 |
| 152 if (value is String) { | 152 if (value is String) { |
| 153 // TODO(nweiz): This could be faster if we used a RegExp to check for | 153 // TODO(nweiz): This could be faster if we used a RegExp to check for |
| 154 // special characters and short-circuited if they didn't exist. | 154 // special characters and short-circuited if they didn't exist. |
| 155 | 155 |
| 156 var escapedValue = value.charCodes.map((c) { | 156 var escapedValue = value.charCodes.map((c) { |
| 157 switch (c) { | 157 switch (c) { |
| 158 case _Parser.TAB: return "\\t"; | 158 case _Parser.TAB: return "\\t"; |
| 159 case _Parser.LF: return "\\n"; | 159 case _Parser.LF: return "\\n"; |
| (...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 229 String toString() { | 229 String toString() { |
| 230 var strContent = Strings.join(content.keys. | 230 var strContent = Strings.join(content.keys. |
| 231 map((k) => '${k}: ${content[k]}'), ', '); | 231 map((k) => '${k}: ${content[k]}'), ', '); |
| 232 return '$tag {$strContent}'; | 232 return '$tag {$strContent}'; |
| 233 } | 233 } |
| 234 | 234 |
| 235 int get hashCode => super.hashCode ^ _hashCode(content); | 235 int get hashCode => super.hashCode ^ _hashCode(content); |
| 236 | 236 |
| 237 visit(_Visitor v) => v.visitMapping(this); | 237 visit(_Visitor v) => v.visitMapping(this); |
| 238 } | 238 } |
| OLD | NEW |