| OLD | NEW |
| 1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2015, 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.fast_hash; | 5 library dart_style.src.fast_hash; |
| 6 | 6 |
| 7 /// A mixin for classes with identity equality that need to be frequently | 7 /// A mixin for classes with identity equality that need to be frequently |
| 8 /// hashed. | 8 /// hashed. |
| 9 abstract class FastHash { | 9 abstract class FastHash { |
| 10 static int _nextId = 0; | 10 static int _nextId = 0; |
| 11 | 11 |
| 12 /// A semi-unique numeric indentifier for the object. | 12 /// A semi-unique numeric indentifier for the object. |
| 13 /// | 13 /// |
| 14 /// This is useful for debugging and also speeds up using the object in hash | 14 /// This is useful for debugging and also speeds up using the object in hash |
| 15 /// sets. Ids are *semi*-unique because they may wrap around in long running | 15 /// sets. Ids are *semi*-unique because they may wrap around in long running |
| 16 /// processes. Since objects are equal based on their identity, this is | 16 /// processes. Since objects are equal based on their identity, this is |
| 17 /// innocuous and prevents ids from growing without bound. | 17 /// innocuous and prevents ids from growing without bound. |
| 18 final int id = _nextId = (_nextId + 1) & 0x0fffffff; | 18 final int id = _nextId = (_nextId + 1) & 0x0fffffff; |
| 19 | 19 |
| 20 int get hashCode => id; | 20 int get hashCode => id; |
| 21 } | 21 } |
| OLD | NEW |