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
Kyle Banker
c7c309b00d
RUBY-158 deprecate BSON::ObjectID for BSON::ObjectId
2010-08-24 12:49:23 -04:00
Kyle Banker
5cbec4e5b6
RUBY-161 accessors for hosts in a replica set by node type
2010-08-24 11:20:54 -04:00
Kyle Banker
bacb1ee69e
RUBY-167 fix OrderedHash#reject
2010-08-23 14:19:32 -04:00
Kyle Banker
f448946ea6
Merge branch 'master' of github.com:mongodb/mongo-ruby-driver
2010-08-23 14:10:17 -04:00
Mike Dirolf
56aa67f4fe
minor: typo
2010-08-17 10:08:48 -04:00
Kyle Banker
9cd7377b00
minor: cleanup
2010-08-09 14:09:51 -04:00
Kyle Banker
7bb59610b7
minor: kill cursors only when necessary
2010-08-06 16:02:51 -04:00
Kyle Banker
391d37ec83
BUMP 1.0.7; HISTORY
2010-08-04 16:53:29 -04:00
Kyle Banker
db8ddd059b
minor: silence some warning due to deprecaton
2010-08-04 16:47:13 -04:00
Kyle Banker
9e223f4510
remove old DB#command arguments
2010-08-04 16:26:29 -04:00
Kyle Banker
f1f0c87b3b
minor: fixes for db commands with new DB#command checking response
2010-08-04 16:21:41 -04:00
Kyle Banker
e9de3e56ea
RUBY-139 add new sub-type 0. Will become default with the release of mongod 1.8
2010-08-04 15:39:31 -04:00
Kyle Banker
065517ac29
Fixed test bug; better replication ack tests; deprecated DB#error and DB#last_status for DB#get_last_error
2010-08-02 18:19:54 -04:00
Kyle Banker
02e5b77219
minor: cleanup (chriseppstein)
2010-07-28 06:27:42 -04:00
Kyle Banker
66e9508f61
Connection#send_message should return bytes sent
2010-07-27 22:19:25 -04:00
Kyle Banker
db27756597
minor: docs
2010-07-26 18:05:23 -04:00
Kyle Banker
e3c1b1eafe
minor: logger bug fix (bernerdschaefer)
2010-07-21 15:27:29 -04:00
Kyle Banker
969ec6f644
Don't check keys on Collection#map_reduce
2010-07-21 08:23:55 -04:00
Kyle Banker
476d856abb
minor: reorganization. warn if using replica sets RUBY-148
2010-07-19 12:23:12 -04:00
Kyle Banker
d8b34d7679
Advance to 1.0.6 to development
2010-07-19 12:09:14 -04:00