mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
a25fbe3b3e
* parse.y: encoding aware parsing. * parse.y (pragma_encoding): encoding specification pragma. * parse.y (rb_intern3): encoding specified symbols. * string.c (rb_str_length): length based on characters. for older behavior, bytesize method added. * string.c (rb_str_index_m): index based on characters. rindex as well. * string.c (succ_char): encoding aware succeeding string. * string.c (rb_str_reverse): reverse based on characters. * string.c (rb_str_inspect): encoding aware string description. * string.c (rb_str_upcase_bang): encoding aware case conversion. downcase, capitalize, swapcase as well. * string.c (rb_str_tr_bang): tr based on characters. delete, squeeze, tr_s, count as well. * string.c (rb_str_split_m): split based on characters. * string.c (rb_str_each_line): encoding aware each_line. * string.c (rb_str_each_char): added. iteration based on characters. * string.c (rb_str_strip_bang): encoding aware whitespace stripping. lstrip, rstrip as well. * string.c (rb_str_justify): encoding aware justifying (ljust, rjust, center). * string.c (str_encoding): get encoding attribute from a string. * re.c (rb_reg_initialize): encoding aware regular expression * sprintf.c (rb_str_format): formatting (i.e. length count) based on characters. * io.c (rb_io_getc): getc to return one-character string. for older behavior, getbyte method added. * ext/stringio/stringio.c (strio_getc): ditto. * io.c (rb_io_ungetc): allow pushing arbitrary string at the current reading point. * ext/stringio/stringio.c (strio_ungetc): ditto. * ext/strscan/strscan.c: encoding support. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@13261 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
58 lines
1.9 KiB
Ruby
58 lines
1.9 KiB
Ruby
# -*- coding: euc-jp -*-
|
|
#
|
|
# entry (no scrollbars) widget demo (called by 'widget')
|
|
#
|
|
|
|
# toplevel widget が存在すれば削除する
|
|
if defined?($entry1_demo) && $entry1_demo
|
|
$entry1_demo.destroy
|
|
$entry1_demo = nil
|
|
end
|
|
|
|
# demo 用の toplevel widget を生成
|
|
$entry1_demo = TkToplevel.new {|w|
|
|
title("Entry Demonstration (no scrollbars)")
|
|
iconname("entry1")
|
|
positionWindow(w)
|
|
}
|
|
|
|
# label 生成
|
|
msg = TkLabel.new($entry1_demo) {
|
|
font $font
|
|
wraplength '5i'
|
|
justify 'left'
|
|
text "3種類の異なるエントリが表示されています。文字を入力するにはポインタを持って行き、クリックしてからタイプしてください。標準的なMotifの編集機能が、Emacsのキーバインドとともに、サポートされています。例えば、バックスペースとコントロール-Hはカーソルの左の文字を削除し、デリートキーとコントロール-Dはカーソルの右側の文字を削除します。長過ぎてウィンドウに入り切らないものは、マウスのボタン2を押したままドラッグすることでスクロールさせることができます。日本語を入力するのはコントロール-バックスラッシュです。kinput2が動いていれば入力することができます。"
|
|
}
|
|
msg.pack('side'=>'top')
|
|
|
|
# frame 生成
|
|
TkFrame.new($entry1_demo) {|frame|
|
|
TkButton.new(frame) {
|
|
#text '了解'
|
|
text '閉じる'
|
|
command proc{
|
|
tmppath = $entry1_demo
|
|
$entry1_demo = nil
|
|
tmppath.destroy
|
|
}
|
|
}.pack('side'=>'left', 'expand'=>'yes')
|
|
|
|
TkButton.new(frame) {
|
|
text 'コード参照'
|
|
command proc{showCode 'entry1'}
|
|
}.pack('side'=>'left', 'expand'=>'yes')
|
|
}.pack('side'=>'bottom', 'fill'=>'x', 'pady'=>'2m')
|
|
|
|
# entry 生成
|
|
e1 = TkEntry.new($entry1_demo, 'relief'=>'sunken')
|
|
e2 = TkEntry.new($entry1_demo, 'relief'=>'sunken')
|
|
e3 = TkEntry.new($entry1_demo, 'relief'=>'sunken')
|
|
[e1,e2,e3].each{|w| w.pack('side'=>'top', 'padx'=>10, 'pady'=>5, 'fill'=>'x')}
|
|
|
|
# 初期値挿入
|
|
e1.insert(0, '初期値')
|
|
e2.insert('end', "このエントリには長い文字列が入っていて、")
|
|
e2.insert('end', "長すぎてウィンドウには入り切らないので、")
|
|
e2.insert('end', "実際の所終りまで見るにはスクロールさせなければ")
|
|
e2.insert('end', "ならないでしょう。")
|
|
|