// Copyright 2014 The Flutter Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. // @dart = 2.8 import 'bitfield.dart' as bitfield; /// The dart:io implementation of [bitfield.kMaxUnsignedSMI]. const int kMaxUnsignedSMI = 0x3FFFFFFFFFFFFFFF; /// The dart:io implementation of [bitfield.Bitfield]. class BitField<T extends dynamic> implements bitfield.BitField<T> { /// The dart:io implementation of [bitfield.Bitfield()]. BitField(this._length) : assert(_length <= _smiBits), _bits = _allZeros; /// The dart:io implementation of [bitfield.Bitfield.filled]. BitField.filled(this._length, bool value) : assert(_length <= _smiBits), _bits = value ? _allOnes : _allZeros; final int _length; int _bits; static const int _smiBits = 62; // see https://www.dartlang.org/articles/numeric-computation/#smis-and-mints static const int _allZeros = 0; static const int _allOnes = kMaxUnsignedSMI; // 2^(_kSMIBits+1)-1 @override bool operator [](T index) { final int _index = index.index as int; assert(_index < _length); return (_bits & 1 << _index) > 0; } @override void operator []=(T index, bool value) { final int _index = index.index as int; assert(_index < _length); if (value) _bits = _bits | (1 << _index); else _bits = _bits & ~(1 << _index); } @override void reset([ bool value = false ]) { _bits = value ? _allOnes : _allZeros; } }