Project

bud

0.32
No commit activity in last 3 years
No release in over 3 years
There's a lot of open issues
A prototype of the Bloom distributed programming language as a Ruby DSL.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
 Dependencies

Development

= 2.5.1

Runtime

= 3.8.0
= 1.5.5
= 1.4.3
= 1.1.0
= 2.4.4
= 3.10.1
= 1.2.2
= 2.3.8
 Project Readme

Build Status

Bud

This is Bud, a.k.a. "Bloom Under Development". It is an initial cut at a Bloom DSL, using Ruby as a setting.

See LICENSE for licensing information.

Language cheatsheet in docs/cheat.md ; see the docs/ directory for other documentation.

Main deficiencies at this point are:

  • No Ruby constraints: Within Bloom programs the full power of Ruby is also available, including mutable state. This allows programmers to get outside the Bloom framework and lose cleanliness.

  • Compatibility: Bud only works with Ruby (MRI) 1.8.7 and 1.9. Bud also has experimental support for Ruby 2.0. JRuby and other Ruby implementations are currently not supported.

Installation

To install the latest release:

% gem install bud

To build and install a new gem from the current development sources:

% gem build bud.gemspec ; gem install bud*.gem

Note that GraphViz must be installed.

Simple example programs can be found in examples. A much larger set of example programs and libraries can be found in the bud-sandbox repository.

To run the unit tests:

% gem install minitest      # unless already installed
% cd test; ruby ts_bud.rb

To run the unit tests and produce a code coverage report:

% gem install simplecov    # unless already installed
% cd test; COVERAGE=1 ruby ts_bud.rb

Optional Dependencies

The bud gem has a handful of mandatory dependencies. It also has one optional dependency: if you wish to use Bud collections backed by Zookeeper, the "zookeeper" gem must be installed.