ffi-gdbm

An attempt to make gdbm available beyond the C Ruby implementation.

Faithfully mimics MRI's standard library and is compatible with gdbm files produced by that version.

Installing

You can download and use gdbm.rb anyhow you would like.

You can also install it using Ruby Gems:

gem install ffi-gdbm

or, if using JRuby:

jgem install gdbm

JRuby does not require further installation, but Rubinius will need the FFI gem:

gem install ffi

Notes

  • Conforms to tests from MRI 1.8.7 and 1.9.1 and follows the C library for MRI if there are contradictions with the documentation
  • Should be compatible with gdbm files created with MRI's standard library
  • Certainly works with JRuby, may work with other alternative Ruby implementations

Status

Tests passing on 64 bit Linux with

  • JRuby 1.7.21 and 9.1.7.0

Older Tests

Passing all tests with JRuby 1.4, 1.5.3, 1.6 on 32-bit Linux.

Passing all tests with MRI Ruby 1.8.7, 1.9.1, 1.9.2 with Ruby-FFI 0.5.4, 0.6.3, 1.0.7 on 32-bit Linux.

Further testing on other systems is welcome!

Testing

Two sets of tests are included, copied straight from the MRI distribution. However, they do require the use of ObjectSpace, so this is how to run them with JRuby:

jruby --1.8 -X+O -r lib/gdbm test/test_gdbm-1.8.7.rb (Note: these tests only work with JRuby prior to 9.0.0.0)

jruby -X+O -r ./lib/gdbm test/test_gdbm-1.9.1.rb

License

Copyright (c), Justin Collins

This library is released under the same tri-license (GPL/LGPL/CPL) as JRuby. Please see the COPYING file distributed with JRuby for details.