W3cubDocs

/Dart 2

single property

E single
override

Checks that this iterable has only one element, and returns that element.

Throws a StateError if this is empty or has more than one element.

Implementation

E get single {
  // Note that this throws correctly if the queue is empty
  // because reading the element of the sentinel throws.
  if (identical(_sentinel._nextLink, _sentinel._previousLink)) {
    _DoubleLinkedQueueEntry<E> entry = _sentinel._nextLink;
    return entry._element;
  }
  throw IterableElementError.tooMany();
}

© 2012 the Dart project authors
Licensed under the Creative Commons Attribution-ShareAlike License v4.0.
https://api.dart.dev/stable/2.5.0/dart-collection/DoubleLinkedQueue/single.html