Merge branch 'master' of git://github.com/jimm/mongo-ruby-driver

This commit is contained in:
Adrian Madrid 2008-12-08 14:46:59 -07:00
commit af8364db7a
5 changed files with 57 additions and 10 deletions

15
README
View File

@ -52,18 +52,18 @@ type
= To Do = To Do
* Support more types: REGEX, etc. * Implement Babble's algorithm for ObjectID. Implement Comparable.
* Study src/main/ed/db/{dbcollection,dbcursor,db}.js in the Babble code. * Change find(selector={}, fields=nil, options={}) to find(selector={},
That's what I should be writing to. options={})
* ObjectID equality.
* Capped collection support. * Capped collection support.
* More code comments. More text in this file. * More code comments. More text in this file.
* Rake task for rdoc generation. * Support more types: REF, SYMBOL, CODE_W_SCOPE, etc.
* Remove default _id generation.
* Introduce optional per-database and per-collection PKInjector. * Introduce optional per-database and per-collection PKInjector.
@ -73,7 +73,8 @@ type
* Implement Admin. * Implement Admin.
* See FIXME in db test. * Study src/main/ed/db/{dbcollection,dbcursor,db}.js and ByteEncoder.java in
the Babble code. That's what I should be writing to.
= Credits = Credits

View File

@ -22,6 +22,8 @@ module XGen
include Comparable include Comparable
include Comparable
@@uuid_generator = UUID.new @@uuid_generator = UUID.new
# String UUID # String UUID
@ -38,6 +40,8 @@ module XGen
@uuid @uuid
end end
# This will make more sense when we implement the Babble algorithm for
# generating object ids.
def <=>(other) def <=>(other)
to_s <=> other.to_s to_s <=> other.to_s
end end

View File

@ -59,6 +59,8 @@ class BSON
serialize_oid_element(@buf, k, v) serialize_oid_element(@buf, k, v)
when ARRAY when ARRAY
serialize_array_element(@buf, k, v) serialize_array_element(@buf, k, v)
when REGEX
serialize_regex_element(@buf, k, v)
when BOOLEAN when BOOLEAN
serialize_boolean_element(@buf, k, v) serialize_boolean_element(@buf, k, v)
when DATE when DATE
@ -97,6 +99,9 @@ class BSON
when ARRAY when ARRAY
key = deserialize_element_name(@buf) key = deserialize_element_name(@buf)
doc[key] = deserialize_array_data(@buf) doc[key] = deserialize_array_data(@buf)
when REGEX
key = deserialize_element_name(@buf)
doc[key] = deserialize_regex_data(@buf)
when OBJECT when OBJECT
key = deserialize_element_name(@buf) key = deserialize_element_name(@buf)
doc[key] = deserialize_object_data(@buf) doc[key] = deserialize_object_data(@buf)
@ -162,6 +167,16 @@ class BSON
a a
end end
def deserialize_regex_data(buf)
str = deserialize_element_name(buf)
options_str = deserialize_element_name(buf)
options = 0
options |= Regexp::IGNORECASE if options_str.include?('i')
options |= Regexp::MULTILINE if options_str.include?('m')
options |= Regexp::EXTENDED if options_str.include?('x')
Regexp.new(str, options)
end
def deserialize_string_data(buf) def deserialize_string_data(buf)
len = buf.get_int len = buf.get_int
bytes = buf.get(len) bytes = buf.get(len)
@ -220,6 +235,21 @@ class BSON
serialize_object_element(buf, key, h, ARRAY) serialize_object_element(buf, key, h, ARRAY)
end end
def serialize_regex_element(buf, key, val)
buf.put(REGEX)
self.class.serialize_cstr(buf, key)
str = val.to_s.sub(/.*?:/, '')[0..-2] # Turn "(?xxx:yyy)" into "yyy"
self.class.serialize_cstr(buf, str)
options = val.options
options_str = ''
options_str << 'i' if ((options & Regexp::IGNORECASE) != 0)
options_str << 'm' if ((options & Regexp::MULTILINE) != 0)
options_str << 'x' if ((options & Regexp::EXTENDED) != 0)
self.class.serialize_cstr(buf, options_str)
end
def serialize_oid_element(buf, key, val) def serialize_oid_element(buf, key, val)
buf.put(OID) buf.put(OID)
self.class.serialize_cstr(buf, key) self.class.serialize_cstr(buf, key)
@ -274,6 +304,8 @@ class BSON
key == "$where" ? CODE : STRING key == "$where" ? CODE : STRING
when Array when Array
ARRAY ARRAY
when Regexp
REGEX
when XGen::Mongo::Driver::ObjectID when XGen::Mongo::Driver::ObjectID
OID OID
when true, false when true, false

View File

@ -7,8 +7,8 @@ require 'test/unit'
class DBAPITest < Test::Unit::TestCase class DBAPITest < Test::Unit::TestCase
def setup def setup
host = ENV['HOST'] || ENV['host'] || 'localhost' host = ENV['MONGO_RUBY_DRIVER_HOST'] || 'localhost'
port = ENV['PORT'] || ENV['port'] || 27017 port = ENV['MONGO_RUBY_DRIVER_PORT'] || XGen::Mongo::Driver::Mongo::DEFAULT_PORT
@db = XGen::Mongo::Driver::Mongo.new(host, port).db('ruby-mongo-test') @db = XGen::Mongo::Driver::Mongo.new(host, port).db('ruby-mongo-test')
@coll = @db.collection('test') @coll = @db.collection('test')
@coll.clear @coll.clear
@ -186,6 +186,14 @@ class DBAPITest < Test::Unit::TestCase
assert_equal [1, 2, 3], rows[0]['b'] assert_equal [1, 2, 3], rows[0]['b']
end end
def test_regex
regex = /foobar/i
@coll << {'b' => regex}
rows = @coll.find({}, {'b' => 1}).collect
assert_equal 1, rows.length
assert_equal regex, rows[0]['b']
end
private private
def new_oid def new_oid

View File

@ -8,6 +8,8 @@ class DBConnectionTest < Test::Unit::TestCase
def test_no_exceptions def test_no_exceptions
host = ENV['HOST'] || ENV['host'] || 'localhost' host = ENV['HOST'] || ENV['host'] || 'localhost'
port = ENV['PORT'] || ENV['port'] || 27017 port = ENV['PORT'] || ENV['port'] || 27017
host = ENV['MONGO_RUBY_DRIVER_HOST'] || 'localhost'
port = ENV['MONGO_RUBY_DRIVER_PORT'] || XGen::Mongo::Driver::Mongo::DEFAULT_PORT
db = XGen::Mongo::Driver::Mongo.new(host, port).db('ruby-mongo-test') db = XGen::Mongo::Driver::Mongo.new(host, port).db('ruby-mongo-test')
coll = db.collection('test') coll = db.collection('test')
coll.clear coll.clear