• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

iconara / ione / 165
99%

Build:
DEFAULT BRANCH: master
Ran 11 Dec 2014 10:48PM UTC
Jobs 5
Files 13
Run time 9min
Badge
Embed ▾
README BADGES
x

If you need to use a raster PNG badge, change the '.svg' to '.png' in the link

Markdown

Textile

RDoc

HTML

Rst

pending completion
165

Pull #23

travis-ci

Gustav Munkby
Proof-of-concept destructive future combinators

Implement destructive versions of the combinators, that updates the
existing future rather than creating a new one. The new combinators
ought to be thread-safe, but interleaving destructive updates might
produce counter-intuitive results sometimes. However, the common use
case seems to be synchronous construction of an asynchronous future
chain, in which case these combinators might reduce memory footprint
and call stack depth.

This is made possible by not resolving a future until after the
callbacks have completed. This is obviously a backwards-incompatible
change, as it causes any code with a `#value` in a callback to hang
indefinitely.

An obvious alternative would be to treat "transformations" and
"callbacks" separately, but I tried to avoid introducing further
bookkeeping surrounding the callbacks. 

Another advantage of keeping callbacks and transformations in a list
is that synchronous transformations behave as expected. That is, if
you add a listener before and after a `map!` is applied, the first
callback will receive the unmapped value, and the second callback will
receive the transformed value.

The future chaining transformations (`flat_map`, `then` and `fallback`)
requires some way to stop the listener dispatch in order to implement
the destructive versions. Here, this is accomplished by using the
return value of the listener callback. There is probably a better way
to get the same effect. To avoid breaking existing callbacks, this was
separated into the `on_complete!` callback.

To avoid too much code duplication, the non-destructive operation `foo`
is implemented using `dup.foo!`, similar to how non-destructive array
operations can be implemented. Not quite sure `dup` is the right name
for the newly constructed future (observing on the original), though.

I made some minor adjustments to the remaining code to get the future
specs to pass, but these are probably not 100% correct.

I have ... (continued)
Pull Request #23:

4 of 4 new or added lines in 1 file covered. (100.0%)

2389 of 2393 relevant lines covered (99.83%)

8608.26 hits per line

Jobs
ID Job ID Ran Files Coverage
1 165.1 (1.9.3) 11 Dec 2014 10:48PM UTC 0
98.65
Travis Job 165.1
2 165.2 (2.0.0) 11 Dec 2014 10:50PM UTC 0
99.03
Travis Job 165.2
3 165.3 (2.1.1) 11 Dec 2014 10:53PM UTC 0
99.03
Travis Job 165.3
4 165.4 (jruby) 11 Dec 2014 10:54PM UTC 0
98.61
Travis Job 165.4
5 165.5 (jruby-head) 11 Dec 2014 10:57PM UTC 0
0.0
Travis Job 165.5
Source Files on build 165
Detailed source file information is not available for this build.
  • Back to Repo
  • Travis Build #165
  • Pull Request #23
  • Next Build on master (#166)
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc