diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2015-12-13 09:27:52 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2015-12-13 09:27:52 +0000 |
commit | cc0313436160b735a3d41361cb5e3eeb10fcbdad (patch) | |
tree | f3f7c9300fd9f90f0febb5750440b44418d6999e | |
parent | cdaa94eab443919ecac3484c0f567eca773d686e (diff) |
psych_emitter.c: check string
* ext/psych/psych_emitter.c (start_document): ensure string before
encoding conversion.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@53078 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | ext/psych/psych_emitter.c | 6 | ||||
-rw-r--r-- | test/psych/test_emitter.rb | 1 |
3 files changed, 10 insertions, 2 deletions
@@ -1,3 +1,8 @@ +Sun Dec 13 18:27:53 2015 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * ext/psych/psych_emitter.c (start_document): ensure string before + encoding conversion. + Sun Dec 13 18:26:31 2015 Nobuyoshi Nakada <nobu@ruby-lang.org> * ext/tk/tkutil/tkutil.c (tk_hash_kv): check types of array diff --git a/ext/psych/psych_emitter.c b/ext/psych/psych_emitter.c index 29df96a562..078ae2b680 100644 --- a/ext/psych/psych_emitter.c +++ b/ext/psych/psych_emitter.c @@ -189,13 +189,15 @@ static VALUE start_document(VALUE self, VALUE version, VALUE tags, VALUE imp) } name = RARRAY_AREF(tuple, 0); value = RARRAY_AREF(tuple, 1); + StringValue(name); + StringValue(value); #ifdef HAVE_RUBY_ENCODING_H name = rb_str_export_to_enc(name, encoding); value = rb_str_export_to_enc(value, encoding); #endif - tail->handle = (yaml_char_t *)StringValuePtr(name); - tail->prefix = (yaml_char_t *)StringValuePtr(value); + tail->handle = (yaml_char_t *)RSTRING_PTR(name); + tail->prefix = (yaml_char_t *)RSTRING_PTR(value); tail++; } diff --git a/test/psych/test_emitter.rb b/test/psych/test_emitter.rb index 1c96c12379..fe198bd1b1 100644 --- a/test/psych/test_emitter.rb +++ b/test/psych/test_emitter.rb @@ -53,6 +53,7 @@ module Psych [[], 'foo', false], [[], ['foo'], false], [[], [nil,nil], false], + [[1,1], [[nil, "tag:TALOS"]], 0], ].each do |args| assert_raises(TypeError) do @emitter.start_document(*args) |