Build Status Coverage Status pub package Gitter Chat

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!');
  }
}

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
  }
}

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
  }
}

The integers function returns a lazy iterable, thus it consumes little memory, since the whole collection is not being generated when integers is called.

Libraries

xrange