From 5ef0a47f790e1a1f4117cc748e009e835e5c4e1b Mon Sep 17 00:00:00 2001 From: ima1zumi Date: Fri, 2 Apr 2021 22:24:11 +0900 Subject: [PATCH] Update Integer#chr description MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - サンプルコードの順番と説明文を整理しました。 - (2**32)はInteger#chrに渡すことはないと思い、サンプルコードから削除しました。 - デフォルト内部エンコーディングに関係があるため、Encoding#default_internalへのリンクを追加しました。 --- refm/api/src/_builtin/Integer | 31 +++++++++++++++++++------------ 1 file changed, 19 insertions(+), 12 deletions(-) diff --git a/refm/api/src/_builtin/Integer b/refm/api/src/_builtin/Integer index ef23f4e4b8..0d225d0197 100644 --- a/refm/api/src/_builtin/Integer +++ b/refm/api/src/_builtin/Integer @@ -66,24 +66,31 @@ Math.sqrt(10**46).floor #=> 99999999999999991611392 (!) --- chr -> String --- chr(encoding) -> String -与えられたエンコーディング encoding において self を文字コードと見た時、それに対応する一文字からなる文字列を返します。 +self を文字コードとして見た時に、引数で与えたエンコーディング encoding に対応する文字を返します。 + +#@samplecode +p 65.chr +# => "A" +p 12354.chr +# => `chr': 12354 out of char range (RangeError) + +p 12354.chr(Encoding::UTF_8) +# => "あ" +p 12354.chr(Encoding::EUC_JP) +# => RangeError: invalid codepoint 0x3042 in EUC-JP +#@end + 引数無しで呼ばれた場合は self を US-ASCII、ASCII-8BIT、デフォルト内部エンコーディングの順で優先的に解釈します。 - p 65.chr # => "A" - p 0x79.chr.encoding # => # - p 0x80.chr.encoding # => # - p 12354.chr Encoding::UTF_8 # => "あ" - p 12354.chr Encoding::EUC_JP - # => RangeError: invalid codepoint 0x3042 in EUC-JP - p 12354.chr Encoding::ASCII_8BIT - # => RangeError: 12354 out of char range - p (2**32).chr - # => RangeError: bignum out of char range +#@samplecode +p 0x79.chr.encoding # => # +p 0x80.chr.encoding # => # +#@end @param encoding エンコーディングを表すオブジェクト。Encoding::UTF_8、'shift_jis' など。 @return 一文字からなる文字列 @raise RangeError self を与えられたエンコーディングで正しく解釈できない場合に発生します。 -@see [[m:String#ord]] +@see [[m:String#ord]] [[m:Encoding#default_internal]] #@end #@since 2.4.0