Project

linda

0.0
No commit activity in last 3 years
No release in over 3 years
Tuple and TupleSpace implementation of Linda - coordinational language for parallel processing
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.3
>= 0

Runtime

>= 0
 Project Readme

Linda

Tuple and TupleSpace implementation of Linda

Installation

% gem install linda

Linda

Linda is a coordination launguage for parallel programming.

Usage

Linda rubygem provides

  • on-memory Tuple/TupleSpace implementation
  • common tests for your Linda implementation, such as using KVS or RDB

Sinatra::RocketIO::Linda is using Linda rubygem inside.

Tuple Matching

Array Tuple [1, 2, 3]

  • matches [1, 2, 3]
  • matches [1, 2, 3, 4]
  • matches [1, 2, 3, "a"]
  • NOT matches [1, 2, "a"]
  • NOT matches [2, 1, 3]
Linda::Tuple.new([1, 2]).match? [1, 2, 3]  # => true
Linda::Tuple.new([1, 2]).match? [1, "a"]   # => false

Hash Tuple {:a => 1, :b => 2}

  • matches {:a => 1, :b => 2}
  • matches {:a => 1, :b => 2, :c => 3}
  • matches {:a => 1, :b => 2, :name => "shokai"}
  • NOT matches {:a => 1, :b => 5}
Linda::Tuple.new(:a => 1, :b => 2).match?(:a => 1, :b => 2, :name => "shokai")  # => true
Linda::Tuple.new(:a => 1, :b => 2).match?(:a => 1, :b => 5)  # => false

Tuple/TupleSpace Functions

TupleSpace#write(tuple, options={})

  • write a Tuple into TupleSpace.
  • default : options = {:expire => 300}
    • expire 300(sec) after.
  • similar to out function in C-Linda.

TupleSpace#read(tuple)

  • return a Tuple which matches in TupleSpace. return nil if not exists.
  • similar to rdp function in C-Linda.

TupleSpace#read(tuple, &callback(tuple))

  • callback a Tuple which matches in TupleSpace. wait until available.
  • async function : it does not return a value.
  • similar to rd function in C-Linda.

TupleSpace#take(tuple)

  • delete a Tuple, then return it which matches in TupleSpace. return nil if not exists.
  • similar to inp function in C-Linda.

TupleSpace#take(tuple, &callback(tuple))

  • delete a Tuple, then callback it which matches in TupleSpace. wait until available.
  • async function : it does not return a value.
  • similar to in function in C-Linda.

TupleSpace#watch(tuple, &callback(tuple))

  • callback Tuples which matches when TupleSpace#write(tuple) is called.

TupleSpace#cancel(callback_id)

  • remove read/take/watch callback by Callback-ID.

TupleSpace#list(tuple)

  • return list(Array) of Tuples they matches in TupleSpace. return empty Array [] if not matches.

Test your Linda implementation

with minitest.

Test Tuple

test/test_tuple.rb

require 'rubygems'
require 'minitest/autorun'
require 'linda/test/tuple'
require 'path/to/my/linda/tuple'  # load your Tuple class

class TestMyTuple < MiniTest::Test
  include Linda::Test::Tuple      # mix-in test code

  def target_tuple
    My::Linda::Tuple              # set your Tuple class name
  end
end
% ruby test/test_tuple.rb

Test TupleSpace

test/test_tuplespace.rb

require 'rubygems'
require 'minitest/autorun'
require 'linda/test/tuplespace'
require 'path/to/my/linda/tuple'       # load your Tuple class
require 'path/to/my/linda/tuplespace'  # load your TupleSpace class

class TestMyTupleSpace < MiniTest::Test
  include Linda::Test::TupleSpace      # mix-in test code

  def target_tuple
    My::Linda::Tuple                   # set your Tuple class name
  end

  def target_tuplespace
    My::Linda::TupleSpace              # set your TupleSpace class name
  end
end
% ruby test/test_tuplespace.rb

Rake

Rakefile

require "rake/testtask"

Rake::TestTask.new do |t|
  t.pattern = "test/test_*.rb"
end

task :default => :test
% rake test

=> run all tests

Test

test this gem

% gem install bundler
% bundle install
% rake test

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request