mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00

* ext/tk/lib/tkextlib/tile.rb: [incompatible] remove TileWidgets' instate/state/identify method to avoid the conflict with standard widget options. Those methods are renamed to ttk_instate/ttk_state/ ttk_identify (tile_instate/tile_state/tile_identify are available too). Although I don't recommend, if you realy need old methods, please define "Tk::USE_OBSOLETE_TILE_STATE_METHOD = true" before "require 'tkextlib/tile'". * ext/tk/lib/tkextlib/tile.rb: "Tk::Tile::__Import_Tile_Widgets__!" is obsolete. It outputs warning. To control default widget set, use "Tk.default_widget_set = :Ttk". * ext/tk/lib/tk.rb: __IGNORE_UNKNOWN_CONFIGURE_OPTION__ method and __set_IGNORE_UNKNOWN_CONFIGURE_OPTION__!(mode) method are defind as module methods of TkConfigMethod. It may help users to wrap old Ruby/Tk scripts (use standard widgets) to force to use Ttk widgets. Ttk widgets don't have some options of standard widgets which are control the view of widgets. When set ignore-mode true, configure method tries to ignoure such unknown options with no exception. Of course, it may raise other troubles on the GUI design. So, those are a little danger methods. * ext/tk/lib/tk/itemconfig.rb: __IGNORE_UNKNOWN_CONFIGURE_OPTION__ method and __set_IGNORE_UNKNOWN_CONFIGURE_OPTION__!(mode) method are defind as module methods of TkItemConfigMethod as the same purpose as TkConfigMethod's ones. * ext/tk/sample/ttk_wrapper.rb: A new example. This is a tool for wrapping old Ruby/Tk scripts (which use standard widgets) to use Ttk (Tile) widgets as default. * ext/tk/sample/tkextlib/tile/demo.rb: use ttk_instate/ttk_state method instead of instate/state method. * ext/tk/lib/tk/root, ext/tk/lib/tk/namespace.rb, ext/tk/lib/tk/text.rb, ext/tk/lib/tkextlib/*: some 'instance_eval's are replaced to "instance_exec(self)". * ext/tk/lib/tk/event.rb: bug fix on KEY_TBL and PROC_TBL (?x is not a character code on Ruby1.9). * ext/tk/lib/tk/variable.rb: support new style of operation argument on Tcl/Tk's 'trace' command for variables. * ext/tk/sample/demos-jp/widget, ext/tk/sample/demos-en/widget: bug fix * ext/tk/sammple/demos-jp/textpeer.rb, ext/tk/sammple/demos-en/textpeer.rb: new widget demo. * ext/tk/tcltklib.c: decrase SEGV troubles (probably) * ext/tk/lib/tk.rb: remove Thread.critical access if Ruby1.9 * ext/tk/lib/tk/multi-tk.rb: support Ruby1.9 (probably) * ext/tk/lib/tkextlib/tile.rb: add method to define Tcl/Tk command to make Tcl/Tk theme sources (based on different version of Tile extension) available. (Tk::Tile::__define_LoadImages_proc_for_comaptibility__) * ext/tk/lib/tk.rb, ext/tk/lib/tk/wm.rb: support dockable frames (Tcl/Tk8.5 feature). 'wm' command can treat many kinds of widgets as toplevel widgets. * ext/tk/lib/tkextlib/tile/style.rb: ditto. (Tk::Tile::Style.__define_wrapper_proc_for_compatibility__) * ext/tk/lib/tk/font.rb: add actual_hash and metrics_hash to get properties as a hash. metrics_hash method returns a boolean value for 'fixed' option. But metrics method returns numeric value (0 or 1) for 'fixed' option, because of backward compatibility. * ext/tk/lib/tk/timer.rb: somtimes fail to set callback procedure. * ext/tk/lib/tk.rb: add Tk.sleep and Tk.wakeup method. Tk.sleep doesn't block the eventloop. It will be better to use the method in event callbacks. * ext/tk/sample/tksleep_sample.rb: sample script about Tk.sleep. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@15848 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
256 lines
4.8 KiB
Ruby
256 lines
4.8 KiB
Ruby
#
|
|
# tkextlib/blt/vector.rb
|
|
# by Hidetoshi NAGAI (nagai@ai.kyutech.ac.jp)
|
|
#
|
|
|
|
require 'tk'
|
|
require 'tkextlib/blt.rb'
|
|
|
|
module Tk::BLT
|
|
class Vector < TkVariable
|
|
TkCommandNames = ['::blt::vector'.freeze].freeze
|
|
|
|
def self.create(*args)
|
|
tk_call('::blt::vector', 'create', *args)
|
|
end
|
|
|
|
def self.destroy(*args)
|
|
tk_call('::blt::vector', 'destroy', *args)
|
|
end
|
|
|
|
def self.expr(expression)
|
|
tk_call('::blt::vector', 'expr', expression)
|
|
end
|
|
|
|
def self.names(pat=None)
|
|
list = simplelist(tk_call('::blt::vector', 'names', pat))
|
|
TkVar_ID_TBL.mutex.synchronize{
|
|
list.collect{|name|
|
|
if TkVar_ID_TBL[name]
|
|
TkVar_ID_TBL[name]
|
|
elsif name[0..1] == '::' && TkVar_ID_TBL[name[2..-1]]
|
|
TkVar_ID_TBL[name[2..-1]]
|
|
else
|
|
name
|
|
end
|
|
}
|
|
}
|
|
end
|
|
|
|
####################################
|
|
|
|
def initialize(size=nil, keys={})
|
|
if size.kind_of?(Hash)
|
|
keys = size
|
|
size = nil
|
|
end
|
|
if size.kind_of?(Array)
|
|
# [first, last]
|
|
size = size.join(':')
|
|
end
|
|
if size
|
|
@id = INTERP._invoke('::blt::vector', 'create',
|
|
"#auto(#{size})", *hash_kv(keys))
|
|
else
|
|
@id = INTERP._invoke('::blt::vector', 'create',
|
|
"#auto", *hash_kv(keys))
|
|
end
|
|
|
|
TkVar_ID_TBL.mutex.synchronize{
|
|
TkVar_ID_TBL[@id] = self
|
|
}
|
|
|
|
@def_default = false
|
|
@default_val = nil
|
|
|
|
@trace_var = nil
|
|
@trace_elem = nil
|
|
@trace_opts = nil
|
|
|
|
# teach Tk-ip that @id is global var
|
|
INTERP._invoke_without_enc('global', @id)
|
|
end
|
|
|
|
def destroy
|
|
tk_call('::blt::vector', 'destroy', @id)
|
|
end
|
|
|
|
def inspect
|
|
'#<Tk::BLT::Vector: ' + @id + '>'
|
|
end
|
|
|
|
def to_s
|
|
@id
|
|
end
|
|
|
|
def *(item)
|
|
list(tk_call(@id, '*', item))
|
|
end
|
|
|
|
def +(item)
|
|
list(tk_call(@id, '+', item))
|
|
end
|
|
|
|
def -(item)
|
|
list(tk_call(@id, '-', item))
|
|
end
|
|
|
|
def /(item)
|
|
list(tk_call(@id, '/', item))
|
|
end
|
|
|
|
def append(*vectors)
|
|
tk_call(@id, 'append', *vectors)
|
|
end
|
|
|
|
def binread(channel, len=None, keys={})
|
|
if len.kind_of?(Hash)
|
|
keys = len
|
|
len = None
|
|
end
|
|
keys = _symbolkey2str(keys)
|
|
keys['swap'] = None if keys.delete('swap')
|
|
tk_call(@id, 'binread', channel, len, keys)
|
|
end
|
|
|
|
def clear()
|
|
tk_call(@id, 'clear')
|
|
self
|
|
end
|
|
|
|
def delete(*indices)
|
|
tk_call(@id, 'delete', *indices)
|
|
self
|
|
end
|
|
|
|
def dup_vector(vec)
|
|
tk_call(@id, 'dup', vec)
|
|
self
|
|
end
|
|
|
|
def expr(expression)
|
|
tk_call(@id, 'expr', expression)
|
|
self
|
|
end
|
|
|
|
def index(idx, val=None)
|
|
number(tk_call(@id, 'index', idx, val))
|
|
end
|
|
|
|
def [](idx)
|
|
index(idx)
|
|
end
|
|
|
|
def []=(idx, val)
|
|
index(idx, val)
|
|
end
|
|
|
|
def length()
|
|
number(tk_call(@id, 'length'))
|
|
end
|
|
|
|
def length=(size)
|
|
number(tk_call(@id, 'length', size))
|
|
end
|
|
|
|
def merge(*vectors)
|
|
tk_call(@id, 'merge', *vectors)
|
|
self
|
|
end
|
|
|
|
def normalize(vec=None)
|
|
tk_call(@id, 'normalize', vec)
|
|
self
|
|
end
|
|
|
|
def notify(keyword)
|
|
tk_call(@id, 'notify', keyword)
|
|
self
|
|
end
|
|
|
|
def offset()
|
|
number(tk_call(@id, 'offset'))
|
|
end
|
|
|
|
def offset=(val)
|
|
number(tk_call(@id, 'offset', val))
|
|
end
|
|
|
|
def random()
|
|
tk_call(@id, 'random')
|
|
end
|
|
|
|
def populate(vector, density=None)
|
|
tk_call(@id, 'populate', vector, density)
|
|
self
|
|
end
|
|
|
|
def range(first, last=None)
|
|
list(tk_call(@id, 'range', first, last))
|
|
end
|
|
|
|
def search(val1, val2=None)
|
|
list(tk_call(@id, 'search', val1, val2))
|
|
end
|
|
|
|
def set(item)
|
|
tk_call(@id, 'set', item)
|
|
self
|
|
end
|
|
|
|
def seq(start, finish=None, step=None)
|
|
tk_call(@id, 'seq', start, finish, step)
|
|
self
|
|
end
|
|
|
|
def sort(*vectors)
|
|
tk_call(@id, 'sort', *vectors)
|
|
self
|
|
end
|
|
|
|
def sort_reverse(*vectors)
|
|
tk_call(@id, 'sort', '-reverse', *vectors)
|
|
self
|
|
end
|
|
|
|
def split(*vectors)
|
|
tk_call(@id, 'split', *vectors)
|
|
self
|
|
end
|
|
|
|
def variable(var)
|
|
tk_call(@id, 'variable', var)
|
|
self
|
|
end
|
|
end
|
|
|
|
class VectorAccess < Vector
|
|
def self.new(name)
|
|
TkVar_ID_TBL.mutex.synchronize{
|
|
if TkVar_ID_TBL[name]
|
|
TkVar_ID_TBL[name]
|
|
else
|
|
(obj = self.allocate).instance_eval{
|
|
initialize(name)
|
|
TkVar_ID_TBL[@id] = self
|
|
}
|
|
obj
|
|
end
|
|
}
|
|
end
|
|
|
|
def initialize(vec_name)
|
|
@id = vec_name
|
|
|
|
@def_default = false
|
|
@default_val = nil
|
|
|
|
@trace_var = nil
|
|
@trace_elem = nil
|
|
@trace_opts = nil
|
|
|
|
# teach Tk-ip that @id is global var
|
|
INTERP._invoke_without_enc('global', @id)
|
|
end
|
|
end
|
|
end
|