Project

ione

0.19
Low commit activity in last 3 years
There's a lot of open issues
No release in over a year
Reactive programming framework for Ruby, painless evented IO, futures and an efficient byte buffer
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
 Dependencies
 Project Readme

Ione

Build Status Coverage Status Blog

If you're reading this on GitHub, please note that this is the readme for the development version and that some features described here might not yet have been released. You can find the readme for a specific version either through rubydoc.info or via the release tags (here is an example).

Ione is a framework for reactive programming in Ruby. It is based on the reactive core of cql-rb, the Ruby driver for Cassandra.

Features

Futures & promises

At the core of Ione is a futures API. Futures make it easy to compose asynchronous operations.

Evented IO

A key piece of the framework is an IO reactor with which you can easily build network clients and servers.

Byte buffer

Networking usually means pushing lots of bytes around and in Ruby it's easy to make the mistake of using strings as buffers. Ione provides an efficient byte buffer implementation as an alternative.

Examples

The examples directory has some examples of what you can do with Ione, for example:

  • redis_client is a more or less full featured Redis client that uses most of Ione's features.
  • http_client is a simplistic HTTP client that uses Ione and http_parser.rb to make HTTP GET request. It also shows how to make TLS connections.
  • cql-rb is a high performance Cassandra driver and where Ione was originally developed.
  • cassandra-driver is the successor to cql-rb.
  • ione-rpc is a RPC framework built on Ione. It makes it reasonably easy to build networked applications without having to reinvent the wheel.

How to contribute

See CONTRIBUTING.md

Copyright

Copyright 2013–2014 Theo Hultberg/Iconara and contributors.

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.