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
69 lines
2.3 KiB
Ruby
69 lines
2.3 KiB
Ruby
# -*- coding: euc-jp -*-
|
||
#
|
||
# spin.rb --
|
||
#
|
||
# This demonstration script creates several spinbox widgets.
|
||
#
|
||
# based on Tcl/Tk8.4.4 widget demos
|
||
|
||
if defined?($spin_demo) && $spin_demo
|
||
$spin_demo.destroy
|
||
$spin_demo = nil
|
||
end
|
||
|
||
$spin_demo = TkToplevel.new {|w|
|
||
title("Spinbox Demonstration")
|
||
iconname("spin")
|
||
positionWindow(w)
|
||
}
|
||
|
||
TkLabel.new($spin_demo,
|
||
:font=>$font, :wraplength=>'5i', :justify=>:left,
|
||
:text=><<EOL).pack(:side=>:top)
|
||
下には3種類のスピンボックスが表示されています。\
|
||
それぞれ、マウスで選択して文字を入力することができます。
|
||
編集操作としては、Emacs 形式の多くに加えて、一般的な
|
||
Motif 形式のキー操作がサポートされています。たとえば、
|
||
Backspace と Control-h とは入力カーソルの左側の文字を
|
||
削除し、Delete と Control-d とは右側の文字を削除します。
|
||
入力枠の長さを越えるような長い文字列を入力した場合には、
|
||
マウスのボタン2を押してドラッグすることで、入力文字列
|
||
をスキャンすることが可能です。
|
||
なお、最初のスピンボックスは、整数値とみなされるような
|
||
文字列しか入力が許されないことに注意してください。また、
|
||
3番目のスピンボックスで選択候補に現れるのはオーストラ
|
||
リアの都市名のリストとなっています。
|
||
もしあなたが使っている Ruby にリンクされている Tk ライ
|
||
ブラリが spinbox ウィジェットを実装していない場合、この
|
||
デモはうまく動かないはずです。その場合には spinbox ウィ
|
||
ジェットが実装されているようなより新しいバージョンの Tk
|
||
を組み合わせて試すようにしてください。
|
||
EOL
|
||
|
||
TkFrame.new($spin_demo){|f|
|
||
pack(:side=>:bottom, :fill=>:x, :pady=>'2m')
|
||
|
||
TkButton.new(f, :text=>'閉じる', :width=>15, :command=>proc{
|
||
$spin_demo.destroy
|
||
$spin_demo = nil
|
||
}).pack(:side=>:left, :expand=>true)
|
||
|
||
TkButton.new(f, :text=>'コード参照', :width=>15, :command=>proc{
|
||
showCode 'spin'
|
||
}).pack(:side=>:left, :expand=>true)
|
||
}
|
||
|
||
australianCities = [
|
||
'Canberra', 'Sydney', 'Melbourne', 'Perth', 'Adelaide',
|
||
'Brisbane', 'Hobart', 'Darwin', 'Alice Springs'
|
||
]
|
||
|
||
[
|
||
TkSpinbox.new($spin_demo, :from=>1, :to=>10, :width=>10, :validate=>:key,
|
||
:validatecommand=>[
|
||
proc{|s| s == '' || /^[+-]?\d+$/ =~ s }, '%P'
|
||
]),
|
||
TkSpinbox.new($spin_demo, :from=>0, :to=>3, :increment=>0.5,
|
||
:format=>'%05.2f', :width=>10),
|
||
TkSpinbox.new($spin_demo, :values=>australianCities, :width=>10)
|
||
].each{|sbox| sbox.pack(:side=>:top, :pady=>5, :padx=>10)}
|