wxruby3 0.9.2 → 0.9.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/INSTALL.md +35 -29
- data/README.md +24 -15
- data/ext/wxruby3/include/wxruby-ClientData.h +48 -0
- data/ext/wxruby3/include/wxruby-Validator.h +39 -0
- data/ext/wxruby3/include/wxruby-ValidatorBinding.h +64 -0
- data/ext/wxruby3/swig/custom/director.swg +8 -0
- data/ext/wxruby3/swig/mark_free_impl.i +0 -33
- data/lib/wx/core/bitmap_combobox.rb +17 -21
- data/lib/wx/core/combobox.rb +13 -3
- data/lib/wx/core/controlwithitems.rb +40 -130
- data/lib/wx/core/enum.rb +17 -1
- data/lib/wx/core/event.rb +6 -1
- data/lib/wx/core/evthandler.rb +8 -2
- data/lib/wx/core/generic_validator.rb +312 -0
- data/lib/wx/core/listbox.rb +2 -2
- data/lib/wx/core/log.rb +1 -1
- data/lib/wx/core/owner_drawn_combobox.rb +45 -0
- data/lib/wx/core/size.rb +4 -0
- data/lib/wx/core/sizer.rb +1 -2
- data/lib/wx/core/standard_paths.rb +22 -0
- data/lib/wx/core/text_entry.rb +4 -1
- data/lib/wx/core/validator.rb +70 -5
- data/lib/wx/core/window.rb +3 -7
- data/lib/wx/doc/art_locator.rb +1 -0
- data/lib/wx/doc/comboctrl.rb +18 -0
- data/lib/wx/doc/controlwithitems.rb +16 -0
- data/lib/wx/doc/date_picker_ctrl.rb +23 -0
- data/lib/wx/doc/editable_listbox.rb +44 -0
- data/lib/wx/doc/enum.rb +15 -0
- data/lib/wx/doc/event.rb +12 -0
- data/lib/wx/doc/extra/12_client_data.md +89 -0
- data/lib/wx/doc/extra/13_validators.md +139 -0
- data/lib/wx/doc/gdi_common.rb +4 -0
- data/lib/wx/doc/generic_validator.rb +95 -0
- data/lib/wx/doc/html/simple_html_listbox.rb +22 -0
- data/lib/wx/doc/num_validator.rb +387 -0
- data/lib/wx/doc/owner_drawn_combobox.rb +96 -0
- data/lib/wx/doc/pg/numeric_property_validator.rb +33 -0
- data/lib/wx/doc/static_bitmap.rb +25 -0
- data/lib/wx/doc/text_validator.rb +10 -0
- data/lib/wx/doc/validator.rb +113 -0
- data/lib/wx/doc/window.rb +30 -0
- data/lib/wx/html/simple_html_listbox.rb +24 -91
- data/lib/wx/keyword_defs.rb +34 -2
- data/lib/wx/rbn/ribbon_gallery.rb +0 -21
- data/lib/wx/version.rb +1 -1
- data/rakelib/lib/config/mingw.rb +12 -0
- data/rakelib/lib/core/include/client_data.inc +65 -0
- data/rakelib/lib/core/include/funcall.inc +1 -1
- data/rakelib/lib/core/package.rb +17 -2
- data/rakelib/lib/core/parameter.rb +1 -1
- data/rakelib/lib/core/spec_helper.rb +7 -1
- data/rakelib/lib/director/app.rb +18 -0
- data/rakelib/lib/director/app_traits.rb +3 -1
- data/rakelib/lib/director/bitmap_combobox.rb +2 -2
- data/rakelib/lib/director/combobox.rb +22 -0
- data/rakelib/lib/director/comboctrl.rb +1 -55
- data/rakelib/lib/director/ctrl_with_items.rb +88 -21
- data/rakelib/lib/director/date_picker_ctrl.rb +8 -6
- data/rakelib/lib/director/editable_listbox.rb +30 -0
- data/rakelib/lib/director/event.rb +102 -12
- data/rakelib/lib/director/event_handler.rb +3 -2
- data/rakelib/lib/director/functions.rb +4 -2
- data/rakelib/lib/director/generic_dirctrl.rb +17 -0
- data/rakelib/lib/director/grid_cell_attr.rb +0 -2
- data/rakelib/lib/director/grid_cell_editor.rb +0 -2
- data/rakelib/lib/director/grid_cell_renderer.rb +0 -2
- data/rakelib/lib/director/header_ctrl.rb +6 -1
- data/rakelib/lib/director/html_listbox.rb +96 -22
- data/rakelib/lib/director/num_validator.rb +495 -0
- data/rakelib/lib/director/numeric_property_validator.rb +131 -6
- data/rakelib/lib/director/owner_drawn_combobox.rb +192 -0
- data/rakelib/lib/director/pgproperty.rb +3 -29
- data/rakelib/lib/director/ribbon_button_bar.rb +3 -3
- data/rakelib/lib/director/ribbon_gallery.rb +3 -5
- data/rakelib/lib/director/sizer.rb +15 -4
- data/rakelib/lib/director/sizer_item.rb +13 -0
- data/rakelib/lib/director/static_bitmap.rb +28 -0
- data/rakelib/lib/director/text_entry.rb +4 -0
- data/rakelib/lib/director/text_validator.rb +124 -13
- data/rakelib/lib/director/toggle_button.rb +1 -0
- data/rakelib/lib/director/top_level_window.rb +0 -2
- data/rakelib/lib/director/tree_ctrl.rb +35 -0
- data/rakelib/lib/director/utils.rb +16 -2
- data/rakelib/lib/director/validator.rb +196 -21
- data/rakelib/lib/director/window.rb +16 -2
- data/rakelib/lib/extractor/function.rb +2 -1
- data/rakelib/lib/generate/analyzer.rb +1 -1
- data/rakelib/lib/generate/doc.rb +10 -4
- data/rakelib/lib/specs/interfaces.rb +2 -0
- data/rakelib/lib/swig_runner.rb +55 -9
- data/rakelib/lib/typemap/client_data.rb +67 -0
- data/rakelib/lib/typemap/common.rb +3 -3
- data/rakelib/lib/typemap/datetime.rb +1 -1
- data/rakelib/lib/typemap/tree_itemid.rb +2 -2
- data/samples/aui/aui.rb +1237 -1233
- data/samples/calendar/calendar.rb +293 -289
- data/samples/controls/get_item_sample.rb +83 -79
- data/samples/controls/htlbox.rb +331 -327
- data/samples/dialogs/dialogs.rb +682 -694
- data/samples/dialogs/wizard.rb +52 -55
- data/samples/dragdrop/dragdrop.rb +146 -142
- data/samples/drawing/bitmap.rb +29 -26
- data/samples/drawing/bitmap_image.rb +84 -80
- data/samples/drawing/graphics_drawing.rb +209 -205
- data/samples/drawing/image_prt.rb +344 -340
- data/samples/drawing/maths_images.rb +18 -1
- data/samples/drawing/rmagic_bitmap_image.rb +88 -84
- data/samples/etc/caret.rb +306 -0
- data/samples/etc/miniframe.rb +65 -60
- data/samples/etc/sash.rb +109 -105
- data/samples/etc/scrollwin.rb +86 -80
- data/samples/etc/system_settings.rb +216 -209
- data/samples/event/activation.rb +72 -67
- data/samples/event/event.rb +160 -153
- data/samples/event/threaded.rb +8 -1
- data/samples/event/update_ui_event.rb +67 -60
- data/samples/grid/grid.rb +188 -181
- data/samples/grid/gridtablebase.rb +136 -129
- data/samples/html/html.rb +208 -204
- data/samples/mdi/mdi.rb +59 -54
- data/samples/minimal/minimal.rb +54 -51
- data/samples/minimal/nothing.rb +1 -0
- data/samples/printing/printing.rb +367 -377
- data/samples/printing/printing2.rb +203 -198
- data/samples/propgrid/propgrid.rb +2312 -2308
- data/samples/propgrid/propgrid_minimal.rb +57 -50
- data/samples/ribbon/ribbon.rb +780 -774
- data/samples/sampler/ext.rb +0 -33
- data/samples/sampler/sample.rb +4 -9
- data/samples/sampler.rb +1 -1
- data/samples/splash/splash.rb +118 -116
- data/samples/text/rich_textctrl.rb +207 -201
- data/samples/text/richtext.rb +1409 -1405
- data/samples/text/scintilla.rb +137 -128
- data/samples/text/textctrl.rb +89 -83
- data/samples/text/unicode.rb +175 -168
- data/samples/treectrl/treectrl.rb +1430 -1426
- data/samples/widgets/activityindicator.rb +95 -0
- data/samples/widgets/art/widgets/activityindicator.xpm +278 -0
- data/samples/widgets/art/widgets/bmpbtn.xpm +37 -0
- data/samples/widgets/art/widgets/bmpcombobox.xpm +54 -0
- data/samples/widgets/art/widgets/button.xpm +54 -0
- data/samples/widgets/art/widgets/checkbox.xpm +54 -0
- data/samples/{bigdemo/icons → widgets/art/widgets}/choice.xpm +1 -1
- data/samples/widgets/art/widgets/choicebk.xpm +54 -0
- data/samples/widgets/art/widgets/clrpicker.xpm +193 -0
- data/samples/widgets/art/widgets/combobox.xpm +54 -0
- data/samples/widgets/art/widgets/datepick.xpm +200 -0
- data/samples/widgets/art/widgets/dirctrl.xpm +54 -0
- data/samples/widgets/art/widgets/dirpicker.xpm +213 -0
- data/samples/widgets/art/widgets/filepicker.xpm +214 -0
- data/samples/widgets/art/widgets/fontpicker.xpm +185 -0
- data/samples/widgets/art/widgets/gauge.xpm +54 -0
- data/samples/widgets/art/widgets/header.xpm +54 -0
- data/samples/widgets/art/widgets/hyperlnk.xpm +54 -0
- data/samples/widgets/art/widgets/listbook.xpm +54 -0
- data/samples/widgets/art/widgets/listbox.xpm +54 -0
- data/samples/widgets/art/widgets/native.xpm +81 -0
- data/samples/widgets/art/widgets/notebook.xpm +54 -0
- data/samples/widgets/art/widgets/odcombobox.xpm +54 -0
- data/samples/widgets/art/widgets/radiobox.xpm +54 -0
- data/samples/widgets/art/widgets/scrolbar.xpm +54 -0
- data/samples/widgets/art/widgets/slider.xpm +54 -0
- data/samples/widgets/art/widgets/spinbtn.xpm +40 -0
- data/samples/widgets/art/widgets/statbmp.xpm +40 -0
- data/samples/widgets/art/widgets/statbox.xpm +54 -0
- data/samples/widgets/art/widgets/stattext.xpm +54 -0
- data/samples/widgets/art/widgets/text.xpm +54 -0
- data/samples/widgets/art/widgets/timepick.xpm +207 -0
- data/samples/widgets/art/widgets/toggle.xpm +54 -0
- data/samples/widgets/art/widgets/toucan.png +0 -0
- data/samples/widgets/bmpcombobox.rb +651 -0
- data/samples/widgets/button.rb +462 -0
- data/samples/widgets/checkbox.rb +211 -0
- data/samples/widgets/choice.rb +287 -0
- data/samples/widgets/clrpicker.rb +156 -0
- data/samples/widgets/combobox.rb +516 -0
- data/samples/widgets/datepick.rb +215 -0
- data/samples/widgets/dirctrl.rb +265 -0
- data/samples/widgets/dirpicker.rb +158 -0
- data/samples/widgets/editlbox.rb +122 -0
- data/samples/widgets/filectrl.rb +216 -0
- data/samples/widgets/filepicker.rb +214 -0
- data/samples/widgets/fontpicker.rb +135 -0
- data/samples/widgets/gauge.rb +311 -0
- data/samples/widgets/headerctrl.rb +236 -0
- data/samples/widgets/hyperlink.rb +203 -0
- data/samples/widgets/itemcontainer.rb +185 -0
- data/samples/widgets/listbox.rb +473 -0
- data/samples/widgets/notebook.rb +488 -0
- data/samples/widgets/odcombobox.rb +608 -0
- data/samples/widgets/radiobox.rb +328 -0
- data/samples/widgets/searchctrl.rb +159 -0
- data/samples/widgets/slider.rb +594 -0
- data/samples/widgets/spinbtn.rb +443 -0
- data/samples/widgets/statbmp.rb +130 -0
- data/samples/widgets/static.rb +436 -0
- data/samples/widgets/textctrl.rb +700 -0
- data/samples/widgets/timepick.rb +148 -0
- data/samples/widgets/tn_widgets.png +0 -0
- data/samples/widgets/toggle.rb +385 -0
- data/samples/widgets/widgets.rb +1233 -0
- data/samples/xrc/custom_xrc_sample.rb +47 -41
- data/samples/xrc/xrc_sample.rb +53 -47
- data/tests/test_event_handling.rb +52 -34
- data/tests/test_events.rb +7 -0
- data/tests/test_item_data.rb +24 -0
- data/tests/test_sizer.rb +44 -1
- data/tests/test_validators.rb +805 -0
- metadata +92 -138
- data/lib/wx/core/choice.rb +0 -14
- data/lib/wx/core/combo_ctrl.rb +0 -110
- data/rakelib/lib/typemap/grid_client_data.rb +0 -58
- data/samples/bigdemo/About.rbw +0 -39
- data/samples/bigdemo/ColorPanel.rbw +0 -23
- data/samples/bigdemo/GridSimple.rbw +0 -78
- data/samples/bigdemo/MDIDemo.rbw +0 -57
- data/samples/bigdemo/PopupMenu.rbw +0 -146
- data/samples/bigdemo/ShapedWindow.rbw +0 -128
- data/samples/bigdemo/Sizers.rbw +0 -541
- data/samples/bigdemo/bigdemo.rb +0 -817
- data/samples/bigdemo/demoTemplate.rbw +0 -33
- data/samples/bigdemo/helpfile.htb +0 -0
- data/samples/bigdemo/icons/Test 015.jpg +0 -0
- data/samples/bigdemo/icons/Test 015.png +0 -0
- data/samples/bigdemo/icons/choice.bmp +0 -0
- data/samples/bigdemo/icons/combo.bmp +0 -0
- data/samples/bigdemo/icons/combo.xpm +0 -27
- data/samples/bigdemo/icons/copy.xpm +0 -25
- data/samples/bigdemo/icons/cut.xpm +0 -24
- data/samples/bigdemo/icons/gauge.bmp +0 -0
- data/samples/bigdemo/icons/gauge.xpm +0 -27
- data/samples/bigdemo/icons/help.xpm +0 -25
- data/samples/bigdemo/icons/list.bmp +0 -0
- data/samples/bigdemo/icons/list.xpm +0 -27
- data/samples/bigdemo/icons/mondrian.ico +0 -0
- data/samples/bigdemo/icons/mondrian.xpm +0 -44
- data/samples/bigdemo/icons/new.xpm +0 -24
- data/samples/bigdemo/icons/ogl.ico +0 -0
- data/samples/bigdemo/icons/ogl.xpm +0 -45
- data/samples/bigdemo/icons/open.xpm +0 -26
- data/samples/bigdemo/icons/paste.bmp +0 -0
- data/samples/bigdemo/icons/paste.xpm +0 -38
- data/samples/bigdemo/icons/pointy.png +0 -0
- data/samples/bigdemo/icons/preview.xpm +0 -26
- data/samples/bigdemo/icons/print.xpm +0 -26
- data/samples/bigdemo/icons/radio.bmp +0 -0
- data/samples/bigdemo/icons/radio.xpm +0 -27
- data/samples/bigdemo/icons/robert.xpm +0 -415
- data/samples/bigdemo/icons/sashtest.ico +0 -0
- data/samples/bigdemo/icons/save.xpm +0 -25
- data/samples/bigdemo/icons/smiles.bmp +0 -0
- data/samples/bigdemo/icons/smiles.xpm +0 -39
- data/samples/bigdemo/icons/smiley.ico +0 -0
- data/samples/bigdemo/icons/smiley.xpm +0 -42
- data/samples/bigdemo/icons/stattext.xpm +0 -24
- data/samples/bigdemo/icons/test2.bmp +0 -0
- data/samples/bigdemo/icons/test2.png +0 -0
- data/samples/bigdemo/icons/test2.xpm +0 -79
- data/samples/bigdemo/icons/text.bmp +0 -0
- data/samples/bigdemo/icons/text.xpm +0 -27
- data/samples/bigdemo/icons/tog1.bmp +0 -0
- data/samples/bigdemo/icons/tog1.xpm +0 -38
- data/samples/bigdemo/icons/tog2.bmp +0 -0
- data/samples/bigdemo/icons/tog2.xpm +0 -38
- data/samples/bigdemo/icons/wxruby-128x128.png +0 -0
- data/samples/bigdemo/icons/wxwin.ico +0 -0
- data/samples/bigdemo/icons/wxwin16x16.png +0 -0
- data/samples/bigdemo/icons/wxwin16x16.xpm +0 -25
- data/samples/bigdemo/icons/wxwin32x32.png +0 -0
- data/samples/bigdemo/icons/wxwin48x48.png +0 -0
- data/samples/bigdemo/run.rb +0 -98
- data/samples/bigdemo/tips.txt +0 -7
- data/samples/bigdemo/utils.rb +0 -20
- data/samples/bigdemo/wxArtProvider.rbw +0 -282
- data/samples/bigdemo/wxBitmapButton.rbw +0 -65
- data/samples/bigdemo/wxButton.rbw +0 -64
- data/samples/bigdemo/wxCalendarCtrl.rbw +0 -59
- data/samples/bigdemo/wxCheckBox.rbw +0 -50
- data/samples/bigdemo/wxCheckListBox.rbw +0 -65
- data/samples/bigdemo/wxChoice.rbw +0 -47
- data/samples/bigdemo/wxChoicebook.rbw +0 -78
- data/samples/bigdemo/wxColourDialog.rbw +0 -33
- data/samples/bigdemo/wxComboBox.rbw +0 -77
- data/samples/bigdemo/wxCursor.rbw +0 -136
- data/samples/bigdemo/wxDialog.rbw +0 -74
- data/samples/bigdemo/wxDirDialog.rbw +0 -29
- data/samples/bigdemo/wxDragImage.rbw +0 -70
- data/samples/bigdemo/wxFileDialog.rbw +0 -37
- data/samples/bigdemo/wxFileDialog_Save.rbw +0 -35
- data/samples/bigdemo/wxFindReplaceDialog.rbw +0 -82
- data/samples/bigdemo/wxFontDialog.rbw +0 -200
- data/samples/bigdemo/wxFrame.rbw +0 -53
- data/samples/bigdemo/wxGauge.rbw +0 -65
- data/samples/bigdemo/wxGenericDirCtrl.rbw +0 -74
- data/samples/bigdemo/wxGrid.rbw +0 -66
- data/samples/bigdemo/wxHtmlHelpController.rbw +0 -52
- data/samples/bigdemo/wxListBox.rbw +0 -140
- data/samples/bigdemo/wxListCtrl_virtual.rbw +0 -112
- data/samples/bigdemo/wxMDIWindows.rbw +0 -50
- data/samples/bigdemo/wxMenu.rbw +0 -247
- data/samples/bigdemo/wxMessageDialog.rbw +0 -27
- data/samples/bigdemo/wxMiniFrame.rbw +0 -70
- data/samples/bigdemo/wxMultipleChoiceDialog.rbw +0 -29
- data/samples/bigdemo/wxNotebook.rbw +0 -136
- data/samples/bigdemo/wxProgressDialog.rbw +0 -43
- data/samples/bigdemo/wxRadioBox.rbw +0 -72
- data/samples/bigdemo/wxRadioButton.rbw +0 -125
- data/samples/bigdemo/wxSashWindow.rbw +0 -141
- data/samples/bigdemo/wxScrolledMessageDialog.rbw +0 -57
- data/samples/bigdemo/wxScrolledWindow.rbw +0 -199
- data/samples/bigdemo/wxSingleChoiceDialog.rbw +0 -33
- data/samples/bigdemo/wxSlider.rbw +0 -42
- data/samples/bigdemo/wxSpinButton.rbw +0 -50
- data/samples/bigdemo/wxSpinCtrl.rbw +0 -51
- data/samples/bigdemo/wxSplitterWindow.rbw +0 -63
- data/samples/bigdemo/wxStaticBitmap.rbw +0 -47
- data/samples/bigdemo/wxStaticText.rbw +0 -55
- data/samples/bigdemo/wxStatusBar.rbw +0 -126
- data/samples/bigdemo/wxTextCtrl.rbw +0 -149
- data/samples/bigdemo/wxTextEntryDialog.rbw +0 -31
- data/samples/bigdemo/wxToggleButton.rbw +0 -49
- data/samples/bigdemo/wxToolBar.rbw +0 -131
- data/samples/bigdemo/wxTreeCtrl.rbw +0 -191
- data/samples/caret/caret.rb +0 -298
- data/samples/caret/mondrian.xpm +0 -44
- data/samples/controls/books.rb +0 -189
- data/samples/controls/choice.xpm +0 -27
- data/samples/controls/combo.xpm +0 -27
- data/samples/controls/controls.rb +0 -1099
- data/samples/controls/gauge.xpm +0 -27
- data/samples/controls/list.xpm +0 -27
- data/samples/controls/mondrian.ico +0 -0
- data/samples/controls/mondrian.xpm +0 -44
- data/samples/controls/radio.xpm +0 -27
- data/samples/controls/stattext.xpm +0 -24
- data/samples/controls/test2.bmp +0 -0
- data/samples/controls/text.xpm +0 -27
- data/samples/controls/tn_books.png +0 -0
- data/samples/controls/tn_controls.png +0 -0
- data/samples/etc/choice.rb +0 -87
- data/samples/etc/tn_choice.png +0 -0
- data/samples/text/mondrian.ico +0 -0
- data/samples/text/mondrian.xpm +0 -44
- /data/samples/{caret → etc}/tn_caret.png +0 -0
data/lib/wx/core/text_entry.rb
CHANGED
@@ -13,7 +13,10 @@ module Wx
|
|
13
13
|
wx_auto_complete = instance_method :auto_complete
|
14
14
|
define_method :auto_complete do |completer|
|
15
15
|
if wx_auto_complete.bind(self).call(completer)
|
16
|
-
@completer = completer # keep the Ruby object alive
|
16
|
+
@completer = completer.is_a?(Wx::TextCompleter) ? completer : nil # keep the Ruby object alive or cleanup
|
17
|
+
true
|
18
|
+
else
|
19
|
+
false
|
17
20
|
end
|
18
21
|
end
|
19
22
|
|
data/lib/wx/core/validator.rb
CHANGED
@@ -1,15 +1,80 @@
|
|
1
1
|
# Copyright (c) 2023 M.J.N. Corino, The Netherlands
|
2
2
|
#
|
3
3
|
# This software is released under the MIT license.
|
4
|
-
#
|
5
|
-
# Some parts are
|
6
|
-
# Copyright 2004-2007, wxRuby development team
|
7
|
-
# released under the MIT-like wxRuby2 license
|
8
4
|
|
9
5
|
class Wx::Validator
|
6
|
+
|
10
7
|
# Default implementation of clone, may need to be over-ridden if
|
11
8
|
# custom subclasses should state variables that need to be copied
|
9
|
+
# NOTE: There is no way to copy the bindings here so do NOT
|
12
10
|
def clone
|
13
|
-
|
11
|
+
begin
|
12
|
+
self.class.new(self)
|
13
|
+
rescue
|
14
|
+
p $!
|
15
|
+
raise
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
# overload for customized functionality
|
20
|
+
def do_transfer_from_window
|
21
|
+
nil # by default just return nil
|
14
22
|
end
|
23
|
+
protected :do_transfer_from_window
|
24
|
+
|
25
|
+
# overload for customized functionality
|
26
|
+
def do_transfer_to_window(_data)
|
27
|
+
true # by default just return true
|
28
|
+
end
|
29
|
+
protected :do_transfer_to_window
|
30
|
+
|
31
|
+
protected :do_on_transfer_from_window
|
32
|
+
protected :do_on_transfer_to_window
|
33
|
+
|
34
|
+
module Binding
|
35
|
+
def self.included(base)
|
36
|
+
wx_on_transfer_from_window = base.instance_method :on_transfer_from_window
|
37
|
+
base.define_method :on_transfer_from_window do |meth = nil, &block|
|
38
|
+
proc = if block and not meth
|
39
|
+
block
|
40
|
+
elsif meth and not block
|
41
|
+
h_meth = case meth
|
42
|
+
when Symbol, String then self.method(meth)
|
43
|
+
when Proc then meth
|
44
|
+
when Method then meth
|
45
|
+
end
|
46
|
+
# check arity == 1
|
47
|
+
if h_meth.arity != 1
|
48
|
+
Kernel.raise ArgumentError,
|
49
|
+
"on_transfer_from_window handler should accept a single argument"
|
50
|
+
end
|
51
|
+
h_meth
|
52
|
+
end
|
53
|
+
wx_on_transfer_from_window.bind(self).call(proc)
|
54
|
+
end
|
55
|
+
|
56
|
+
wx_on_transfer_to_window = base.instance_method :on_transfer_to_window
|
57
|
+
base.define_method :on_transfer_to_window do |meth = nil, &block|
|
58
|
+
proc = if block and not meth
|
59
|
+
block
|
60
|
+
elsif meth and not block
|
61
|
+
h_meth = case meth
|
62
|
+
when Symbol, String then self.method(meth)
|
63
|
+
when Proc then meth
|
64
|
+
when Method then meth
|
65
|
+
end
|
66
|
+
# check arity == 0
|
67
|
+
if h_meth.arity != 0
|
68
|
+
Kernel.raise ArgumentError,
|
69
|
+
"on_transfer_to_window handler should not accept any argument"
|
70
|
+
end
|
71
|
+
h_meth
|
72
|
+
end
|
73
|
+
wx_on_transfer_to_window.bind(self).call(proc)
|
74
|
+
end
|
75
|
+
end
|
76
|
+
end
|
77
|
+
|
78
|
+
include Binding
|
79
|
+
|
15
80
|
end
|
data/lib/wx/core/window.rb
CHANGED
@@ -26,13 +26,9 @@ class Wx::Window
|
|
26
26
|
# In case a more explicit option is preferred.
|
27
27
|
alias :wx_id :get_id
|
28
28
|
|
29
|
-
#
|
30
|
-
|
31
|
-
|
32
|
-
# Window#raise completely, but for now, offer alternatives to
|
33
|
-
# raise/lower that could replace them in future versions.
|
34
|
-
alias :bring_to_front :raise
|
35
|
-
alias :send_to_back :lower
|
29
|
+
# Z-order alternatives
|
30
|
+
alias :bring_to_front :raise_window
|
31
|
+
alias :send_to_back :lower_window
|
36
32
|
|
37
33
|
# Recursively searches all windows below +self+ and returns the first
|
38
34
|
# window which has the id +an_id+. This corresponds to the find_window
|
data/lib/wx/doc/art_locator.rb
CHANGED
@@ -59,6 +59,7 @@ module Wx
|
|
59
59
|
# @param [String,nil] art_path base path to look up the art file
|
60
60
|
# @param [String,nil] art_section optional owner folder name for art files
|
61
61
|
# @param [Wx::BitmapType,nil] bmp_type bitmap type of art file
|
62
|
+
# @return [String,nil] full path of art file or nil if not found
|
62
63
|
def find_art(art_name, art_type: nil, art_path: nil, art_section: nil, bmp_type: nil) end
|
63
64
|
|
64
65
|
end
|
@@ -0,0 +1,18 @@
|
|
1
|
+
# :stopdoc:
|
2
|
+
# Copyright (c) 2023 M.J.N. Corino, The Netherlands
|
3
|
+
#
|
4
|
+
# This software is released under the MIT license.
|
5
|
+
# :startdoc:
|
6
|
+
|
7
|
+
|
8
|
+
module Wx
|
9
|
+
|
10
|
+
class OwnerDrawnComboBox < ComboCtrl
|
11
|
+
|
12
|
+
alias :get_item_data :get_client_object
|
13
|
+
|
14
|
+
alias :set_item_data :set_client_object
|
15
|
+
|
16
|
+
end
|
17
|
+
|
18
|
+
end
|
@@ -9,6 +9,14 @@ module Wx
|
|
9
9
|
|
10
10
|
class ControlWithItems
|
11
11
|
|
12
|
+
alias :get_client_data :get_client_object
|
13
|
+
|
14
|
+
alias :set_client_data :set_client_object
|
15
|
+
|
16
|
+
alias :has_client_data :has_client_object_data
|
17
|
+
|
18
|
+
alias :has_client_data? :has_client_object_data
|
19
|
+
|
12
20
|
# Yield each string to the given block.
|
13
21
|
# Returns an Enumerator if no block given.
|
14
22
|
# @yieldparam [String] string the string yielded
|
@@ -22,6 +30,14 @@ module Wx
|
|
22
30
|
def is_sorted; end
|
23
31
|
alias :sorted? :is_sorted
|
24
32
|
|
33
|
+
alias :get_list_selection :get_selection
|
34
|
+
|
35
|
+
alias :set_list_selection :set_selection
|
36
|
+
|
37
|
+
alias :get_list_string_selection :get_string_selection
|
38
|
+
|
39
|
+
alias :set_list_string_selection :set_string_selection
|
40
|
+
|
25
41
|
end
|
26
42
|
|
27
43
|
end
|
@@ -0,0 +1,23 @@
|
|
1
|
+
# :stopdoc:
|
2
|
+
# Copyright (c) 2023 M.J.N. Corino, The Netherlands
|
3
|
+
#
|
4
|
+
# This software is released under the MIT license.
|
5
|
+
# :startdoc:
|
6
|
+
|
7
|
+
|
8
|
+
module Wx
|
9
|
+
|
10
|
+
class DatePickerCtrl < Control
|
11
|
+
|
12
|
+
# If the control had been previously limited to a range of dates using #set_range, returns the lower and upper bounds of this range.
|
13
|
+
#
|
14
|
+
# If no range is set (or only one of the bounds is set), dt1 and/or dt2 are set to be invalid.
|
15
|
+
#
|
16
|
+
# Notice that when using a native MSW implementation of this control the lower range is always set, even
|
17
|
+
# if #set_range hadn't been called explicitly, as the native control only supports dates later than year 1601.
|
18
|
+
# @return [Array(Time, Time),nil] a set with the lower and upper range limit or nil if no range previously set
|
19
|
+
def get_range; end
|
20
|
+
|
21
|
+
end
|
22
|
+
|
23
|
+
end
|
@@ -0,0 +1,44 @@
|
|
1
|
+
# :stopdoc:
|
2
|
+
# Copyright (c) 2023 M.J.N. Corino, The Netherlands
|
3
|
+
#
|
4
|
+
# This software is released under the MIT license.
|
5
|
+
# :startdoc:
|
6
|
+
|
7
|
+
|
8
|
+
module Wx
|
9
|
+
|
10
|
+
class EditableListBox < Panel
|
11
|
+
|
12
|
+
# Returns list control of composite.
|
13
|
+
# @return [Wx::ListCtrl]
|
14
|
+
def get_list_ctrl; end
|
15
|
+
alias :list_ctrl :get_list_ctrl
|
16
|
+
|
17
|
+
# Returns button of composite.
|
18
|
+
# @return [Wx::BitmapButton]
|
19
|
+
def get_del_button; end
|
20
|
+
alias :del_button :get_del_button
|
21
|
+
|
22
|
+
# Returns button of composite.
|
23
|
+
# @return [Wx::BitmapButton]
|
24
|
+
def get_new_button; end
|
25
|
+
alias :new_button :get_new_button
|
26
|
+
|
27
|
+
# Returns button of composite.
|
28
|
+
# @return [Wx::BitmapButton]
|
29
|
+
def get_up_button; end
|
30
|
+
alias :up_button :get_up_button
|
31
|
+
|
32
|
+
# Returns button of composite.
|
33
|
+
# @return [Wx::BitmapButton]
|
34
|
+
def get_down_button; end
|
35
|
+
alias :down_button :get_down_button
|
36
|
+
|
37
|
+
# Returns button of composite.
|
38
|
+
# @return [Wx::BitmapButton]
|
39
|
+
def get_edit_button; end
|
40
|
+
alias :edit_button :get_edit_button
|
41
|
+
|
42
|
+
end
|
43
|
+
|
44
|
+
end
|
data/lib/wx/doc/enum.rb
CHANGED
@@ -68,6 +68,21 @@ module Wx
|
|
68
68
|
# @return [Boolean]
|
69
69
|
def !; end
|
70
70
|
|
71
|
+
# Returns true if all bits that are set (=1) in mask are also set in self; returns false otherwise.
|
72
|
+
# @param [Integer] mask
|
73
|
+
# @return [Boolean]
|
74
|
+
def allbits?(mask) end
|
75
|
+
|
76
|
+
# Returns true if any bit that is set (=1) in mask is also set in self; returns false otherwise.
|
77
|
+
# @param [Integer] mask
|
78
|
+
# @return [Boolean]
|
79
|
+
def anybits?(mask) end
|
80
|
+
|
81
|
+
# Returns true if no bit that is set (=1) in mask is also set in self; returns false otherwise.
|
82
|
+
# @param [Integer] mask
|
83
|
+
# @return [Boolean]
|
84
|
+
def nobits?(mask) end
|
85
|
+
|
71
86
|
# Return next integer value from enum's value.
|
72
87
|
# @return [Integer] next integer value
|
73
88
|
def succ; end
|
data/lib/wx/doc/event.rb
CHANGED
@@ -27,4 +27,16 @@ module Wx
|
|
27
27
|
|
28
28
|
end
|
29
29
|
|
30
|
+
class CommandEvent < Event
|
31
|
+
|
32
|
+
alias :set_client_data :set_client_object
|
33
|
+
|
34
|
+
alias :client_data= :set_client_object
|
35
|
+
|
36
|
+
alias :get_client_data :get_client_object
|
37
|
+
|
38
|
+
alias :client_data :get_client_object
|
39
|
+
|
40
|
+
end
|
41
|
+
|
30
42
|
end
|
@@ -0,0 +1,89 @@
|
|
1
|
+
<!--
|
2
|
+
# @markup markdown
|
3
|
+
# @title 12. Client/User data with wxRuby
|
4
|
+
-->
|
5
|
+
|
6
|
+
# 12. Client/User data with wxRuby
|
7
|
+
|
8
|
+
## Introduction
|
9
|
+
|
10
|
+
The wxWidgets library has widespread support for attaching arbitrary client (or user) data to GUI elements like
|
11
|
+
windows (all event handlers actually), window items, sizer items etc.
|
12
|
+
To cater to various C++ use cases in most instances this support covers both specific wxWidgets defined types (like
|
13
|
+
wxClientData and wxObject instances) and untyped data pointers (represented as `void *`) with subtle but essential
|
14
|
+
differences.
|
15
|
+
|
16
|
+
wxRuby implements a fully compatible version of this support.
|
17
|
+
|
18
|
+
## Everything is an Object
|
19
|
+
|
20
|
+
As Ruby does not do untyped data (everything is an Object), and having two different options is confusing anyway,
|
21
|
+
wxRuby provides only a single option and more or less unifies the interface across the entire library.
|
22
|
+
In Ruby anywhere the original wxWidgets library supports some type of client (or user) data attachment wxRuby will
|
23
|
+
support the attachment of any arbitrary Ruby `Object` by either the method `#set_client_object` (where C++ supports
|
24
|
+
`SetClientData` and `SetClientObject`) or `#set_user_data` (where C++ supports `SetUserData`). Data retrieval
|
25
|
+
is supported by complementary `#get_client_object` or `#get_user_data` methods in all cases.
|
26
|
+
Wherever C++ supports `SetClientObject` wxRuby also provides the method aliases `#set_client_data` and `#get_client_data`.
|
27
|
+
|
28
|
+
Another difference with C++ is that for typed client data in wxWidgets developers could leverage object destruction as
|
29
|
+
callback trigger (through the implementation of virtual destructors) to handle any required 'unlinking' logic. This
|
30
|
+
obviously does not apply to untyped data (one of the 'subtle' differences).
|
31
|
+
As Ruby does not provide any usable object destruction hooks this does not work there.
|
32
|
+
Ruby however has 'Duck-typing' which is what wxRuby uses to provide support for a unlinking callback 'hook' for attached
|
33
|
+
client data.
|
34
|
+
|
35
|
+
> Any attached Ruby Object implementing (responding to) the method `#client_data_unlinked` will have that method called after the
|
36
|
+
> attached object has been detached from the element it was attached to (either because of data replacement or element
|
37
|
+
> deletion).
|
38
|
+
|
39
|
+
Regard the following example.
|
40
|
+
|
41
|
+
```ruby
|
42
|
+
frame = Wx::Frame.new(nil, Wx::ID_ANY)
|
43
|
+
|
44
|
+
# attach a hash with user data
|
45
|
+
frame.set_client_data({ text: 'A string', float: 3.14 })
|
46
|
+
|
47
|
+
# ... do something with frame
|
48
|
+
|
49
|
+
# replace the user data
|
50
|
+
frame.set_client_data([1,2,3,4])
|
51
|
+
|
52
|
+
# ... do something else with frame
|
53
|
+
```
|
54
|
+
|
55
|
+
In this case standard Ruby object are attached. After attachment the object can be retrieved using a call to `get_client_data`
|
56
|
+
anywhere access to the frame instance is available.
|
57
|
+
|
58
|
+
Using a specially derived (or adapted) object a developer can handle specific logic after the object has been unlinked
|
59
|
+
like in this example:
|
60
|
+
|
61
|
+
```ruby
|
62
|
+
# define a user data class
|
63
|
+
class MyUserData
|
64
|
+
def initialize(payload)
|
65
|
+
@payload = payload
|
66
|
+
end
|
67
|
+
attr_reader :payload
|
68
|
+
|
69
|
+
def client_data_unlinked
|
70
|
+
# handle some logic
|
71
|
+
end
|
72
|
+
end
|
73
|
+
|
74
|
+
# ...
|
75
|
+
|
76
|
+
# attach data to some window
|
77
|
+
win.set_client_data(MyUserData.new(some_payload_data))
|
78
|
+
|
79
|
+
# ...
|
80
|
+
|
81
|
+
# reset user data for some reason (will call MyUserData#client_data_unlinked after replacement)
|
82
|
+
win.set_client_data(nil)
|
83
|
+
```
|
84
|
+
|
85
|
+
# CommandEvent data
|
86
|
+
|
87
|
+
wxRuby also fully supports the propagation of attached client data to Wx::CommandEvent objects (see
|
88
|
+
{Wx::CommandEvent#get_client_object} and {Wx::CommandEvent#set_client_object}).
|
89
|
+
As mentioned above wxRuby provides the method aliases `#set_client_data` and `#get_client_data` here also.
|
@@ -0,0 +1,139 @@
|
|
1
|
+
<!--
|
2
|
+
# @markup markdown
|
3
|
+
# @title 13. Validators and data binding
|
4
|
+
-->
|
5
|
+
|
6
|
+
# 13. Validators and data binding
|
7
|
+
|
8
|
+
## Introduction
|
9
|
+
|
10
|
+
wxRuby fully supports validator classes offering input validation and/or data binding and/or event filtering.
|
11
|
+
|
12
|
+
## Validation
|
13
|
+
|
14
|
+
The base Wx::Validator class defines the method {Wx::Validator#validate} which is called when validation of the
|
15
|
+
value or content of the associated window is required.
|
16
|
+
|
17
|
+
The implementation of this method should (somehow) retrieve the value of the associated window and validate that
|
18
|
+
value, returning `true` if valid or `false` otherwise. The default implementation always returns `false`.
|
19
|
+
|
20
|
+
An example would be:
|
21
|
+
|
22
|
+
```ruby
|
23
|
+
# define custom validator
|
24
|
+
class MyTextValidator < Wx::Validator
|
25
|
+
|
26
|
+
def validate(_parent)
|
27
|
+
txt = get_window.value
|
28
|
+
# validate that the control text starts with a capital if not empty
|
29
|
+
txt.empty? || (?A..?Z).include?(txt[0])
|
30
|
+
end
|
31
|
+
|
32
|
+
end
|
33
|
+
|
34
|
+
# ...
|
35
|
+
|
36
|
+
# assign custom validator to text control
|
37
|
+
text = Wx::TextCtrl.new(parent, MY_TEXT_ID)
|
38
|
+
text.set_validator(MyTextValidator.new)
|
39
|
+
```
|
40
|
+
|
41
|
+
The derived, specialized, validator classes {Wx::TextValidator}, {Wx::IntegerValidator}, {Wx::IntegerValidator} and
|
42
|
+
{Wx::FloatValidator} all have implementations that can be configured through specific options and do not
|
43
|
+
normally require an override to be defined.
|
44
|
+
|
45
|
+
Examples of using the standard validators would be:
|
46
|
+
|
47
|
+
```ruby
|
48
|
+
text = Wx::TextCtrl.new(parent, MY_TEXT_ID)
|
49
|
+
|
50
|
+
# accept only hexadecimal characters
|
51
|
+
text.set_validator(Wx::TextValidator.new(Wx::TextValidatorStyle::FILTER_XDIGITS))
|
52
|
+
|
53
|
+
# or only numbers between -20 and 20
|
54
|
+
text.set_validator(Wx::IntegerValidator.new(-20, 20))
|
55
|
+
```
|
56
|
+
|
57
|
+
## Event filtering
|
58
|
+
|
59
|
+
All validator classes are event handlers and can have event handling routines defined (see
|
60
|
+
[Event Handling](05_event-handling.md)).
|
61
|
+
When processing events the core implementation will allow any validator associated with a window to handle an event
|
62
|
+
before the associated window itself thereby allowing it to filter events (see {Wx::EvtHandler#process_event} for more
|
63
|
+
details).
|
64
|
+
|
65
|
+
The standard specialized validators use this functionality to filter entry of allowable characters (by handling
|
66
|
+
Wx::EVT_CHAR events).
|
67
|
+
|
68
|
+
## Data binding
|
69
|
+
|
70
|
+
Data binding concerns the transfer of a validator's associated window's value to or from a user definable storage (a
|
71
|
+
variable, memory cache entry, persistent storage ...).
|
72
|
+
|
73
|
+
To integrate with the core C++ implementation but allow for Ruby specific differences the scheme implemented for this
|
74
|
+
differs somewhat (in naming and functionality) from the original wxWidgets interface.
|
75
|
+
|
76
|
+
The responsibilities of the standard wxRuby interface for handling validator data binding is distributed over 2 base
|
77
|
+
methods and a mixin module.
|
78
|
+
|
79
|
+
- The protected {Wx::Validator#do_transfer_from_window} and {Wx::Validator#do_transfer_to_window} methods are
|
80
|
+
responsible for collecting and transferring data from/to the associated window (possibly applying conversions).<br>
|
81
|
+
<br>
|
82
|
+
These methods have default implementations in all of the derived validator classes and should not be overridden for
|
83
|
+
specializations of these as they will be ignored.<br>
|
84
|
+
Overriding these methods is necessary to implement data binding for any user defined specialization of the base
|
85
|
+
{Wx::Validator} class.<br>
|
86
|
+
<br>
|
87
|
+
- The methods the {Wx::Validator::Binding} mixin module provide the means to store data after collection from or retrieve data
|
88
|
+
before transfer to the associated window.<br>
|
89
|
+
<br>
|
90
|
+
The methods {Wx::Validator::Binding#on_transfer_from_window} and {Wx::Validator::Binding#on_transfer_to_window} provide
|
91
|
+
the means to specify user defined binding handlers for storing the data transferred from the associated window or retrieving the
|
92
|
+
data to transfer to the associated window. Like with event handling the handlers can be specified using a `String` or
|
93
|
+
`Symbol`, a `Proc` or a `Method`.<br>
|
94
|
+
<br>
|
95
|
+
The methods {Wx::Validator::Binding#do_on_transfer_from_window} and {Wx::Validator::Binding#do_on_transfer_to_window} by
|
96
|
+
default call the binding handlers if defined.
|
97
|
+
These methods can be overridden to create derived validator classes with dedicated data binding functionality like
|
98
|
+
with {Wx::GenericValidator}.
|
99
|
+
|
100
|
+
An example of a custom validator providing data binding would be:
|
101
|
+
|
102
|
+
```ruby
|
103
|
+
class MyTextValidator < Wx::Validator
|
104
|
+
|
105
|
+
def do_transfer_from_window
|
106
|
+
get_window.get_value
|
107
|
+
end
|
108
|
+
|
109
|
+
def do_transfer_to_window(val)
|
110
|
+
get_window.set_value(val)
|
111
|
+
true
|
112
|
+
end
|
113
|
+
|
114
|
+
end
|
115
|
+
|
116
|
+
# ...
|
117
|
+
|
118
|
+
# use custom validator
|
119
|
+
@data = nil # attribute to store data
|
120
|
+
text.set_validator(MyTextValidator.new)
|
121
|
+
text.get_validator.on_transfer_to_window { @data }
|
122
|
+
text.get_validator.on_transfer_from_window { |v| @data = v }
|
123
|
+
```
|
124
|
+
|
125
|
+
All derived, specialized, validators implement a dedicated value cache which can be accessed through the `#value` attribute
|
126
|
+
accessor. Through this accessor the data collected from the associated window can get retrieved or the data to be transferred
|
127
|
+
to the associated window set.
|
128
|
+
With these classes it is therefor not necessary to define binding handlers. Defining binding handlers can however still be
|
129
|
+
useful to implement a custom, persistent, storage solution.
|
130
|
+
|
131
|
+
### Wx::GenericValidator
|
132
|
+
|
133
|
+
The {Wx::GenericValidator} class provides an extendable standard implementation for data binding in combination with a
|
134
|
+
large collection of controls (see class documentation).
|
135
|
+
The implementation provides a standard accessor {Wx::GenericValidator#value} to get the data value collected
|
136
|
+
from the associated window or set the data to transfer to the associated window.
|
137
|
+
|
138
|
+
To add support for any control unsupported by the standard implementation the method {Wx::GenericValidator.define_handler}
|
139
|
+
is provided (see documentation for an example).
|
data/lib/wx/doc/gdi_common.rb
CHANGED
@@ -61,8 +61,12 @@ module Wx
|
|
61
61
|
|
62
62
|
alias :get_x :get_width
|
63
63
|
alias :x :get_width
|
64
|
+
alias :set_x :set_width
|
65
|
+
alias :x= :set_width
|
64
66
|
alias :get_y :get_height
|
65
67
|
alias :y :get_height
|
68
|
+
alias :set_y :set_height
|
69
|
+
alias :y= :set_height
|
66
70
|
|
67
71
|
# Set this size to the given size's width,height values
|
68
72
|
# @param [Wx::Size] sz
|
@@ -0,0 +1,95 @@
|
|
1
|
+
# :stopdoc:
|
2
|
+
# Copyright (c) 2023 M.J.N. Corino, The Netherlands
|
3
|
+
#
|
4
|
+
# This software is released under the MIT license.
|
5
|
+
# :startdoc:
|
6
|
+
|
7
|
+
|
8
|
+
module Wx
|
9
|
+
|
10
|
+
# Wx::GenericValidator performs data transfer (but not validation or filtering)
|
11
|
+
# for many type of controls.
|
12
|
+
#
|
13
|
+
# Wx::GenericValidator supports:
|
14
|
+
# - boolean type controls
|
15
|
+
# - Wx::CheckBox, Wx::RadioButton, Wx::ToggleButton, Wx::BitmapToggleButton
|
16
|
+
# - string type controls
|
17
|
+
# - Wx::Button, Wx::StaticText, Wx::TextCtrl
|
18
|
+
# - Wx::ComboBox in case it does not have style Wx::CB_READONLY
|
19
|
+
# - integer type controls
|
20
|
+
# - Wx::RadioBox, Wx::SpinButton, Wx::SpinCtrl, Wx::Gauge, Wx::Slider, Wx::ScrollBar, Wx::Choice
|
21
|
+
# - Wx::ComboBox in case it has style Wx::CB_READONLY
|
22
|
+
# - Wx::ListBox and Wx::CheckListBox in case of style Wx::LB_SINGLE
|
23
|
+
# - integer array type controls
|
24
|
+
# - Wx::ListBox and Wx::CheckListBox in case of style Wx::LB_MULTIPLE or Wx::LB_EXTENDED
|
25
|
+
# - date/time type controls
|
26
|
+
# - Wx::DatePickerCtrl, Wx::TimePickerCtrl
|
27
|
+
#
|
28
|
+
# It checks the type of the window and uses an appropriate type for it.
|
29
|
+
# For example, Wx::Button and Wx::TextCtrl transfer data to and from a
|
30
|
+
# String variable; Wx::ListBox uses an Array of Integer (in case of multiple
|
31
|
+
# selection list) or an Integer (in case of a single choice list); Wx::CheckBox
|
32
|
+
# uses a boolean.
|
33
|
+
#
|
34
|
+
# In wxRuby this is a pure Ruby implementation derived from Wx::Validator and
|
35
|
+
# **not** a wrapper for the C++ wxGenericValidator class although the functionality
|
36
|
+
# is virtually identical.
|
37
|
+
#
|
38
|
+
# @see Wx::Validator
|
39
|
+
# @see Wx::TextValidator
|
40
|
+
# @see Wx::IntegerValidator
|
41
|
+
# @see Wx::UnsignedValidator
|
42
|
+
# @see Wx::FloatValidator
|
43
|
+
#
|
44
|
+
# @wxrb_require USE_VALIDATORS
|
45
|
+
class GenericValidator < Wx::Validator
|
46
|
+
|
47
|
+
# Returns a Hash of handlers for the various control types this class supports.
|
48
|
+
# User defined extension (or re-definition) of these handlers is possible.
|
49
|
+
# @see GenericValidator.define_handler
|
50
|
+
# @return [Hash]
|
51
|
+
def self.handlers; end
|
52
|
+
|
53
|
+
# Defines a new handler for a control type (class).
|
54
|
+
#
|
55
|
+
# When called it should be supplied the control Class and either a Proc or Method
|
56
|
+
# instance or a block which should accept a single Wx::Window argument and an optional
|
57
|
+
# second argument.
|
58
|
+
# The handler will be called when transferring data from or to the associated window.
|
59
|
+
# The associated window is always passed as the first argument.
|
60
|
+
# In case of a transfer from the associated window that is the only argument and the
|
61
|
+
# handler should retrieve and return the data typical for the type of control window.
|
62
|
+
# In case of a transfer to the associated window the second argument will be the data
|
63
|
+
# to transfer to the associated control window.
|
64
|
+
#
|
65
|
+
# @example Definition of Wx::TextCtrl handler
|
66
|
+
# GenericValidator.define_handler(Wx::TextCtrl) do |win, *val|
|
67
|
+
# if val.empty?
|
68
|
+
# win.get_value
|
69
|
+
# else
|
70
|
+
# win.set_value(val.shift)
|
71
|
+
# end
|
72
|
+
# end
|
73
|
+
#
|
74
|
+
# @param [Class] klass control window class
|
75
|
+
# @param [Proc,Method,nil] meth
|
76
|
+
# @return [void]
|
77
|
+
def self.define_handler(klass, meth=nil, &block) end
|
78
|
+
|
79
|
+
# @overload initialize
|
80
|
+
# Default constructor.
|
81
|
+
# @return [Wx::GenericValidator]
|
82
|
+
# @overload initialize(other)
|
83
|
+
# Copy constructor.
|
84
|
+
# @param [Wx::GenericValidator] other
|
85
|
+
# @return [Wx::GenericValidator]
|
86
|
+
def initialize(*arg)end
|
87
|
+
|
88
|
+
# The value store attribute. Initially nil. When set the type should
|
89
|
+
# be appropriate for the associated control type.
|
90
|
+
# No forced conversions will be applied.
|
91
|
+
attr_accessor :value
|
92
|
+
|
93
|
+
end
|
94
|
+
|
95
|
+
end
|
@@ -0,0 +1,22 @@
|
|
1
|
+
# :stopdoc:
|
2
|
+
# Copyright (c) 2023 M.J.N. Corino, The Netherlands
|
3
|
+
#
|
4
|
+
# This software is released under the MIT license.
|
5
|
+
# :startdoc:
|
6
|
+
|
7
|
+
|
8
|
+
class Wx
|
9
|
+
|
10
|
+
module HTML
|
11
|
+
|
12
|
+
class SimpleHtmlListBox
|
13
|
+
|
14
|
+
alias :get_client_data :get_client_object
|
15
|
+
|
16
|
+
alias :set_client_data :set_client_object
|
17
|
+
|
18
|
+
end
|
19
|
+
|
20
|
+
end
|
21
|
+
|
22
|
+
end
|