1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00
ruby--ruby/ext/tk/lib/tkextlib/blt/dragdrop.rb
nagai ed6ce8b43b * ext/tk/extconf.rb: New strategy for searching Tcl/Tk libraries.
* ext/tk/*: Support new features of Tcl/Tk8.6b1 and minor bug fixes.
     ( [KNOWN BUG] Ruby/Tk on Ruby 1.9 will not work on Cygwin. )
* ext/tk/*: Unify sources between Ruby 1.8 & 1.9.
            Improve default_widget_set handling.
* ext/tk/*: Multi-TkInterpreter (multi-tk.rb) works on Ruby 1.8 & 1.9.
     ( [KNOWN BUG] On Ruby 1.8, join to a long term Thread on Tk
       callbacks may freeze. On Ruby 1.9, cannot create a second 
       master interpreter (creating slaves are OK); supported master
       interpreter is the default master interpreter only. )
* ext/tk/lib/tkextlib/*: Update supported versions of Tk extensions.
         Tcllib 1.8/Tklib 0.4.1  ==>  Tcllib 1.11.1/Tklib 0.5
         BWidgets 1.7            ==>  BWidgets 1.8
         TkTable 2.9             ==>  TkTable 2.10
         TkTreeCtrl 2005-12-02   ==>  TkTreeCtrl 2.2.9
         Tile 0.8.0/8.5.1        ==>  Tile 0.8.3/8.6b1
         IncrTcl 2005-02-14      ==>  IncrTcl 2008-12-15
         TclX 2005-02-07         ==>  TclX 2008-12-15
         Trofs 0.4.3             ==>  Trofs 0.4.4


git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@24063 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2009-07-12 23:08:32 +00:00

269 lines
6.6 KiB
Ruby

#
# tkextlib/blt/dragdrop.rb
# by Hidetoshi NAGAI (nagai@ai.kyutech.ac.jp)
#
require 'tk'
require 'tk/itemconfig'
require 'tkextlib/blt.rb'
module Tk::BLT
module DragDrop
extend TkCore
TkCommandNames = ['::blt::drag&drop'.freeze].freeze
class Token < TkWindow
WidgetClassName = 'DragDropToken'.freeze
WidgetClassNames[WidgetClassName] ||= self
def initialize(arg)
if arg.kind_of?(Hash) # arg is a hash includes the widgetpath of token
arg = _symbolkey2str(arg)
install_win(nil, arg['widgetname'])
else # arg is a drag&drop source
tk_call('::blt::drag&drop', 'source', arg)
install_win(nil, tk_call('::blt::drag&drop', 'token', arg))
end
end
end
###################################
extend TkItemConfigMethod
extend Tk::ValidateConfigure
class << self
def __item_config_cmd(id) # id := ['source'|'target', win]
['::blt::drag&drop', id[0], id[1]]
end
private :__item_config_cmd
def __item_boolval_optkeys(id)
super(id) << 'selftarget'
end
private :__item_boolval_optkeys
def __item_listval_optkeys(id)
super(id) << 'send'
end
private :__item_listval_optkeys
def __item_strval_optkeys(id)
super(id) << 'rejectbg' << 'rejectfg' << 'tokenbg'
end
private :__item_strval_optkeys
undef itemcget
undef itemcget_tkstring
private :itemconfigure, :itemconfiginfo, :current_itemconfiginfo
def source_configure(win, slot, value=None)
itemconfigure(['source', win], slot, value)
end
def source_configinfo(win, slot=nil)
itemconfiginfo(['source', win], slot)
end
def current_source_configinfo(win, slot=nil)
current_itemconfiginfo(['source', win], slot)
end
end
class PackageCommand < TkValidateCommand
class ValidateArgs < TkUtil::CallbackSubst
KEY_TBL = [
[ ?t, ?w, :token ],
[ ?W, ?w, :widget ],
nil
]
PROC_TBL = [
[ ?w, TkComm.method(:window) ],
nil
]
=begin
# for Ruby m17n :: ?x --> String --> char-code ( getbyte(0) )
KEY_TBL.map!{|inf|
if inf.kind_of?(Array)
inf[0] = inf[0].getbyte(0) if inf[0].kind_of?(String)
inf[1] = inf[1].getbyte(0) if inf[1].kind_of?(String)
end
inf
}
PROC_TBL.map!{|inf|
if inf.kind_of?(Array)
inf[0] = inf[0].getbyte(0) if inf[0].kind_of?(String)
end
inf
}
=end
_setup_subst_table(KEY_TBL, PROC_TBL)
def self.ret_val(val)
val
end
end
def self._config_keys
['packagecmd']
end
end
class SiteCommand < TkValidateCommand
class ValidateArgs < TkUtil::CallbackSubst
KEY_TBL = [
[ ?s, ?b, :compatible ],
[ ?t, ?w, :token ],
nil
]
PROC_TBL = [
[ ?b, TkComm.method(:bool) ],
[ ?w, TkComm.method(:window) ],
nil
]
=begin
# for Ruby m17n :: ?x --> String --> char-code ( getbyte(0) )
KEY_TBL.map!{|inf|
if inf.kind_of?(Array)
inf[0] = inf[0].getbyte(0) if inf[0].kind_of?(String)
inf[1] = inf[1].getbyte(0) if inf[1].kind_of?(String)
end
inf
}
PROC_TBL.map!{|inf|
if inf.kind_of?(Array)
inf[0] = inf[0].getbyte(0) if inf[0].kind_of?(String)
end
inf
}
=end
_setup_subst_table(KEY_TBL, PROC_TBL)
def self.ret_val(val)
val
end
end
def self._config_keys
['sitecmd']
end
end
def self.__validation_class_list
super() << PackageCommand << SiteCommand
end
class << self
Tk::ValidateConfigure.__def_validcmd(binding, PackageCommand)
Tk::ValidateConfigure.__def_validcmd(binding, SiteCommand)
end
###################################
class DnD_Handle < TkUtil::CallbackSubst
KEY_TBL = [
[ ?i, ?s, :ip_name ],
[ ?v, ?v, :value ],
[ ?W, ?w, :widget ],
nil
]
PROC_TBL = [
[ ?i, TkComm.method(:string) ],
[ ?v, TkComm.method(:tk_tcl2ruby) ],
[ ?w, TkComm.method(:window) ],
nil
]
=begin
# for Ruby m17n :: ?x --> String --> char-code ( getbyte(0) )
KEY_TBL.map!{|inf|
if inf.kind_of?(Array)
inf[0] = inf[0].getbyte(0) if inf[0].kind_of?(String)
inf[1] = inf[1].getbyte(0) if inf[1].kind_of?(String)
end
inf
}
PROC_TBL.map!{|inf|
if inf.kind_of?(Array)
inf[0] = inf[0].getbyte(0) if inf[0].kind_of?(String)
end
inf
}
=end
_setup_subst_table(KEY_TBL, PROC_TBL)
end
def self.source_handler(win, datatype, cmd=Proc.new, *args)
_bind_for_event_class(DnD_Handle,
['::blt::drag&drop', 'source', win, 'handler'],
cmd, *args)
end
def self.target_handler(win, datatype, cmd=Proc.new, *args)
_bind_for_event_class(DnD_Handle,
['::blt::drag&drop', 'target', win, 'handler'],
cmd, *args)
end
###################################
def self.init_source(win)
tk_call('::blt::drag&drop', 'source', win)
end
def self.source()
list(tk_call('::blt::drag&drop', 'source'))
end
def self.source_handler_list(win)
simplelist(tk_call('::blt::drag&drop', 'source', win, 'handler'))
end
def self.source_handler_info(win, type)
tk_tcl2ruby(tk_call('::blt::drag&drop', 'source', win, 'handler', type))
end
def self.target
list(tk_call('::blt::drag&drop', 'target'))
end
def self.target_handler_list(win)
simplelist(tk_call('::blt::drag&drop', 'target', win, 'handler'))
end
def self.handle_target(win, type, val=None)
tk_call('::blt::drag&drop', 'target', win, 'handle', type, val)
end
def self.token(win)
window(tk_call('::blt::drag&drop', 'token', win))
end
def self.drag(win, x, y)
tk_call('::blt::drag&drop', 'drag', win, x, y)
end
def self.drop(win, x, y)
tk_call('::blt::drag&drop', 'drop', win, x, y)
end
def self.errors(cmd=Proc.new)
tk_call('::blt::drag&drop', 'errors', cmd)
end
def self.active
bool(tk_call('::blt::drag&drop', 'active'))
end
def self.location(x=None, y=None)
list(tk_call('::blt::drag&drop', 'location', x, y))
end
end
end