2004-12-23 11:23:30 -05:00
|
|
|
#
|
|
|
|
# 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)
|
* ext/tk/*: full update Ruby/Tk to support Ruby(1.9|1.8) and Tc/Tk8.5.
* 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
2008-03-29 01:25:12 -04:00
|
|
|
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
|
|
|
|
}
|
2004-12-23 11:23:30 -05:00
|
|
|
}
|
|
|
|
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
|
|
|
|
|
* ext/tk/*: full update Ruby/Tk to support Ruby(1.9|1.8) and Tc/Tk8.5.
* 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
2008-03-29 01:25:12 -04:00
|
|
|
TkVar_ID_TBL.mutex.synchronize{
|
|
|
|
TkVar_ID_TBL[@id] = self
|
|
|
|
}
|
2004-12-23 11:23:30 -05:00
|
|
|
|
|
|
|
@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)
|
* ext/tk/*: full update Ruby/Tk to support Ruby(1.9|1.8) and Tc/Tk8.5.
* 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
2008-03-29 01:25:12 -04:00
|
|
|
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
|
|
|
|
}
|
2004-12-23 11:23:30 -05:00
|
|
|
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
|