Kyle Banker
27b410f869
ReplSetConnection updates
2010-12-13 14:07:32 -05:00
Kyle Banker
08b7cddc81
Initial ReplSetConnection checking. Refactoring.
2010-12-10 16:00:35 -05:00
Kyle Banker
b63250e6e4
Fix for connections to replica sets with 1 secondary and 1 arbiter
2010-12-10 11:12:18 -05:00
Kyle Banker
03bf0a18de
minor: Collection#remove returns true on nonsafe remove
2010-12-02 12:47:50 -05:00
Kyle Banker
13a27771b0
minor: ensure_index fix for 1.9.1
2010-12-02 11:24:21 -05:00
Kyle Banker
9a8d83ad24
Tests for GridIO#each
2010-12-01 13:30:57 -05:00
Jonathan Tron
c80cd285fa
Add Mongo::GridIO#each which yield each chunks of a file, allowing Rack streaming
2010-12-01 12:55:55 -05:00
Kyle Banker
8fca10267a
BUMP 1.1.4
2010-11-30 12:50:28 -05:00
David A. Cuadrado
e4eca05447
optimize ObjectId#to_s
2010-11-30 12:46:04 -05:00
Kyle Banker
5930c500b4
RUBY-208 test for connection failure. Minor test fix.
2010-11-30 12:36:45 -05:00
Kyle Banker
f8ada701d9
BUMP 1.1.3
2010-11-29 17:05:41 -05:00
Kyle Banker
1a14156206
minor: cleanup
2010-11-29 14:06:38 -05:00
Kyle Banker
e621db732e
minor: cleanup
2010-11-24 14:01:26 -05:00
Daniel Cooper
df80704f77
Cursor#count now has optional argument to make it take notice of skip and limit
2010-11-24 13:51:05 -05:00
Kyle Banker
8aaed130d6
Cleanup for distributed reads on replica sets.
2010-11-24 13:49:34 -05:00
Kyle Banker
c5862da061
minor: test fix
2010-11-23 13:37:29 -05:00
Kyle Banker
add9779fa0
Select secondary read node randomly
2010-11-19 18:26:38 -05:00
Kyle Banker
1e57ca90e1
Initial commit for reads from rs secondaries
2010-11-16 15:43:59 -05:00
Kyle Banker
29dfe390c5
RUBY-196 tweaks to Collection#ensure_index
2010-11-11 17:41:31 -05:00
Matthew Rathbone
d33ddfb8e0
added ensure_index
2010-11-11 16:21:23 -05:00
Steve Shreeve
5e81cf2f82
simplify logic
2010-11-11 15:31:27 -05:00
Ryan Fitzgerald
4a1bccefae
implementing as_json for object id to return structure of mongoDB extended json
2010-11-11 15:26:06 -05:00
Ijonas Kisselbach
2188522687
removed argument type checks from Cursor.skip() and Cursor.limit() due to clash with JRuby's redefining of Integer
2010-11-11 15:20:08 -05:00
Steve Ardis
ffab7ba5a3
Fixed issue with grid.rb where 'put' was duplicating the filename attribute on the file
2010-11-11 15:18:52 -05:00
Evgeny Shadchnev
8c96f5d52f
removed batch_size accessor that's overridden by a method anyway
2010-11-11 15:08:24 -05:00
Evgeny Shadchnev
af0822f476
initializing query_run and closed before they are first used
2010-11-11 15:08:01 -05:00
Kyle Banker
b1fe3767f2
minor: formatting
2010-11-11 15:02:16 -05:00
Maz
a9a4b35841
Ensured that the C Driver will not be loaded unless the platform supports it--it will only be loaded on little endian
2010-11-11 15:00:41 -05:00
Kyle Banker
9d25efece4
Bug fix on Collection#rename
2010-11-09 13:45:33 -05:00
Kyle Banker
b4d5448179
Create index concurrency fix
2010-11-09 13:34:28 -05:00
Kyle Banker
ced3bfbfe8
Update and remove return error object in safe mode
2010-11-09 13:07:01 -05:00
Kyle Banker
8e79793053
BUMP 1.1.2 and HISTORY
2010-11-04 17:50:48 -04:00
Kyle Banker
8125e26c4d
minor: fix prev commit
2010-11-04 17:35:58 -04:00
Kyle Banker
c984af4ff0
Fixed bug passing :timeout to Cursor. Added tests.
2010-11-04 17:26:21 -04:00
Kyle Banker
8b1fbbb868
minor: cleanup
2010-11-03 19:02:03 -04:00
Kyle Banker
a2f501924e
Specify pk factory on Collection.new as a :pk option
2010-11-03 18:36:29 -04:00
Kyle Banker
68af3dbe8f
Allow the setting of safe mode globally on the Connection,
...
DB, and Collection levels. The safe mode setting will
automatically be inherited down the hierarchy Connection ->
DB -> Collection -> (insert, update, remove). This default
can be overridden at any time. Connection#safe, DB#safe, and
Collection#safe will yield the current default value.
2010-11-03 17:36:08 -04:00
Kyle Banker
f7d151c8dc
minor: doc fixes
2010-11-03 15:32:19 -04:00
Kyle Banker
d6f8f9d41a
Allow specification of replica set name on connect.
...
Raise ReplicaSetConnectionError if expected name doesn't match set.
2010-11-03 15:12:15 -04:00
Kyle Banker
5aa8721b25
Allow idiomatic :drop_dups in addition to :dropDups
...
on index creation.
Don't raise exception if :dropDups results in duplicate key error.
2010-11-02 14:50:02 -04:00
Kyle Banker
e21a4b897a
minor: extra rake tasks for tests. don't show C ext warning when testing
2010-11-02 14:25:14 -04:00
Kyle Banker
2939932526
close connection when safe mode insert results in 'not master'
2010-10-29 23:18:49 -04:00
Kyle Banker
424f08af5e
close connection on exception on safe insert
2010-10-29 17:52:15 -04:00
Kyle Banker
2720206f77
minor: docs
2010-10-22 13:27:56 -04:00
Kyle Banker
e416e05fc7
RUBY-190 bug fix for unavailable nodes on Connection#multi
2010-10-21 14:33:48 -04:00
Kyle Banker
a905c3f1f2
RUBY-191 fix to pass options to new db with Connection#db
2010-10-21 13:27:57 -04:00
Kyle Banker
afe8fe3167
RUBY-193 don't create gridfs indexes when slave_ok
2010-10-21 13:01:32 -04:00
Kyle Banker
68cadc1987
minor: patch for JRuby 1.9 MD5 comparison bug
2010-10-14 16:35:13 -04:00
Kyle Banker
f1ddd871f2
major: typo
2010-10-13 18:38:15 -04:00
Kyle Banker
80044b9a58
RUBY-187 All tests can now use custom host and port;
...
Minor test fixes.
2010-10-13 17:09:23 -04:00
Kyle Banker
cd03fafb27
RUBY-187 ByteBuffer should take another ByteBuffer as initial data
2010-10-13 17:08:45 -04:00
Kyle Banker
df0377c3d4
JRuby Test fixes
2010-10-12 15:39:28 -04:00
Kyle Banker
b0f2911170
BUMP 1.1.1
2010-10-07 17:59:12 -04:00
Kyle Banker
0c82f01d97
JRuby: validate key names and only move _id when necessary.
2010-10-07 17:42:39 -04:00
Kyle Banker
850159cd7c
BUMP 1.1
2010-10-04 15:19:14 -04:00
Kyle Banker
3a0cdf64af
remove deprecated support for implicit
2010-10-04 14:37:19 -04:00
Kyle Banker
b8d6f57602
A few more BSON fixes
2010-10-04 14:25:44 -04:00
Jari Bakken
112870b537
Get rid of missing parentheses warning.
2010-10-04 13:32:46 -04:00
Jari Bakken
9d2f3fbc27
Call super in BSON::OrderedHash#== instead of doing the comparison in Ruby.
...
This has a notable performance impact for large hashes.
2010-10-04 13:32:33 -04:00
Kyle Banker
b3ed1486e5
minor: updates for removal deprecated DB and Connection methods and ObjectID
2010-10-04 13:28:26 -04:00
Kyle Banker
bd4b6060f7
Removed deprecated DB methods
2010-10-04 12:16:40 -04:00
Kyle Banker
f7a97a0db0
Removed deprecated Connection methods
2010-10-04 12:16:11 -04:00
Kyle Banker
8dce3a613d
Removed deprecated ObjectID class (use ObjectId now)
2010-10-04 12:15:14 -04:00
Kyle Banker
bf10db9b21
minor: ObjectId optimization
2010-10-04 12:09:29 -04:00
Kyle Banker
7ad280c2cb
RUBY-184 Connection#locked?
2010-10-04 11:38:20 -04:00
Kyle Banker
c04dfec1db
Revert JRuby callback to use RubyBSONCallback
2010-10-01 13:57:16 -04:00
Kyle Banker
315e608cd4
Optimized callback class to return Java objects
2010-10-01 09:52:29 -04:00
Kyle Banker
2a7b089a9b
BSON for JRuby
2010-09-30 09:43:17 -04:00
Kyle Banker
4141331f79
RUBY-184 fsync lock helpers
2010-09-28 12:15:45 -04:00
Kyle Banker
a1565b3ac8
BUMP 1.0.9
2010-09-20 15:07:30 -04:00
Hongli Lai (Phusion)
b474b29d35
Optimize Mongo::Connection#receive_message_on_socket and #receive_and_discard_message_on_socket: avoid creating initial input buffer up front so that IO#read only needs to allocate the buffer once.
2010-09-14 10:37:08 -04:00
Hongli Lai (Phusion)
6316c939d5
Optimize Mongo::Connection#send_message_on_socket: don't slice the input when not necessary.
2010-09-14 10:36:54 -04:00
Hongli Lai (Phusion)
87e6d578c1
Optimize Mongo::Connection#add_message_headers by packing data directly instead of using ByteBuffer.
2010-09-14 10:36:40 -04:00
Kyle Banker
f494c9601d
minor: comment cleanup
2010-09-13 14:44:41 -04:00
Hongli Lai (Phusion)
0585aa1aae
Fix MongoDB::Collection #insert_documents, #update and #remove and MongoDB::Connection #receive_header and #last_error_message: usage strings as much as possible instead of byte arrays, otherwise performance really suffers.
2010-09-13 10:51:53 -04:00
Hongli Lai (Phusion)
264bddbeee
Fix reference to NULL_BYTE.
2010-09-13 10:51:44 -04:00
Hongli Lai (Phusion)
c8726ca150
Optimize MongoDB::Cursor#construct_query_message.
2010-09-13 10:51:15 -04:00
Hongli Lai (Phusion)
bde53f1e20
Optimize ByteBuffer: use binary string as underlying storage instead of array.
2010-09-13 10:51:02 -04:00
Hongli Lai (Phusion)
c6206eddf4
Optimize MongoDB::Connection#receive_response_header by using raw string operations and unpack() instead of the slower ByteBuffer.
2010-09-13 10:50:39 -04:00
Hongli Lai (Phusion)
e1bf168767
Optimize MongoDB::Connection#receive.
...
It doesn't do anything with the header. So instead of parsing the header,
just read the header data and discard it.
2010-09-13 10:50:25 -04:00
Hongli Lai (Phusion)
2291a59fcc
Optimize Mongo::Connection#read_documents by using raw string operations and unpack() instead of the slower ByteBuffer.
2010-09-13 10:50:16 -04:00
Hongli Lai (Phusion)
1c25541492
Optimize ByteBuffer#get_int.
2010-09-13 10:50:04 -04:00
Hongli Lai (Phusion)
026e409d6d
Optimize Ruby 1.8 implementation of BSON::OrderedHash.
...
The set in there is unnecessary. Use the hash itself as "set". This makes
BSON::OrderedHash 148% faster on Ruby 1.8.
2010-09-13 10:49:50 -04:00
Hongli Lai (Phusion)
117ce2389c
Optimize receive_message_on_socket for the optimistic average case where 1 socket.read() operation receives all requested data. Also fix some Ruby 1.9 encoding issues in that function while we're at it.
2010-09-13 10:48:32 -04:00
Mislav Marohnić
56f37e49b6
replace usage of returning
with each_with_object
...
`each_with_object` is a Ruby 1.9 method, here re-implemented in core_ext.rb
in case it's missing (for older Ruby versions). Using `returning` is bad in
combination with Ruby on Rails because each usage of the method will emit
a Rails deprecation warning. This might be considered an Active Support bug,
but it's better to avoid using `returning` altogether and use `tap` from
Ruby 1.8.7, also re-implemented here in case it's missing.
Since existing usages or `returning` were better suited for `each_with_object`
than `tap`, they were rewritten using the former instead.
2010-09-13 01:10:38 +08:00
Hongli Lai (Phusion)
b9de2eaa5c
When possible, have BSON::ByteBuffer store the underlying binary data as a binary String instead of an array.
...
This dramatically improves the performance of BSON::ByteBuffer.new(a_string).
On Ruby 1.9.2 it is about 130 times faster.
2010-09-09 15:59:17 -04:00
Kyle Banker
3a4134a5c2
RUBY-180 fixed failing test
2010-09-09 14:53:29 -04:00
Kyle Banker
e03ea6b690
minor: typo fix
2010-09-09 14:22:09 -04:00
Kyle Banker
36c71ef48e
RUBY-180 Fix batch size
2010-09-09 14:12:12 -04:00
Kyle Banker
b339871eb9
minor: #refresh instead of #refill_via_get_more
2010-09-08 14:34:28 -04:00
Kyle Banker
300b442a94
Create logging message only when a logger is passed to the Connection.
...
Results in a pretty significant performance improvement.
Many thanks to Matt Taylor for noticing the unusual glut of calls
to ObjectId#to_s. See here: http://unhalting.com/?p=18
2010-09-08 14:27:27 -04:00
Kyle Banker
c2955239a4
BUMP BSON 1.0.7
2010-08-28 20:08:50 -04:00
Kyle Banker
a867ddd341
BUMP BSON 1.0.6
2010-08-28 12:20:58 -04:00
Kyle Banker
2eaca6bc8e
RUBY-172 fix for OrderedHash#clone
2010-08-27 15:50:42 -04:00
Kyle Banker
dd8c79cfcb
BUMP 1.0.8
2010-08-27 06:27:14 -04:00
Kyle Banker
6b2939f2f7
RUBY-171 allow Cursor#to_a even after iterating; added Cursor#rewind; consistent Enumberable behavior for Cursor
2010-08-26 12:35:42 -04:00
Mike Dirolf
7702d671ea
Use C objectid_generate for ObjectId in addition to ObjectID.
...
Also, remove broken defined? check from objectid.rb and object_id.rb -
it was never doing anything since we require those files at the top of
cbson.c.
2010-08-25 10:23:18 -04:00
Steve Sloan
dfcf8d9d60
Moved thread and socket classes into Connection for easy overriding.
...
This is necessary for use under em-synchrony, which uses Fibers instead of Threads and EventMachine instead of blocking sockets.
2010-08-24 14:35:21 -04:00
Kyle Banker
02a0c7c2dc
RUBY-165 raise error if BSON.serialize is passed something other than a hash
2010-08-24 14:01:24 -04:00
Kyle Banker
e843891c8a
BUMP BSON 1.0.5
2010-08-24 12:50:37 -04:00