deserialize to RegexpOfHolding only when necessary
This commit is contained in:
parent
32606db5e9
commit
fc2ddf3bbd
@ -62,6 +62,7 @@ static VALUE DBRef;
|
|||||||
static VALUE Code;
|
static VALUE Code;
|
||||||
static VALUE MinKey;
|
static VALUE MinKey;
|
||||||
static VALUE MaxKey;
|
static VALUE MaxKey;
|
||||||
|
static VALUE Regexp;
|
||||||
static VALUE RegexpOfHolding;
|
static VALUE RegexpOfHolding;
|
||||||
static VALUE OrderedHash;
|
static VALUE OrderedHash;
|
||||||
static VALUE InvalidName;
|
static VALUE InvalidName;
|
||||||
@ -693,8 +694,13 @@ static VALUE get_value(const char* buffer, int* position, int type) {
|
|||||||
}
|
}
|
||||||
argv[0] = pattern;
|
argv[0] = pattern;
|
||||||
argv[1] = INT2FIX(flags);
|
argv[1] = INT2FIX(flags);
|
||||||
|
if(extra[0] == 0) {
|
||||||
|
value = rb_class_new_instance(2, argv, Regexp);
|
||||||
|
}
|
||||||
|
else { // Deserializing a RegexpOfHolding
|
||||||
argv[2] = rb_str_new2(extra);
|
argv[2] = rb_str_new2(extra);
|
||||||
value = rb_class_new_instance(3, argv, RegexpOfHolding);
|
value = rb_class_new_instance(3, argv, RegexpOfHolding);
|
||||||
|
}
|
||||||
*position += flags_length + 1;
|
*position += flags_length + 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -877,6 +883,7 @@ void Init_cbson() {
|
|||||||
MinKey = rb_const_get(mongo, rb_intern("MinKey"));
|
MinKey = rb_const_get(mongo, rb_intern("MinKey"));
|
||||||
MaxKey = rb_const_get(mongo, rb_intern("MaxKey"));
|
MaxKey = rb_const_get(mongo, rb_intern("MaxKey"));
|
||||||
rb_require("mongo/types/regexp_of_holding");
|
rb_require("mongo/types/regexp_of_holding");
|
||||||
|
Regexp = rb_const_get(rb_cObject, rb_intern("Regexp"));
|
||||||
RegexpOfHolding = rb_const_get(mongo, rb_intern("RegexpOfHolding"));
|
RegexpOfHolding = rb_const_get(mongo, rb_intern("RegexpOfHolding"));
|
||||||
rb_require("mongo/exceptions");
|
rb_require("mongo/exceptions");
|
||||||
InvalidName = rb_const_get(mongo, rb_intern("InvalidName"));
|
InvalidName = rb_const_get(mongo, rb_intern("InvalidName"));
|
||||||
|
@ -329,8 +329,13 @@ class BSON_RUBY
|
|||||||
options |= Regexp::MULTILINE if options_str.include?('m')
|
options |= Regexp::MULTILINE if options_str.include?('m')
|
||||||
options |= Regexp::EXTENDED if options_str.include?('x')
|
options |= Regexp::EXTENDED if options_str.include?('x')
|
||||||
options_str.gsub!(/[imx]/, '') # Now remove the three we understand
|
options_str.gsub!(/[imx]/, '') # Now remove the three we understand
|
||||||
|
if options_str == ''
|
||||||
|
Regexp.new(str, options)
|
||||||
|
else
|
||||||
|
warn("Use deprecated Regexp options #{options_str}; future versions of this MongoDB driver will support only i, m, and x. See deprecated class RegexpOfHolding for more info.")
|
||||||
RegexpOfHolding.new(str, options, options_str)
|
RegexpOfHolding.new(str, options, options_str)
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def deserialize_string_data(buf)
|
def deserialize_string_data(buf)
|
||||||
len = buf.get_int
|
len = buf.get_int
|
||||||
|
@ -138,10 +138,9 @@ class BSONTest < Test::Unit::TestCase
|
|||||||
assert_equal doc, doc2
|
assert_equal doc, doc2
|
||||||
|
|
||||||
r = doc2['doc']
|
r = doc2['doc']
|
||||||
assert_kind_of RegexpOfHolding, r
|
assert_kind_of Regexp, r
|
||||||
assert_equal '', r.extra_options_str
|
|
||||||
|
|
||||||
r.extra_options_str << 'zywcab'
|
r = RegexpOfHolding.new('st', 0, 'zywcab')
|
||||||
assert_equal 'zywcab', r.extra_options_str
|
assert_equal 'zywcab', r.extra_options_str
|
||||||
|
|
||||||
doc = {'doc' => r}
|
doc = {'doc' => r}
|
||||||
|
Loading…
Reference in New Issue
Block a user