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
@@ -0,0 +1,387 @@
|
|
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
|
+
# Validator for text entries used for integer entry.
|
11
|
+
#
|
12
|
+
# This validator can be used with Wx::TextCtrl or Wx::ComboBox (and potentially
|
13
|
+
# any other class implementing Wx::TextEntry interface) to check that only
|
14
|
+
# valid integer values can be entered into them.
|
15
|
+
#
|
16
|
+
# By default this validator accepts any signed integer values in the 64 bit range.
|
17
|
+
# This range can be restricted further by calling #set_min and #set_max or #set_range
|
18
|
+
# methods inherited from the base class.
|
19
|
+
#
|
20
|
+
# When the validator displays integers with thousands separators, the
|
21
|
+
# character used for the separators (usually "." or ",") depends on the locale
|
22
|
+
# set with Wx::Locale (note that you shouldn't change locale with `setlocale()`
|
23
|
+
# as this can result in a mismatch between the thousands separator used by
|
24
|
+
# Wx::Locale and the one used by the run-time library).
|
25
|
+
#
|
26
|
+
# @example A simple example of using this class:
|
27
|
+
# class MyDialog < Wx::Dialog
|
28
|
+
#
|
29
|
+
# def initialize
|
30
|
+
# super(...)
|
31
|
+
# ...
|
32
|
+
# # Allow integers and display them with thousands
|
33
|
+
# # separators.
|
34
|
+
# @value = 0
|
35
|
+
# val = Wx::IntegerValidator.new(Wx::NUM_VAL_THOUSANDS_SEPARATOR)
|
36
|
+
# val.on_transfer_to_window { @value }
|
37
|
+
# val.on_transfer_from_window { |val| @value = val }
|
38
|
+
#
|
39
|
+
# # If the would like to accept only positive integers we could
|
40
|
+
# # call val.set_min(0) or alternatively use {Wx::UnsignedValidator}.
|
41
|
+
#
|
42
|
+
# # Associate it with the text control:
|
43
|
+
# Wx::TextCtrl.new(self, ..., val)
|
44
|
+
# end
|
45
|
+
#
|
46
|
+
# end
|
47
|
+
#
|
48
|
+
# @see Wx::Validator
|
49
|
+
# @see Wx::GenericValidator
|
50
|
+
# @see Wx::TextValidator
|
51
|
+
# @see Wx::UnsignedValidator
|
52
|
+
# @see Wx::FloatValidator
|
53
|
+
# @wxrb_require USE_VALIDATORS
|
54
|
+
class IntegerValidator < Validator
|
55
|
+
|
56
|
+
# @overload initialize(style=Wx::NumValidatorStyle::NUM_VAL_DEFAULT)
|
57
|
+
# Constructor.
|
58
|
+
# @param [Wx::NumValidatorStyle] style A combination of Wx::NumValidatorStyle enum values with the exception of Wx::NUM_VAL_NO_TRAILING_ZEROES which can't be used here.
|
59
|
+
# @return [Wx::IntegerValidator]
|
60
|
+
# @overload initialize(min, max, style=Wx::NumValidatorStyle::NUM_VAL_DEFAULT)
|
61
|
+
# Constructor with specified range.
|
62
|
+
# @param [Integer] min The minimum value accepted by the validator.
|
63
|
+
# @param [Integer] max The maximum value accepted by the validator.
|
64
|
+
# @param [Wx::NumValidatorStyle] style A combination of Wx::NumValidatorStyle enum values with the exception of Wx::NUM_VAL_NO_TRAILING_ZEROES which can't be used here.
|
65
|
+
# @return [Wx::IntegerValidator]
|
66
|
+
# @overload initialize(other)
|
67
|
+
# Copy constructor.
|
68
|
+
# @param [Wx::IntegerValidator] other
|
69
|
+
# @return [Wx::IntegerValidator]
|
70
|
+
def initialize(*arg) end
|
71
|
+
|
72
|
+
# Sets the minimal value accepted by the validator.
|
73
|
+
#
|
74
|
+
# This value is inclusive, i.e. the value equal to min is accepted.
|
75
|
+
# @param [Integer] min
|
76
|
+
def set_min(min) end
|
77
|
+
alias :min= :set_min
|
78
|
+
|
79
|
+
# Gets the minimal value accepted by the validator.
|
80
|
+
# @return [Integer]
|
81
|
+
def get_min; end
|
82
|
+
alias :min :get_min
|
83
|
+
|
84
|
+
# Sets the maximal value accepted by the validator.
|
85
|
+
#
|
86
|
+
# This value is inclusive, i.e. the value equal to max is accepted.
|
87
|
+
# @param [Integer] max
|
88
|
+
def set_max(max) end
|
89
|
+
alias :max= :set_max
|
90
|
+
|
91
|
+
# Gets the maximum value accepted by the validator.
|
92
|
+
# @return [Integer]
|
93
|
+
def get_max; end
|
94
|
+
alias :max :get_max
|
95
|
+
|
96
|
+
# Sets both minimal and maximal values accepted by the validator.
|
97
|
+
#
|
98
|
+
# Calling this is equivalent to calling both #set_min and #set_max.
|
99
|
+
# @param [Integer] min
|
100
|
+
# @param [Integer] max
|
101
|
+
def set_range(min, max) end
|
102
|
+
alias :range= :set_range
|
103
|
+
|
104
|
+
# Gets both minimal and maximal values accepted by the validator.
|
105
|
+
#
|
106
|
+
# Returns an array with `[min, max]`
|
107
|
+
# @return [Array<Integer,Integer>]
|
108
|
+
def get_range; end
|
109
|
+
alias :range :get_range
|
110
|
+
|
111
|
+
# Change the validator style.
|
112
|
+
#
|
113
|
+
# Can be used to change the style of the validator after its creation.
|
114
|
+
# @param [Wx::NumValidatorStyle] style A combination of Wx::NumValidatorStyle enum values with the exception of Wx::NUM_VAL_NO_TRAILING_ZEROES which can't be used here.
|
115
|
+
def set_style(style) end
|
116
|
+
alias :style= :set_style
|
117
|
+
|
118
|
+
# Returns the value store attribute. Initially 0.
|
119
|
+
# @return [Integer]
|
120
|
+
def get_value; end
|
121
|
+
alias :value :get_value
|
122
|
+
|
123
|
+
# Sets the value store attribute.
|
124
|
+
# @param [Integer] val
|
125
|
+
def set_value(val) end
|
126
|
+
alias :value= :set_value
|
127
|
+
|
128
|
+
end
|
129
|
+
|
130
|
+
# Validator for text entries used for unsigned integer entry.
|
131
|
+
#
|
132
|
+
# This validator can be used with Wx::TextCtrl or Wx::ComboBox (and potentially
|
133
|
+
# any other class implementing Wx::TextEntry interface) to check that only
|
134
|
+
# valid integer values can be entered into them.
|
135
|
+
#
|
136
|
+
# By default this validator accepts any unsigned integer values in the 64 bit range.
|
137
|
+
# This range can be restricted further by calling #set_min and #set_max or #set_range
|
138
|
+
# methods inherited from the base class.
|
139
|
+
#
|
140
|
+
# When the validator displays integers with thousands separators, the
|
141
|
+
# character used for the separators (usually "." or ",") depends on the locale
|
142
|
+
# set with Wx::Locale (note that you shouldn't change locale with `setlocale()`
|
143
|
+
# as this can result in a mismatch between the thousands separator used by
|
144
|
+
# Wx::Locale and the one used by the run-time library).
|
145
|
+
#
|
146
|
+
# @example A simple example of using this class:
|
147
|
+
# class MyDialog < Wx::Dialog
|
148
|
+
#
|
149
|
+
# def initialize
|
150
|
+
# super(...)
|
151
|
+
# ...
|
152
|
+
# # Allow unsigned integers and display them with thousands
|
153
|
+
# # separators.
|
154
|
+
# @value = 0
|
155
|
+
# val = Wx::UnsignedValidator.new(Wx::NUM_VAL_THOUSANDS_SEPARATOR)
|
156
|
+
# val.on_transfer_to_window { @value }
|
157
|
+
# val.on_transfer_from_window { |val| @value = val }
|
158
|
+
#
|
159
|
+
# # Associate it with the text control:
|
160
|
+
# Wx::TextCtrl.new(self, ..., val)
|
161
|
+
# end
|
162
|
+
#
|
163
|
+
# end
|
164
|
+
#
|
165
|
+
# @see Wx::Validator
|
166
|
+
# @see Wx::GenericValidator
|
167
|
+
# @see Wx::TextValidator
|
168
|
+
# @see Wx::IntegerValidator
|
169
|
+
# @see Wx::FloatValidator
|
170
|
+
# @wxrb_require USE_VALIDATORS
|
171
|
+
class UnsignedValidator < Validator
|
172
|
+
|
173
|
+
# @overload initialize(style=Wx::NumValidatorStyle::NUM_VAL_DEFAULT)
|
174
|
+
# Constructor.
|
175
|
+
# @param [Wx::NumValidatorStyle] style A combination of Wx::NumValidatorStyle enum values with the exception of Wx::NUM_VAL_NO_TRAILING_ZEROES which can't be used here.
|
176
|
+
# @return [Wx::UnsignedValidator]
|
177
|
+
# @overload initialize(min, max, style=Wx::NumValidatorStyle::NUM_VAL_DEFAULT)
|
178
|
+
# Constructor with specified range.
|
179
|
+
# @param [Integer] min The minimum value accepted by the validator.
|
180
|
+
# @param [Integer] max The maximum value accepted by the validator.
|
181
|
+
# @param [Wx::NumValidatorStyle] style A combination of Wx::NumValidatorStyle enum values with the exception of Wx::NUM_VAL_NO_TRAILING_ZEROES which can't be used here.
|
182
|
+
# @return [Wx::UnsignedValidator]
|
183
|
+
# @overload initialize(other)
|
184
|
+
# Copy constructor.
|
185
|
+
# @param [Wx::UnsignedValidator] other
|
186
|
+
# @return [Wx::UnsignedValidator]
|
187
|
+
def initialize(*arg) end
|
188
|
+
|
189
|
+
# Sets the minimal value accepted by the validator.
|
190
|
+
#
|
191
|
+
# This value is inclusive, i.e. the value equal to min is accepted.
|
192
|
+
# @param [Integer] min
|
193
|
+
def set_min(min) end
|
194
|
+
alias :min= :set_min
|
195
|
+
|
196
|
+
# Gets the minimal value accepted by the validator.
|
197
|
+
# @return [Integer]
|
198
|
+
def get_min; end
|
199
|
+
alias :min :get_min
|
200
|
+
|
201
|
+
# Sets the maximal value accepted by the validator.
|
202
|
+
#
|
203
|
+
# This value is inclusive, i.e. the value equal to max is accepted.
|
204
|
+
# @param [Integer] max
|
205
|
+
def set_max(max) end
|
206
|
+
alias :max= :set_max
|
207
|
+
|
208
|
+
# Gets the maximum value accepted by the validator.
|
209
|
+
# @return [Integer]
|
210
|
+
def get_max; end
|
211
|
+
alias :max :get_max
|
212
|
+
|
213
|
+
# Sets both minimal and maximal values accepted by the validator.
|
214
|
+
#
|
215
|
+
# Calling this is equivalent to calling both #set_min and #set_max.
|
216
|
+
# @param [Integer] min
|
217
|
+
# @param [Integer] max
|
218
|
+
def set_range(min, max) end
|
219
|
+
alias :range= :set_range
|
220
|
+
|
221
|
+
# Gets both minimal and maximal values accepted by the validator.
|
222
|
+
#
|
223
|
+
# Returns an array with `[min, max]`
|
224
|
+
# @return [Array<Integer,Integer>]
|
225
|
+
def get_range; end
|
226
|
+
alias :range :get_range
|
227
|
+
|
228
|
+
# Change the validator style.
|
229
|
+
#
|
230
|
+
# Can be used to change the style of the validator after its creation.
|
231
|
+
# @param [Wx::NumValidatorStyle] style A combination of Wx::NumValidatorStyle enum values with the exception of Wx::NUM_VAL_NO_TRAILING_ZEROES which can't be used here.
|
232
|
+
def set_style(style) end
|
233
|
+
alias :style= :set_style
|
234
|
+
|
235
|
+
# Returns the value store attribute. Initially 0.
|
236
|
+
# @return [Integer]
|
237
|
+
def get_value; end
|
238
|
+
alias :value :get_value
|
239
|
+
|
240
|
+
# Sets the value store attribute.
|
241
|
+
# @param [Integer] val
|
242
|
+
def set_value(val) end
|
243
|
+
alias :value= :set_value
|
244
|
+
|
245
|
+
end
|
246
|
+
|
247
|
+
# Validator for text entries used for floating point numbers entry.
|
248
|
+
#
|
249
|
+
# This validator can be used with Wx::TextCtrl or Wx::ComboBox (and potentially
|
250
|
+
# any other class implementing Wx::TextEntry interface) to check that only
|
251
|
+
# valid floating point values can be entered into them. Currently only fixed
|
252
|
+
# format is supported on input, i.e. scientific format with mantissa and
|
253
|
+
# exponent is not supported.
|
254
|
+
#
|
255
|
+
# Similarly to Wx::IntegerValidator, the range for the accepted values is by
|
256
|
+
# default set appropriately for the type (`double`). Additionally, this validator allows
|
257
|
+
# to specify the maximum number of digits that can be entered after the
|
258
|
+
# decimal separator. By default this is also set appropriately for the type
|
259
|
+
# used, e.g. 15 for `double` on a typical IEEE-754-based
|
260
|
+
# implementation. As with the range, the precision can be restricted after
|
261
|
+
# the validator creation if necessary.
|
262
|
+
#
|
263
|
+
# When the validator displays numbers with decimal or thousands separators,
|
264
|
+
# the characters used for the separators (usually "." or ",") depend on the
|
265
|
+
# locale set with Wx::Locale (note that you shouldn't change locale with
|
266
|
+
# `setlocale()` as this can result in a mismatch between the separators used by
|
267
|
+
# Wx::Locale and the one used by the run-time library).
|
268
|
+
#
|
269
|
+
# @example A simple example of using this class:
|
270
|
+
# class MyDialog < Wx::Dialog
|
271
|
+
# def initialize
|
272
|
+
# super(..)
|
273
|
+
# ...
|
274
|
+
# # Allow floating point numbers from 0 to 100 with 2 decimal
|
275
|
+
# # digits only and handle empty string as 0 by default.
|
276
|
+
# val = Wx::FloatValidator.new(2, Wx::NUM_VAL_ZERO_AS_BLANK)
|
277
|
+
# val.set_range(0, 100)
|
278
|
+
#
|
279
|
+
# # Associate it with the text control:
|
280
|
+
# Wx::TextCtrl.new(this, ..., val)
|
281
|
+
# end
|
282
|
+
#
|
283
|
+
# end
|
284
|
+
#
|
285
|
+
# @see Wx::Validator
|
286
|
+
# @see Wx::GenericValidator
|
287
|
+
# @see Wx::TextValidator
|
288
|
+
# @see Wx::IntegerValidator
|
289
|
+
# @see Wx::UnsignedValidator
|
290
|
+
# @wxrb_require USE_VALIDATORS
|
291
|
+
class FloatValidator < Validator
|
292
|
+
|
293
|
+
# @overload initialize(style=Wx::NumValidatorStyle::NUM_VAL_DEFAULT)
|
294
|
+
# Constructor.
|
295
|
+
# @param [Wx::NumValidatorStyle] style A combination of Wx::NumValidatorStyle enum values.
|
296
|
+
# @return [Wx::FloatValidator]
|
297
|
+
# @overload initialize(precision, style)
|
298
|
+
# Constructor for validator specifying the precision.
|
299
|
+
# @param [Integer] precision The number of decimal digits after the decimal separator to show and accept.
|
300
|
+
# @param [Wx::NumValidatorStyle] style A combination of Wx::NumValidatorStyle enum values.
|
301
|
+
# @return [Wx::FloatValidator]
|
302
|
+
# @overload initialize(other)
|
303
|
+
# Copy constructor.
|
304
|
+
# @param [Wx::FloatValidator] other
|
305
|
+
# @return [Wx::FloatValidator]
|
306
|
+
def initialize(*arg) end
|
307
|
+
|
308
|
+
# Sets the minimal value accepted by the validator.
|
309
|
+
#
|
310
|
+
# This value is inclusive, i.e. the value equal to min is accepted.
|
311
|
+
# @param [Float] min
|
312
|
+
def set_min(min) end
|
313
|
+
alias :min= :set_min
|
314
|
+
|
315
|
+
# Gets the minimal value accepted by the validator.
|
316
|
+
# @return [Float]
|
317
|
+
def get_min; end
|
318
|
+
alias :min :get_min
|
319
|
+
|
320
|
+
# Sets the maximal value accepted by the validator.
|
321
|
+
#
|
322
|
+
# This value is inclusive, i.e. the value equal to max is accepted.
|
323
|
+
# @param [Float] max
|
324
|
+
def set_max(max) end
|
325
|
+
alias :max= :set_max
|
326
|
+
|
327
|
+
# Gets the maximum value accepted by the validator.
|
328
|
+
# @return [Float]
|
329
|
+
def get_max; end
|
330
|
+
alias :max :get_max
|
331
|
+
|
332
|
+
# Sets both minimal and maximal values accepted by the validator.
|
333
|
+
#
|
334
|
+
# Calling this is equivalent to calling both #set_min and #set_max.
|
335
|
+
# @param [Float] min
|
336
|
+
# @param [Float] max
|
337
|
+
def set_range(min, max) end
|
338
|
+
alias :range= :set_range
|
339
|
+
|
340
|
+
# Gets both minimal and maximal values accepted by the validator.
|
341
|
+
#
|
342
|
+
# Returns an array with `[min, max]`
|
343
|
+
# @return [Array<Float,Float>]
|
344
|
+
def get_range; end
|
345
|
+
alias :range :get_range
|
346
|
+
|
347
|
+
# Change the validator style.
|
348
|
+
#
|
349
|
+
# Can be used to change the style of the validator after its creation.
|
350
|
+
# @param [Wx::NumValidatorStyle] style A combination of Wx::NumValidatorStyle enum values.
|
351
|
+
def set_style(style) end
|
352
|
+
alias :style= :set_style
|
353
|
+
|
354
|
+
# Set precision.
|
355
|
+
#
|
356
|
+
# Precision is the number of digits shown (and accepted on input)
|
357
|
+
# after the decimal point. By default this is set to the maximal
|
358
|
+
# precision supported by the type handled by the validator in its
|
359
|
+
# constructor.
|
360
|
+
# @param [Integer] precision
|
361
|
+
def set_precision(precision) end
|
362
|
+
alias :precision= :set_precision
|
363
|
+
|
364
|
+
# Set factor used for displaying the value.
|
365
|
+
#
|
366
|
+
# The value associated with the validator is multiplied by the factor
|
367
|
+
# before displaying it and divided by it when retrieving its value from
|
368
|
+
# the control. By default, the factor is 1, so the actual value is not
|
369
|
+
# affected by it, but it can be set to, for example, 100, to display the
|
370
|
+
# value in percents while still storing it as absolute value.
|
371
|
+
# @param [Float] factor
|
372
|
+
def set_factor(factor) end
|
373
|
+
alias :factor= :set_factor
|
374
|
+
|
375
|
+
# Returns the value store attribute. Initially 0.
|
376
|
+
# @return [Float]
|
377
|
+
def get_value; end
|
378
|
+
alias :value :get_value
|
379
|
+
|
380
|
+
# Sets the value store attribute.
|
381
|
+
# @param [Float] val
|
382
|
+
def set_value(val) end
|
383
|
+
alias :value= :set_value
|
384
|
+
|
385
|
+
end
|
386
|
+
|
387
|
+
end
|
@@ -0,0 +1,96 @@
|
|
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
|
11
|
+
|
12
|
+
# Returns the label of the selected item or an empty string if no item is selected.
|
13
|
+
#
|
14
|
+
# @see Wx::OwnerDrawnComboBox#get_selection
|
15
|
+
# @return [String]
|
16
|
+
def get_list_string_selection; end
|
17
|
+
alias :list_string_selection :get_list_string_selection
|
18
|
+
|
19
|
+
# Selects the item with the specified string in the control.
|
20
|
+
#
|
21
|
+
# This method doesn't cause any command events to be emitted.
|
22
|
+
# Notice that this method is case-insensitive, i.e. the string is compared with all the elements of the control
|
23
|
+
# case-insensitively and the first matching entry is selected, even if it doesn't have exactly the same case as
|
24
|
+
# this string and there is an exact match afterwards.
|
25
|
+
#
|
26
|
+
# true if the specified string has been selected, false if it wasn't found in the control.
|
27
|
+
# @param string [String] The string to select.
|
28
|
+
# @return [Boolean]
|
29
|
+
def set_list_string_selection(string) end
|
30
|
+
alias :list_string_selection= :set_list_string_selection
|
31
|
+
|
32
|
+
# Returns the index of the selected item or {Wx::NOT_FOUND} if no item is selected.
|
33
|
+
#
|
34
|
+
# The position of the current selection.
|
35
|
+
# @see Wx::OwnerDrawnComboBox#set_list_selection
|
36
|
+
# @see Wx::OwnerDrawnComboBox#get_list_string_selection
|
37
|
+
# @return [Integer]
|
38
|
+
def get_list_selection; end
|
39
|
+
alias :list_selection :get_list_selection
|
40
|
+
|
41
|
+
# Sets the selection to the given item n or removes the selection entirely if n == {Wx::NOT_FOUND}.
|
42
|
+
#
|
43
|
+
# Note that this does not cause any command events to be emitted nor does it deselect any other items in the controls which support multiple selections.
|
44
|
+
# @see Wx::OwnerDrawnComboBox#set_string
|
45
|
+
# @see Wx::OwnerDrawnComboBox#set_list_string_selection
|
46
|
+
# @param n [Integer] The string position to select, starting from zero.
|
47
|
+
# @return [void]
|
48
|
+
def set_list_selection(n) end
|
49
|
+
alias :list_selection= :set_list_selection
|
50
|
+
|
51
|
+
# Returns the number of items in the control.
|
52
|
+
#
|
53
|
+
# @see Wx::OwnerDrawnComboBox#is_list_empty
|
54
|
+
# @return [Integer]
|
55
|
+
def get_count; end
|
56
|
+
alias_method :count, :get_count
|
57
|
+
|
58
|
+
# Returns the label of the item with the given index.
|
59
|
+
#
|
60
|
+
# The index must be valid, i.e. less than the value returned by {Wx::OwnerDrawnComboBox#get_count},
|
61
|
+
# otherwise an assert is triggered. Notably, this function can't be called if the control is empty.
|
62
|
+
#
|
63
|
+
# The label of the item.
|
64
|
+
# @param n [Integer] The zero-based index.
|
65
|
+
# @return [String]
|
66
|
+
def get_string(n) end
|
67
|
+
alias_method :string, :get_string
|
68
|
+
|
69
|
+
# Returns the array of the labels of all items in the control.
|
70
|
+
# @return [Array<String>]
|
71
|
+
def get_strings; end
|
72
|
+
alias_method :strings, :get_strings
|
73
|
+
|
74
|
+
# Sets the label for the given item.
|
75
|
+
# @param n [Integer] The zero-based item index.
|
76
|
+
# @param string [String] The label to set.
|
77
|
+
# @return [void]
|
78
|
+
def set_string(n, string) end
|
79
|
+
|
80
|
+
# Finds an item whose label matches the given string.
|
81
|
+
#
|
82
|
+
# The zero-based position of the item, or {Wx::NOT_FOUND} if the string was not found.
|
83
|
+
# @param string [String] String to find.
|
84
|
+
# @param caseSensitive [Boolean] Whether search is case sensitive (default is not).
|
85
|
+
# @return [Integer]
|
86
|
+
def find_string(string, caseSensitive=false) end
|
87
|
+
|
88
|
+
# This is the same as {Wx::OwnerDrawnComboBox#set_list_selection} and exists only because it is slightly
|
89
|
+
# more natural for controls which support multiple selection.
|
90
|
+
# @param n [Integer]
|
91
|
+
# @return [void]
|
92
|
+
def select(n) end
|
93
|
+
|
94
|
+
end
|
95
|
+
|
96
|
+
end
|
@@ -0,0 +1,33 @@
|
|
1
|
+
# :stopdoc:
|
2
|
+
# This file is automatically generated by the WXRuby3 documentation
|
3
|
+
# generator. Do not alter this file.
|
4
|
+
# :startdoc:
|
5
|
+
|
6
|
+
|
7
|
+
module Wx::PG
|
8
|
+
|
9
|
+
class NumericPropertyValidator < TextValidator
|
10
|
+
|
11
|
+
# @overload initialize(validator)
|
12
|
+
# Copy constructor.
|
13
|
+
# @param [Wx::wxNumericPropertyValidator] validator validator to copy
|
14
|
+
# @overload initialize(numericType, base=10)
|
15
|
+
# @param numericType [Wx::wxNumericPropertyValidator::NumericType]
|
16
|
+
# @param base [Integer]
|
17
|
+
# @return [Wx::PG::NumericPropertyValidator]
|
18
|
+
def initialize(*args) end
|
19
|
+
|
20
|
+
# Returns the value store attribute. Initially an empty string.
|
21
|
+
# @return [String]
|
22
|
+
def get_value; end
|
23
|
+
alias :value :get_value
|
24
|
+
|
25
|
+
# Sets the value store attribute.
|
26
|
+
# @param [String] val
|
27
|
+
def set_value(val) end
|
28
|
+
alias :value= :set_value
|
29
|
+
|
30
|
+
end # NumericPropertyValidator
|
31
|
+
|
32
|
+
|
33
|
+
end
|
@@ -0,0 +1,25 @@
|
|
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
|
+
# A generic (non-native) static bitmap control to display bitmap.
|
11
|
+
#
|
12
|
+
# Unlike the native control implemented by {Wx::StaticBitmap}, which on some platforms is only meant for display of
|
13
|
+
# the small icons in the dialog boxes, you may use this implementation to display larger images portably.
|
14
|
+
# Notice that for the best results, the size of the control should be the same as the size of the image displayed in
|
15
|
+
# it, as happens by default if it's not resized explicitly. Otherwise, behaviour depends on the platform: under MSW,
|
16
|
+
# the bitmap is drawn centred inside the control, while elsewhere it is drawn at the origin of the control. You can
|
17
|
+
# use {Wx::GenericStaticBitmap#set_scale_mode} to control how the image is scaled inside the control.
|
18
|
+
#
|
19
|
+
# @see Wx::Bitmap
|
20
|
+
# @see Wx::StaticBitmap
|
21
|
+
class GenericStaticBitmap < Control
|
22
|
+
|
23
|
+
end
|
24
|
+
|
25
|
+
end
|
@@ -17,6 +17,16 @@ module Wx
|
|
17
17
|
# @param [Integer] style One or more of the {Wx::TextValidatorStyle} styles. See #set_style.
|
18
18
|
def initialize(*args) end
|
19
19
|
|
20
|
+
# Returns the value store attribute. Initially an empty string.
|
21
|
+
# @return [String]
|
22
|
+
def get_value; end
|
23
|
+
alias :value :get_value
|
24
|
+
|
25
|
+
# Sets the value store attribute.
|
26
|
+
# @param [String] val
|
27
|
+
def set_value(val) end
|
28
|
+
alias :value= :set_value
|
29
|
+
|
20
30
|
end
|
21
31
|
|
22
32
|
end
|
@@ -0,0 +1,113 @@
|
|
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 Validator < EvtHandler
|
11
|
+
|
12
|
+
# @overload initialize()
|
13
|
+
# Constructor.
|
14
|
+
# @return [Wx::Validator]
|
15
|
+
# @overload initialize(other)
|
16
|
+
# Copy constructor.
|
17
|
+
# @param [Wx::Validator] other
|
18
|
+
# @return [Wx::Validator]
|
19
|
+
def initialize(*arg) end
|
20
|
+
|
21
|
+
# Method called when transferring data from window.
|
22
|
+
# Should retrieve and return the data from the associated window (#get_window).
|
23
|
+
# By default returns nil (which indicates there is no custom data to transfer).
|
24
|
+
# Overload for customized functionality.
|
25
|
+
# @return [Object] retrieved data from window
|
26
|
+
def do_transfer_from_window; end
|
27
|
+
protected :do_transfer_from_window
|
28
|
+
|
29
|
+
# Method called when transferring data to window.
|
30
|
+
# Should transfer the given data to the associated window and return true if successful.
|
31
|
+
# By default does nothing and just returns true.
|
32
|
+
# Overload for customized functionality.
|
33
|
+
# @param [Object] data
|
34
|
+
# @return [Boolean]
|
35
|
+
def do_transfer_to_window(data) end
|
36
|
+
protected :do_transfer_to_window
|
37
|
+
|
38
|
+
# Mixin module providing data binding options for validators.
|
39
|
+
module Binding
|
40
|
+
|
41
|
+
# Installs a callback handler to capture the data retrieved from the associated window.
|
42
|
+
# The callback handler can be specified as a (name of a) method, a Proc or a block.
|
43
|
+
#
|
44
|
+
# @example This can be used to implement data binding like:
|
45
|
+
# class MyValidator < Wx::Validator
|
46
|
+
# def initialize(data_store)
|
47
|
+
# @data_store = data_store
|
48
|
+
# self.on_transfer_from_window :store_data
|
49
|
+
# self.on_transfer_to_window :load_data
|
50
|
+
# end
|
51
|
+
# protected
|
52
|
+
# def store_data(data)
|
53
|
+
# @data_store.save_the_data(data)
|
54
|
+
# end
|
55
|
+
# def load_data
|
56
|
+
# @data_store.get_the_data
|
57
|
+
# end
|
58
|
+
# end
|
59
|
+
# val = MyValidator.new(a_data_store)
|
60
|
+
# win.set_validator(val)
|
61
|
+
#
|
62
|
+
# @param [String,Symbol,Method,Proc] meth (name of) method or event handling proc; to be supplied when no block is given
|
63
|
+
# @yieldparam [Object] data the data retrieved from the window
|
64
|
+
def on_transfer_from_window(meth=nil, &block) end
|
65
|
+
|
66
|
+
# Installs a callback handler to provide the data to transfer to the associated window.
|
67
|
+
# The callback handler can be specified as a (name of a) method, a Proc or a block.
|
68
|
+
#
|
69
|
+
# @example This can be used to implement data binding like:
|
70
|
+
# class MyValidator < Wx::Validator
|
71
|
+
# def initialize(data_store)
|
72
|
+
# @data_store = data_store
|
73
|
+
# self.on_transfer_from_window :store_data
|
74
|
+
# self.on_transfer_to_window :load_data
|
75
|
+
# end
|
76
|
+
# protected
|
77
|
+
# def store_data(data)
|
78
|
+
# @data_store.save_the_data(data)
|
79
|
+
# end
|
80
|
+
# def load_data
|
81
|
+
# @data_store.get_the_data
|
82
|
+
# end
|
83
|
+
# end
|
84
|
+
# val = MyValidator.new(a_data_store)
|
85
|
+
# win.set_validator(val)
|
86
|
+
#
|
87
|
+
# @param [String,Symbol,Method,Proc] meth (name of) method or event handling proc; to be supplied when no block is given
|
88
|
+
# @yieldreturn [Object] the data to transfer to the window
|
89
|
+
def on_transfer_to_window(meth=nil, &block) end
|
90
|
+
|
91
|
+
# Method called with data transferred from window.
|
92
|
+
# By default will call the on_transfer_from_window handler if defined.
|
93
|
+
# Returns true if successful or none defined.
|
94
|
+
# @param [Object] data
|
95
|
+
# @return [Boolean]
|
96
|
+
def do_on_transfer_from_window(data) end
|
97
|
+
protected :do_on_transfer_from_window
|
98
|
+
|
99
|
+
# Method called to get data to transfer to window.
|
100
|
+
# By default will call the on_transfer_to_window handler if defined.
|
101
|
+
# Returns the handler's result if successful.
|
102
|
+
# Otherwise returns nil.
|
103
|
+
# @return [Object]
|
104
|
+
def do_on_transfer_to_window; end
|
105
|
+
protected :do_on_transfer_to_window
|
106
|
+
|
107
|
+
end
|
108
|
+
|
109
|
+
include Binding
|
110
|
+
|
111
|
+
end
|
112
|
+
|
113
|
+
end
|