1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00

extension.rdoc: fix rb_get_kwargs [ci skip]

* doc/extension.rdoc: [DOC] optional keyword arguments are
  defaulted to Qundef.  ignored keys are kept in the hash but a
  new Hash is not created.  [ruby-dev:49893] [Bug #13004]

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@56980 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
nobu 2016-12-04 08:50:28 +00:00
parent b16d1968e6
commit b62e322017
2 changed files with 7 additions and 8 deletions

View file

@ -1409,10 +1409,10 @@ int rb_get_kwargs(VALUE keyword_hash, const ID *table, int required, int optiona
optional (optionalが負の場合は-optional-1) 個のIDは省略可能
キーワードです必須キーワードがkeyword_hash中にない場合
"missing keyword"ArgumentErrorが発生します省略可能キーワー
ドがない場合はvalues中の対応する要素は変更されません.
keyword_hashに使用されない要素がある場合はoptionalが負なら
新しいHashとして省略可能引数の次に保存されますがそうでなけ
れば"unknown keyword"ArgumentErrorが発生します
ドがない場合はvalues中の対応する要素にはQundefがセットされ
ます.keyword_hashに使用されない要素がある場合はoptionalが
負なら無視されますが,そうでなければ"unknown keyword"
ArgumentErrorが発生します
VALUE rb_extract_keywords(VALUE *original_hash) ::

View file

@ -1431,10 +1431,9 @@ int rb_get_kwargs(VALUE keyword_hash, const ID *table, int required, int optiona
+optional+ is negative) number of IDs are optional. If a
mandatory key is not contained in +keyword_hash+, raises "missing
keyword" +ArgumentError+. If an optional key is not present in
+keyword_hash+, the corresponding element in +values+ is not changed.
If +optional+ is negative, rest of +keyword_hash+ are stored in the
next to optional +values+ as a new Hash, otherwise raises "unknown
keyword" +ArgumentError+.
+keyword_hash+, the corresponding element in +values+ is set to +Qundef+.
If +optional+ is negative, rest of +keyword_hash+ are ignored, otherwise
raises "unknown keyword" +ArgumentError+.
Be warned, handling keyword arguments in the C API is less efficient
than handling them in Ruby. Consider using a Ruby wrapper method