Skip to content
forked from tbroyer/promises

Promises for Java – THIS PROJECT IS DEPRECATED!

Notifications You must be signed in to change notification settings

lukaci/promises

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

THIS PROJECT IS DEPRECATED!

Promises for Java Build Status

Promises for Java is a simple implementation of promises, based on the Promises/A+ proposal for JavaScript.

From that proposal:

A promise represents a value that may not be available yet. The primary method for interacting with a promise is its then method.

The goal is to simplify asynchronous flows, avoiding the so-called Callback Pyramid of Doom.

The major difference, besides strong type-checking brought/enforced by Java, is that the then method is not asynchronous: if the promise is already fulfilled or rejected, the callbacks will be called synchronously, before the method returns.

The implementation is inspired by Guava's Optional and SettableFuture, and includes a FuturePromise as a two-way bridge with Guava's ListenableFuture. The dependency on Guava is optional though (but then you won't bridge with futures).

License

Copyright 2013 Thomas Broyer

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

About

Promises for Java – THIS PROJECT IS DEPRECATED!

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 100.0%