0 purchases
xrange
This is a fork of Interval library
XRange lib #
Provides the Range class, a contiguous set of values, and the NumRange class, that along with functionality of
Range class can also generate values of arithmetic progression in a specific diapason.
If a range contains two values, it also contains all values between them. It may have an upper and lower bound,
and those bounds may be open or closed.
Also the library contains integers generator function, that is based on NumRange class. It produces integer values
from a specific closed diapason.
Usage #
Range #
import 'package:xrange/xrange.dart';
void main() {
final date1 = DateTime(2015);
final date2 = DateTime(2221);
final dates = Range<DateTime>.closed(date1, date2);
if (dates.contains(DateTime.now())) {
print('Hi, contemporary!');
} else {
print('Apparently, you are from the future!');
}
}
copied to clipboard
NumRange #
import 'package:xrange/xrange.dart';
void main() {
final range = NumRange.closed(-10, 10);
for (final value in range.values(step: 2)) {
print(value); // it yields numbers from -10 to 10 with step equals 2
}
}
copied to clipboard
Pay attention to values method - it is a generator function, so use all the benefits of this.
integers #
import 'package:xrange/xrange.dart';
void main() {
for (final value in integers(-10, 10)) {
print(value); // it yields numbers from -10 to 10 with step equals 2
}
}
copied to clipboard
The integers function returns a lazy iterable, thus it consumes little memory, since the whole collection is not
being generated when integers is called.
For personal and professional use. You cannot resell or redistribute these repositories in their original state.
There are no reviews.