Skip to content

A set of builders that create streams of java.time objects

License

Notifications You must be signed in to change notification settings

tginsberg/java-timestream

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Java-Timestream

A set of builders that create streams of java.time objects.

To use this library in your project, add this to your dependencies:

<dependency>
    <groupId>com.ginsberg</groupId>
    <artifactId>java-timestream</artifactId>
    <version>1.1.0</version>
</dependency>

These are fully functional streams, so you can use them like any other stream, once created.

The lack of a convenient takeWhile(Predicate<T> predicate) method in Java 8 is what led to the creation of this library. Now that Java 9 has Stream.takeWhile() support, there is no reason to add this as a dependency.

This library can create streams of the following java.time classes:

  • LocalDate via LocalDateStream
  • LocalDateTime via LocalDateTimeStream
  • YearMonth via YearMonthStream
  • ZonedDateTime via ZoneDateTimeStream

And has support for...

  • Inclusive end point (to)
  • Exclusive end point (until)
  • Configurable period between stream elements (every)
  • Streams can move forward or backward through time
  • Infinite streams (by not providing an end point)

Usage

Every builder needs a non-null point in time to begin the stream. Therefore, each builder can be created using one of two methods:

  • .fromNow() - Assumes 'now'
  • .from(T from) - Type-specific starting point, provided by caller

To set the optional point in time where the stream ends (inclusive) you can call one of two methods:

  • .to(T to) - Type-specific end point. Can be null to indicate forever
  • .to(amount, units) - Where amount is a positive integer (for forward through time) or a negative integer (for backward through time), and unit is a valid ChronoUnit

To make the optional end of the stream exclusive, you can call one of two methods:

  • .until(T to) - Type-specific end point. Can be null to indicate forever
  • .until(amount, units) - Where amount is a positive integer (for forward through time) or a negative integer (for backward through time), and unit is a valid ChronoUnit

To indicate how much time should be skipped in each iteration:

  • .every(amount, units) - Where amount is an integer representing the number of units, and unit is a valid ChronoUnit
  • .every(period) - Where period is a valid Period object. (Supported on LocalDateStream and YearMonthStream only).
  • .every(duration) - Where duration is a valid Duration object. (Supported on everything other than LocalDateStream and YearMonthStream).

Note that providing an end time (via to or until) is optional. In that case, the stream will have no end and should produce values until you stop it.

Examples

Create a stream of LocalDateTime objects, between now and hour from now, every two minutes:

final Stream<LocalDateTime> stream = LocalDateTimeStream
        .fromNow()
        .to(1, ChronoUnit.HOURS)
        .every(2, ChronoUnit.MINUTES)
        .stream();

Or (equivalent):

final Stream<LocalDateTime> stream = LocalDateTimeStream
        .from(LocalDateTime.now())
        .to(LocalDateTime.now().plusHours(1))
        .every(2, ChronoUnit.MINUTES)
        .stream();

Create a stream of YearMonth objects from today, to a year ago (backward through time), stopping before the end (exclusive), every month:

final Stream<YearMonth> stream = YearMonthStream
        .fromNow()
        .until(-12, ChronoUnit.MONTHS)
        .every(1, ChronoUnit.MONTHS) // This is the default
        .stream();

Replace this code that does something with every minute of time over the last hour, going backwards:

final LocalDateTime end = LocalDateTime.now().minusHours(1);
LocalDateTime when = LocalDateTime.now();

while(when.isAfter(end)) {
    doSomething(when);
    when = when.minusMinutes(1);
}

... with this:

LocalDateTimeStream
    .fromNow()
    .until(-1, ChronoUnit.HOURS)
    .every(1, ChronoUnit.MINUTES)
    .stream()
    .forEach(this::doSomething);

It's not less code, but it certainly makes it easier to understand.

There are also plenty of examples in the unit tests.

Contributing and Issues

Please feel free to file issues for change requests or bugs. If you would like to contribute new functionality, please contact me first!

About

A set of builders that create streams of java.time objects

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages