requires=
classes=
methods=String/i.jcount.jcode,String/i.jlength.jcode,String/i.mbchar=3f.jcode,String/i.each_char.jcode,String/i.chop.jcode,String/i.chop=21.jcode,String/i.delete.jcode,String/i.delete=21.jcode,String/i.squeeze.jcode,String/i.squeeze=21.jcode,String/i.succ.jcode,String/i.succ=21.jcode,String/i.tr.jcode,String/i.tr=21.jcode,String/i.tr_s.jcode,String/i.tr_s=21.jcode
sublibraries=
is_sublibrary=false
category=CharacterEncoding

[[c:String]]クラスのメソッドを追加、再定義し、
日本語を意識した文字列処理を提供します。

対象の文字列のエンコーディングが [[m:$KCODE]] で
あるものとして処理します。つまりスクリプト中で
[[m:$KCODE]] を変更すると以後メソッドの動作が変わります。

[[m:String#chop]]、[[m:String#delete]] といった既存の
メソッドを置き換えるため、別のライブラリの
動作が変化してしまう可能性があります。
そのためこのライブラリを使ってよいのは
利用しているライブラリを含め
動作しているソースすべてが把握可能な場合のみです。

マルチバイト文字列の取扱に関する問題を
このライブラリで解決しようとするのはお勧めしません。
Ruby の文字列のエンコーディングの取り扱いに関しては、
[[d:spec/rubycmd]] の -K オプションの所や、 [[m:$KCODE]] を
見てください。

=== 使用例 

  #!/usr/bin/ruby -Ke
  # -*- coding: euc-jp -*-
  # 漢字コードをEUC-JPに。
  # Windows で Shift JIS なら -Ks, coding: cp932 にする
  
  # jcode ライブラリを読み込み、メソッドの追加、再定義を行う
  require 'jcode' 
  
  # 再定義された String#tr を呼びだす
  puts 'abcdef'.tr('a-z', 'Ａ-Ｚ')
