mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
generator.c: fix infinite recursion
* ext/json/generator/generator.c (generate_json): get rid of unnecessary recursive calls which can cause infinite recursion. T_STRING may not have rb_cString. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@49562 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
4068d9089a
commit
e5c516c89a
3 changed files with 17 additions and 1 deletions
|
@ -1,3 +1,9 @@
|
|||
Wed Feb 11 11:01:33 2015 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* ext/json/generator/generator.c (generate_json): get rid of
|
||||
unnecessary recursive calls which can cause infinite recursion.
|
||||
T_STRING may not have rb_cString.
|
||||
|
||||
Wed Feb 11 07:53:35 2015 Masaki Suketa <masaki.suketa@nifty.ne.jp>
|
||||
|
||||
* test/win32ole/test_word.rb: use skip method to skip test.
|
||||
|
|
|
@ -880,7 +880,7 @@ static void generate_json(FBuffer *buffer, VALUE Vstate, JSON_Generator_State *s
|
|||
} else {
|
||||
tmp = rb_funcall(obj, i_to_s, 0);
|
||||
Check_Type(tmp, T_STRING);
|
||||
generate_json(buffer, Vstate, state, tmp);
|
||||
generate_json_string(buffer, Vstate, state, tmp);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -334,4 +334,14 @@ EOT
|
|||
assert_equal true, JSON.generate(["\xea"])
|
||||
end
|
||||
end
|
||||
|
||||
def test_string_subclass
|
||||
s = Class.new(String) do
|
||||
def to_s; self; end
|
||||
undef to_json
|
||||
end
|
||||
assert_nothing_raised(SystemStackError) do
|
||||
assert_equal '[""]', JSON.generate([s.new])
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue