* encoding.c: provide basic features for M17N.
* 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
2007-08-25 03:29:39 +00:00
|
|
|
|
# -*- coding: euc-jp -*-
|
2003-07-31 20:52:40 +00:00
|
|
|
|
#
|
|
|
|
|
# bitmap widget demo (called by 'widget')
|
|
|
|
|
#
|
|
|
|
|
|
|
|
|
|
# bitmapRow --
|
|
|
|
|
# Create a row of bitmap items in a window.
|
|
|
|
|
#
|
|
|
|
|
# Arguments:
|
2004-10-11 04:51:21 +00:00
|
|
|
|
# w - The parent window that is to contain the row.
|
|
|
|
|
# args - The names of one or more bitmaps, which will be displayed
|
|
|
|
|
# in a new row across the bottom of w along with their
|
|
|
|
|
# names.
|
2003-07-31 20:52:40 +00:00
|
|
|
|
|
|
|
|
|
def bitmapRow(w,*args)
|
|
|
|
|
TkFrame.new(w){|row|
|
|
|
|
|
pack('side'=>'top', 'fill'=>'both')
|
|
|
|
|
for bitmap in args
|
|
|
|
|
TkFrame.new(row){|base|
|
2004-10-11 04:51:21 +00:00
|
|
|
|
pack('side'=>'left', 'fill'=>'both', 'pady'=>'.25c', 'padx'=>'.25c')
|
|
|
|
|
TkLabel.new(base, 'text'=>bitmap, 'width'=>9).pack('side'=>'bottom')
|
|
|
|
|
TkLabel.new(base, 'bitmap'=>bitmap).pack('side'=>'bottom')
|
2003-07-31 20:52:40 +00:00
|
|
|
|
}
|
|
|
|
|
end
|
|
|
|
|
}
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
# toplevel widget <20><>¸<EFBFBD>ߤ<EFBFBD><DFA4><EFBFBD><EFBFBD>к<EFBFBD><D0BA><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
if defined?($bitmap_demo) && $bitmap_demo
|
|
|
|
|
$bitmap_demo.destroy
|
|
|
|
|
$bitmap_demo = nil
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
# demo <20>Ѥ<EFBFBD> toplevel widget <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
$bitmap_demo = TkToplevel.new {|w|
|
|
|
|
|
title("Bitmap Demonstration")
|
|
|
|
|
iconname("bitmap")
|
|
|
|
|
positionWindow(w)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# label <20><><EFBFBD><EFBFBD>
|
|
|
|
|
TkLabel.new($bitmap_demo,'font'=>$font,'wraplength'=>'4i','justify'=>'left',
|
2004-10-11 04:51:21 +00:00
|
|
|
|
'text'=>"<EFBFBD><EFBFBD><EFBFBD>Υ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ɥ<EFBFBD><EFBFBD>ˤϡ<EFBFBD>Tk <20><><EFBFBD>Ȥ߹<C8A4><DFB9>ޤ줿<DEA4><ECA4BF><EFBFBD>٤ƤΥӥåȥޥåפ<C3A5><D7A4><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>̾<EFBFBD><CCBE><EFBFBD>ȶ<EFBFBD><C8B6><EFBFBD>ɽ<EFBFBD><C9BD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ƥ<EFBFBD><C6A4>ޤ<EFBFBD><DEA4><EFBFBD>Tcl <20>Υ<EFBFBD><CEA5><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ץ<EFBFBD><D7A5><EFBFBD><EFBFBD>Ǥϡ<C7A4><CFA1><EFBFBD><EFBFBD>줾<EFBFBD><ECA4BE><EFBFBD><EFBFBD>̾<EFBFBD><CCBE><EFBFBD><EFBFBD><EFBFBD>Ѥ<EFBFBD><D1A4>ƻ<EFBFBD><C6BB>Ȥ<EFBFBD><C8A4>ޤ<EFBFBD><DEA4><EFBFBD>"){
|
2003-07-31 20:52:40 +00:00
|
|
|
|
pack('side'=>'top')
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# frame <20><><EFBFBD><EFBFBD>
|
|
|
|
|
$bitmap_buttons = TkFrame.new($bitmap_demo) {|frame|
|
|
|
|
|
TkButton.new(frame) {
|
2004-05-01 16:09:54 +00:00
|
|
|
|
#text 'λ<><CEBB>'
|
|
|
|
|
text '<27>Ĥ<EFBFBD><C4A4><EFBFBD>'
|
2003-07-31 20:52:40 +00:00
|
|
|
|
command proc{
|
|
|
|
|
tmppath = $bitmap_demo
|
|
|
|
|
$bitmap_demo = nil
|
|
|
|
|
tmppath.destroy
|
|
|
|
|
}
|
|
|
|
|
}.pack('side'=>'left', 'expand'=>'yes')
|
|
|
|
|
|
|
|
|
|
TkButton.new(frame) {
|
|
|
|
|
text '<27><><EFBFBD><EFBFBD><EFBFBD>ɻ<EFBFBD><C9BB><EFBFBD>'
|
|
|
|
|
command proc{showCode 'bitmap'}
|
|
|
|
|
}.pack('side'=>'left', 'expand'=>'yes')
|
|
|
|
|
}
|
|
|
|
|
$bitmap_buttons.pack('side'=>'bottom', 'fill'=>'x', 'pady'=>'2m')
|
|
|
|
|
|
|
|
|
|
# frame <20><><EFBFBD><EFBFBD>
|
|
|
|
|
TkFrame.new($bitmap_demo){|f|
|
|
|
|
|
bitmapRow(f,'error','gray25','gray50','hourglass')
|
|
|
|
|
bitmapRow(f,'info','question','questhead','warning')
|
|
|
|
|
pack('side'=>'top', 'expand'=>'yes', 'fill'=>'both')
|
|
|
|
|
}
|
|
|
|
|
|