wxruby3 0.9.2 → 0.9.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (379) hide show
  1. checksums.yaml +4 -4
  2. data/INSTALL.md +35 -29
  3. data/README.md +24 -15
  4. data/ext/wxruby3/include/wxruby-ClientData.h +48 -0
  5. data/ext/wxruby3/include/wxruby-Config.h +23 -5
  6. data/ext/wxruby3/include/wxruby-Persistence.h +79 -0
  7. data/ext/wxruby3/include/wxruby-Validator.h +39 -0
  8. data/ext/wxruby3/include/wxruby-ValidatorBinding.h +64 -0
  9. data/ext/wxruby3/swig/custom/director.swg +8 -0
  10. data/ext/wxruby3/swig/mark_free_impl.i +0 -33
  11. data/ext/wxruby3/swig/memory_management.i +6 -0
  12. data/lib/wx/core/bitmap_combobox.rb +17 -21
  13. data/lib/wx/core/book_ctrl_base.rb +16 -0
  14. data/lib/wx/core/combobox.rb +13 -3
  15. data/lib/wx/core/config.rb +454 -83
  16. data/lib/wx/core/controlwithitems.rb +40 -130
  17. data/lib/wx/core/enum.rb +17 -1
  18. data/lib/wx/core/event.rb +6 -1
  19. data/lib/wx/core/evthandler.rb +8 -2
  20. data/lib/wx/core/generic_validator.rb +312 -0
  21. data/lib/wx/core/listbox.rb +2 -2
  22. data/lib/wx/core/log.rb +1 -1
  23. data/lib/wx/core/notebook.rb +10 -8
  24. data/lib/wx/core/owner_drawn_combobox.rb +45 -0
  25. data/lib/wx/core/peristent_object.rb +15 -0
  26. data/lib/wx/core/persistence_manager.rb +39 -0
  27. data/lib/wx/core/persistent_window.rb +16 -0
  28. data/lib/wx/core/size.rb +4 -0
  29. data/lib/wx/core/sizer.rb +1 -2
  30. data/lib/wx/core/standard_paths.rb +22 -0
  31. data/lib/wx/core/text_entry.rb +4 -1
  32. data/lib/wx/core/top_level_window.rb +16 -0
  33. data/lib/wx/core/treebook.rb +18 -0
  34. data/lib/wx/core/validator.rb +70 -5
  35. data/lib/wx/core/window.rb +3 -7
  36. data/lib/wx/core.rb +4 -0
  37. data/lib/wx/doc/art_locator.rb +1 -0
  38. data/lib/wx/doc/book_ctrl_base.rb +19 -0
  39. data/lib/wx/doc/comboctrl.rb +18 -0
  40. data/lib/wx/doc/config.rb +101 -41
  41. data/lib/wx/doc/controlwithitems.rb +16 -0
  42. data/lib/wx/doc/date_picker_ctrl.rb +23 -0
  43. data/lib/wx/doc/editable_listbox.rb +44 -0
  44. data/lib/wx/doc/enum.rb +15 -0
  45. data/lib/wx/doc/event.rb +12 -0
  46. data/lib/wx/doc/extra/12_client_data.md +89 -0
  47. data/lib/wx/doc/extra/13_validators.md +139 -0
  48. data/lib/wx/doc/extra/14_config.md +101 -0
  49. data/lib/wx/doc/extra/15_persistence.md +148 -0
  50. data/lib/wx/doc/gdi_common.rb +4 -0
  51. data/lib/wx/doc/generic_validator.rb +95 -0
  52. data/lib/wx/doc/html/simple_html_listbox.rb +22 -0
  53. data/lib/wx/doc/num_validator.rb +387 -0
  54. data/lib/wx/doc/owner_drawn_combobox.rb +96 -0
  55. data/lib/wx/doc/persistence_manager.rb +36 -0
  56. data/lib/wx/doc/persistent_object.rb +27 -0
  57. data/lib/wx/doc/pg/numeric_property_validator.rb +33 -0
  58. data/lib/wx/doc/static_bitmap.rb +25 -0
  59. data/lib/wx/doc/text_validator.rb +10 -0
  60. data/lib/wx/doc/top_level_window.rb +19 -0
  61. data/lib/wx/doc/treebook.rb +6 -1
  62. data/lib/wx/doc/validator.rb +113 -0
  63. data/lib/wx/doc/window.rb +30 -0
  64. data/lib/wx/html/simple_html_listbox.rb +24 -91
  65. data/lib/wx/keyword_defs.rb +34 -2
  66. data/lib/wx/rbn/ribbon_gallery.rb +0 -21
  67. data/lib/wx/version.rb +1 -1
  68. data/rakelib/build.rb +1 -1
  69. data/rakelib/lib/config/mingw.rb +12 -0
  70. data/rakelib/lib/core/include/client_data.inc +65 -0
  71. data/rakelib/lib/core/include/funcall.inc +1 -1
  72. data/rakelib/lib/core/package.rb +39 -3
  73. data/rakelib/lib/core/parameter.rb +1 -1
  74. data/rakelib/lib/core/spec.rb +10 -0
  75. data/rakelib/lib/core/spec_helper.rb +8 -2
  76. data/rakelib/lib/director/app.rb +18 -0
  77. data/rakelib/lib/director/app_traits.rb +3 -1
  78. data/rakelib/lib/director/bitmap_combobox.rb +2 -2
  79. data/rakelib/lib/director/combobox.rb +22 -0
  80. data/rakelib/lib/director/comboctrl.rb +1 -55
  81. data/rakelib/lib/director/config_base.rb +490 -19
  82. data/rakelib/lib/director/ctrl_with_items.rb +88 -21
  83. data/rakelib/lib/director/date_picker_ctrl.rb +8 -6
  84. data/rakelib/lib/director/editable_listbox.rb +30 -0
  85. data/rakelib/lib/director/event.rb +102 -12
  86. data/rakelib/lib/director/event_filter.rb +1 -1
  87. data/rakelib/lib/director/event_handler.rb +3 -2
  88. data/rakelib/lib/director/event_loop.rb +1 -1
  89. data/rakelib/lib/director/file_dialog_customize_hook.rb +2 -2
  90. data/rakelib/lib/director/functions.rb +4 -2
  91. data/rakelib/lib/director/generic_dirctrl.rb +17 -0
  92. data/rakelib/lib/director/grid_cell_attr.rb +1 -3
  93. data/rakelib/lib/director/grid_cell_editor.rb +1 -3
  94. data/rakelib/lib/director/grid_cell_renderer.rb +1 -3
  95. data/rakelib/lib/director/header_ctrl.rb +9 -1
  96. data/rakelib/lib/director/html_listbox.rb +97 -22
  97. data/rakelib/lib/director/num_validator.rb +495 -0
  98. data/rakelib/lib/director/numeric_property_validator.rb +131 -6
  99. data/rakelib/lib/director/owner_drawn_combobox.rb +192 -0
  100. data/rakelib/lib/director/persistence_manager.rb +410 -0
  101. data/rakelib/lib/director/persistent_object.rb +70 -0
  102. data/rakelib/lib/director/persistent_window.rb +73 -0
  103. data/rakelib/lib/director/pgproperty.rb +3 -29
  104. data/rakelib/lib/director/ribbon_button_bar.rb +3 -3
  105. data/rakelib/lib/director/ribbon_gallery.rb +3 -5
  106. data/rakelib/lib/director/sizer.rb +15 -4
  107. data/rakelib/lib/director/sizer_item.rb +13 -0
  108. data/rakelib/lib/director/static_bitmap.rb +32 -0
  109. data/rakelib/lib/director/text_entry.rb +5 -1
  110. data/rakelib/lib/director/text_validator.rb +124 -13
  111. data/rakelib/lib/director/toggle_button.rb +1 -0
  112. data/rakelib/lib/director/top_level_window.rb +0 -2
  113. data/rakelib/lib/director/tree_ctrl.rb +35 -0
  114. data/rakelib/lib/director/utils.rb +16 -2
  115. data/rakelib/lib/director/validator.rb +196 -21
  116. data/rakelib/lib/director/window.rb +16 -2
  117. data/rakelib/lib/extractor/function.rb +2 -1
  118. data/rakelib/lib/generate/analyzer.rb +44 -44
  119. data/rakelib/lib/generate/doc.rb +11 -5
  120. data/rakelib/lib/specs/interfaces.rb +5 -0
  121. data/rakelib/lib/swig_runner.rb +55 -9
  122. data/rakelib/lib/typemap/client_data.rb +67 -0
  123. data/rakelib/lib/typemap/common.rb +3 -3
  124. data/rakelib/lib/typemap/config.rb +8 -0
  125. data/rakelib/lib/typemap/datetime.rb +1 -1
  126. data/rakelib/lib/typemap/tree_itemid.rb +2 -2
  127. data/samples/aui/aui.rb +1237 -1233
  128. data/samples/calendar/calendar.rb +293 -289
  129. data/samples/controls/get_item_sample.rb +83 -79
  130. data/samples/controls/htlbox.rb +331 -327
  131. data/samples/dialogs/dialogs.rb +682 -694
  132. data/samples/dialogs/wizard.rb +52 -55
  133. data/samples/dragdrop/dragdrop.rb +146 -142
  134. data/samples/drawing/bitmap.rb +29 -26
  135. data/samples/drawing/bitmap_image.rb +84 -80
  136. data/samples/drawing/graphics_drawing.rb +209 -205
  137. data/samples/drawing/image_prt.rb +344 -340
  138. data/samples/drawing/maths_images.rb +18 -1
  139. data/samples/drawing/rmagic_bitmap_image.rb +88 -84
  140. data/samples/etc/caret.rb +306 -0
  141. data/samples/etc/miniframe.rb +65 -60
  142. data/samples/etc/sash.rb +109 -105
  143. data/samples/etc/scrollwin.rb +86 -80
  144. data/samples/etc/system_settings.rb +216 -209
  145. data/samples/event/activation.rb +72 -67
  146. data/samples/event/event.rb +160 -153
  147. data/samples/event/threaded.rb +8 -1
  148. data/samples/event/update_ui_event.rb +67 -60
  149. data/samples/grid/grid.rb +188 -181
  150. data/samples/grid/gridtablebase.rb +136 -129
  151. data/samples/html/html.rb +208 -204
  152. data/samples/mdi/mdi.rb +59 -54
  153. data/samples/minimal/minimal.rb +54 -51
  154. data/samples/minimal/nothing.rb +1 -0
  155. data/samples/printing/printing.rb +367 -377
  156. data/samples/printing/printing2.rb +203 -198
  157. data/samples/propgrid/propgrid.rb +2312 -2308
  158. data/samples/propgrid/propgrid_minimal.rb +57 -50
  159. data/samples/ribbon/ribbon.rb +780 -774
  160. data/samples/sampler/ext.rb +0 -33
  161. data/samples/sampler/sample.rb +4 -9
  162. data/samples/sampler.rb +1 -1
  163. data/samples/splash/splash.rb +118 -116
  164. data/samples/text/rich_textctrl.rb +207 -201
  165. data/samples/text/richtext.rb +1409 -1405
  166. data/samples/text/scintilla.rb +137 -128
  167. data/samples/text/textctrl.rb +89 -83
  168. data/samples/text/unicode.rb +175 -168
  169. data/samples/treectrl/treectrl.rb +1430 -1426
  170. data/samples/widgets/activityindicator.rb +95 -0
  171. data/samples/widgets/art/widgets/activityindicator.xpm +278 -0
  172. data/samples/widgets/art/widgets/bmpbtn.xpm +37 -0
  173. data/samples/widgets/art/widgets/bmpcombobox.xpm +54 -0
  174. data/samples/widgets/art/widgets/button.xpm +54 -0
  175. data/samples/widgets/art/widgets/checkbox.xpm +54 -0
  176. data/samples/{bigdemo/icons → widgets/art/widgets}/choice.xpm +1 -1
  177. data/samples/widgets/art/widgets/choicebk.xpm +54 -0
  178. data/samples/widgets/art/widgets/clrpicker.xpm +193 -0
  179. data/samples/widgets/art/widgets/combobox.xpm +54 -0
  180. data/samples/widgets/art/widgets/datepick.xpm +200 -0
  181. data/samples/widgets/art/widgets/dirctrl.xpm +54 -0
  182. data/samples/widgets/art/widgets/dirpicker.xpm +213 -0
  183. data/samples/widgets/art/widgets/filepicker.xpm +214 -0
  184. data/samples/widgets/art/widgets/fontpicker.xpm +185 -0
  185. data/samples/widgets/art/widgets/gauge.xpm +54 -0
  186. data/samples/widgets/art/widgets/header.xpm +54 -0
  187. data/samples/widgets/art/widgets/hyperlnk.xpm +54 -0
  188. data/samples/widgets/art/widgets/listbook.xpm +54 -0
  189. data/samples/widgets/art/widgets/listbox.xpm +54 -0
  190. data/samples/widgets/art/widgets/native.xpm +81 -0
  191. data/samples/widgets/art/widgets/notebook.xpm +54 -0
  192. data/samples/widgets/art/widgets/odcombobox.xpm +54 -0
  193. data/samples/widgets/art/widgets/radiobox.xpm +54 -0
  194. data/samples/widgets/art/widgets/scrolbar.xpm +54 -0
  195. data/samples/widgets/art/widgets/slider.xpm +54 -0
  196. data/samples/widgets/art/widgets/spinbtn.xpm +40 -0
  197. data/samples/widgets/art/widgets/statbmp.xpm +40 -0
  198. data/samples/widgets/art/widgets/statbox.xpm +54 -0
  199. data/samples/widgets/art/widgets/stattext.xpm +54 -0
  200. data/samples/widgets/art/widgets/text.xpm +54 -0
  201. data/samples/widgets/art/widgets/timepick.xpm +207 -0
  202. data/samples/widgets/art/widgets/toggle.xpm +54 -0
  203. data/samples/widgets/art/widgets/toucan.png +0 -0
  204. data/samples/widgets/bmpcombobox.rb +651 -0
  205. data/samples/widgets/button.rb +462 -0
  206. data/samples/widgets/checkbox.rb +211 -0
  207. data/samples/widgets/choice.rb +287 -0
  208. data/samples/widgets/clrpicker.rb +156 -0
  209. data/samples/widgets/combobox.rb +516 -0
  210. data/samples/widgets/datepick.rb +215 -0
  211. data/samples/widgets/dirctrl.rb +265 -0
  212. data/samples/widgets/dirpicker.rb +158 -0
  213. data/samples/widgets/editlbox.rb +122 -0
  214. data/samples/widgets/filectrl.rb +216 -0
  215. data/samples/widgets/filepicker.rb +214 -0
  216. data/samples/widgets/fontpicker.rb +135 -0
  217. data/samples/widgets/gauge.rb +311 -0
  218. data/samples/widgets/headerctrl.rb +236 -0
  219. data/samples/widgets/hyperlink.rb +203 -0
  220. data/samples/widgets/itemcontainer.rb +185 -0
  221. data/samples/widgets/listbox.rb +473 -0
  222. data/samples/widgets/notebook.rb +488 -0
  223. data/samples/widgets/odcombobox.rb +608 -0
  224. data/samples/widgets/radiobox.rb +328 -0
  225. data/samples/widgets/searchctrl.rb +159 -0
  226. data/samples/widgets/slider.rb +594 -0
  227. data/samples/widgets/spinbtn.rb +443 -0
  228. data/samples/widgets/statbmp.rb +130 -0
  229. data/samples/widgets/static.rb +436 -0
  230. data/samples/widgets/textctrl.rb +700 -0
  231. data/samples/widgets/timepick.rb +148 -0
  232. data/samples/widgets/tn_widgets.png +0 -0
  233. data/samples/widgets/toggle.rb +385 -0
  234. data/samples/widgets/widgets.rb +1229 -0
  235. data/samples/xrc/custom_xrc_sample.rb +47 -41
  236. data/samples/xrc/xrc_sample.rb +53 -47
  237. data/tests/test_config.rb +207 -42
  238. data/tests/test_event_handling.rb +52 -34
  239. data/tests/test_events.rb +7 -0
  240. data/tests/test_item_data.rb +24 -0
  241. data/tests/test_persistence.rb +142 -0
  242. data/tests/test_sizer.rb +44 -1
  243. data/tests/test_validators.rb +805 -0
  244. metadata +109 -138
  245. data/lib/wx/core/choice.rb +0 -14
  246. data/lib/wx/core/combo_ctrl.rb +0 -110
  247. data/rakelib/lib/typemap/grid_client_data.rb +0 -58
  248. data/samples/bigdemo/About.rbw +0 -39
  249. data/samples/bigdemo/ColorPanel.rbw +0 -23
  250. data/samples/bigdemo/GridSimple.rbw +0 -78
  251. data/samples/bigdemo/MDIDemo.rbw +0 -57
  252. data/samples/bigdemo/PopupMenu.rbw +0 -146
  253. data/samples/bigdemo/ShapedWindow.rbw +0 -128
  254. data/samples/bigdemo/Sizers.rbw +0 -541
  255. data/samples/bigdemo/bigdemo.rb +0 -817
  256. data/samples/bigdemo/demoTemplate.rbw +0 -33
  257. data/samples/bigdemo/helpfile.htb +0 -0
  258. data/samples/bigdemo/icons/Test 015.jpg +0 -0
  259. data/samples/bigdemo/icons/Test 015.png +0 -0
  260. data/samples/bigdemo/icons/choice.bmp +0 -0
  261. data/samples/bigdemo/icons/combo.bmp +0 -0
  262. data/samples/bigdemo/icons/combo.xpm +0 -27
  263. data/samples/bigdemo/icons/copy.xpm +0 -25
  264. data/samples/bigdemo/icons/cut.xpm +0 -24
  265. data/samples/bigdemo/icons/gauge.bmp +0 -0
  266. data/samples/bigdemo/icons/gauge.xpm +0 -27
  267. data/samples/bigdemo/icons/help.xpm +0 -25
  268. data/samples/bigdemo/icons/list.bmp +0 -0
  269. data/samples/bigdemo/icons/list.xpm +0 -27
  270. data/samples/bigdemo/icons/mondrian.ico +0 -0
  271. data/samples/bigdemo/icons/mondrian.xpm +0 -44
  272. data/samples/bigdemo/icons/new.xpm +0 -24
  273. data/samples/bigdemo/icons/ogl.ico +0 -0
  274. data/samples/bigdemo/icons/ogl.xpm +0 -45
  275. data/samples/bigdemo/icons/open.xpm +0 -26
  276. data/samples/bigdemo/icons/paste.bmp +0 -0
  277. data/samples/bigdemo/icons/paste.xpm +0 -38
  278. data/samples/bigdemo/icons/pointy.png +0 -0
  279. data/samples/bigdemo/icons/preview.xpm +0 -26
  280. data/samples/bigdemo/icons/print.xpm +0 -26
  281. data/samples/bigdemo/icons/radio.bmp +0 -0
  282. data/samples/bigdemo/icons/radio.xpm +0 -27
  283. data/samples/bigdemo/icons/robert.xpm +0 -415
  284. data/samples/bigdemo/icons/sashtest.ico +0 -0
  285. data/samples/bigdemo/icons/save.xpm +0 -25
  286. data/samples/bigdemo/icons/smiles.bmp +0 -0
  287. data/samples/bigdemo/icons/smiles.xpm +0 -39
  288. data/samples/bigdemo/icons/smiley.ico +0 -0
  289. data/samples/bigdemo/icons/smiley.xpm +0 -42
  290. data/samples/bigdemo/icons/stattext.xpm +0 -24
  291. data/samples/bigdemo/icons/test2.bmp +0 -0
  292. data/samples/bigdemo/icons/test2.png +0 -0
  293. data/samples/bigdemo/icons/test2.xpm +0 -79
  294. data/samples/bigdemo/icons/text.bmp +0 -0
  295. data/samples/bigdemo/icons/text.xpm +0 -27
  296. data/samples/bigdemo/icons/tog1.bmp +0 -0
  297. data/samples/bigdemo/icons/tog1.xpm +0 -38
  298. data/samples/bigdemo/icons/tog2.bmp +0 -0
  299. data/samples/bigdemo/icons/tog2.xpm +0 -38
  300. data/samples/bigdemo/icons/wxruby-128x128.png +0 -0
  301. data/samples/bigdemo/icons/wxwin.ico +0 -0
  302. data/samples/bigdemo/icons/wxwin16x16.png +0 -0
  303. data/samples/bigdemo/icons/wxwin16x16.xpm +0 -25
  304. data/samples/bigdemo/icons/wxwin32x32.png +0 -0
  305. data/samples/bigdemo/icons/wxwin48x48.png +0 -0
  306. data/samples/bigdemo/run.rb +0 -98
  307. data/samples/bigdemo/tips.txt +0 -7
  308. data/samples/bigdemo/utils.rb +0 -20
  309. data/samples/bigdemo/wxArtProvider.rbw +0 -282
  310. data/samples/bigdemo/wxBitmapButton.rbw +0 -65
  311. data/samples/bigdemo/wxButton.rbw +0 -64
  312. data/samples/bigdemo/wxCalendarCtrl.rbw +0 -59
  313. data/samples/bigdemo/wxCheckBox.rbw +0 -50
  314. data/samples/bigdemo/wxCheckListBox.rbw +0 -65
  315. data/samples/bigdemo/wxChoice.rbw +0 -47
  316. data/samples/bigdemo/wxChoicebook.rbw +0 -78
  317. data/samples/bigdemo/wxColourDialog.rbw +0 -33
  318. data/samples/bigdemo/wxComboBox.rbw +0 -77
  319. data/samples/bigdemo/wxCursor.rbw +0 -136
  320. data/samples/bigdemo/wxDialog.rbw +0 -74
  321. data/samples/bigdemo/wxDirDialog.rbw +0 -29
  322. data/samples/bigdemo/wxDragImage.rbw +0 -70
  323. data/samples/bigdemo/wxFileDialog.rbw +0 -37
  324. data/samples/bigdemo/wxFileDialog_Save.rbw +0 -35
  325. data/samples/bigdemo/wxFindReplaceDialog.rbw +0 -82
  326. data/samples/bigdemo/wxFontDialog.rbw +0 -200
  327. data/samples/bigdemo/wxFrame.rbw +0 -53
  328. data/samples/bigdemo/wxGauge.rbw +0 -65
  329. data/samples/bigdemo/wxGenericDirCtrl.rbw +0 -74
  330. data/samples/bigdemo/wxGrid.rbw +0 -66
  331. data/samples/bigdemo/wxHtmlHelpController.rbw +0 -52
  332. data/samples/bigdemo/wxListBox.rbw +0 -140
  333. data/samples/bigdemo/wxListCtrl_virtual.rbw +0 -112
  334. data/samples/bigdemo/wxMDIWindows.rbw +0 -50
  335. data/samples/bigdemo/wxMenu.rbw +0 -247
  336. data/samples/bigdemo/wxMessageDialog.rbw +0 -27
  337. data/samples/bigdemo/wxMiniFrame.rbw +0 -70
  338. data/samples/bigdemo/wxMultipleChoiceDialog.rbw +0 -29
  339. data/samples/bigdemo/wxNotebook.rbw +0 -136
  340. data/samples/bigdemo/wxProgressDialog.rbw +0 -43
  341. data/samples/bigdemo/wxRadioBox.rbw +0 -72
  342. data/samples/bigdemo/wxRadioButton.rbw +0 -125
  343. data/samples/bigdemo/wxSashWindow.rbw +0 -141
  344. data/samples/bigdemo/wxScrolledMessageDialog.rbw +0 -57
  345. data/samples/bigdemo/wxScrolledWindow.rbw +0 -199
  346. data/samples/bigdemo/wxSingleChoiceDialog.rbw +0 -33
  347. data/samples/bigdemo/wxSlider.rbw +0 -42
  348. data/samples/bigdemo/wxSpinButton.rbw +0 -50
  349. data/samples/bigdemo/wxSpinCtrl.rbw +0 -51
  350. data/samples/bigdemo/wxSplitterWindow.rbw +0 -63
  351. data/samples/bigdemo/wxStaticBitmap.rbw +0 -47
  352. data/samples/bigdemo/wxStaticText.rbw +0 -55
  353. data/samples/bigdemo/wxStatusBar.rbw +0 -126
  354. data/samples/bigdemo/wxTextCtrl.rbw +0 -149
  355. data/samples/bigdemo/wxTextEntryDialog.rbw +0 -31
  356. data/samples/bigdemo/wxToggleButton.rbw +0 -49
  357. data/samples/bigdemo/wxToolBar.rbw +0 -131
  358. data/samples/bigdemo/wxTreeCtrl.rbw +0 -191
  359. data/samples/caret/caret.rb +0 -298
  360. data/samples/caret/mondrian.xpm +0 -44
  361. data/samples/controls/books.rb +0 -189
  362. data/samples/controls/choice.xpm +0 -27
  363. data/samples/controls/combo.xpm +0 -27
  364. data/samples/controls/controls.rb +0 -1099
  365. data/samples/controls/gauge.xpm +0 -27
  366. data/samples/controls/list.xpm +0 -27
  367. data/samples/controls/mondrian.ico +0 -0
  368. data/samples/controls/mondrian.xpm +0 -44
  369. data/samples/controls/radio.xpm +0 -27
  370. data/samples/controls/stattext.xpm +0 -24
  371. data/samples/controls/test2.bmp +0 -0
  372. data/samples/controls/text.xpm +0 -27
  373. data/samples/controls/tn_books.png +0 -0
  374. data/samples/controls/tn_controls.png +0 -0
  375. data/samples/etc/choice.rb +0 -87
  376. data/samples/etc/tn_choice.png +0 -0
  377. data/samples/text/mondrian.ico +0 -0
  378. data/samples/text/mondrian.xpm +0 -44
  379. /data/samples/{caret → etc}/tn_caret.png +0 -0
@@ -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).
@@ -0,0 +1,101 @@
1
+ <!--
2
+ # @markup markdown
3
+ # @title 14. Configuration support
4
+ -->
5
+
6
+ # 14. Configuration support
7
+
8
+ ## Introduction
9
+
10
+ wxRuby3 fully supports the wxWidgets config classes providing a Ruby-fied interface.
11
+
12
+ The config classes provide a way to store some application configuration information providing features
13
+ that make them very useful for storing all kinds of small to medium volumes of hierarchically-organized,
14
+ heterogeneous data.
15
+ In wxWidgets these were especially designed for storing application configuration information and intended to be
16
+ mostly limited to that. That meant the information to be stored was intended to be:
17
+
18
+ * Typed, i.e. strings, booleans or numbers for the moment. You cannot store binary data, for example.
19
+ * Small. For instance, it is not recommended to use the Windows registry (which is the default storage medium on
20
+ that platform) for amounts of data more than a couple of kilobytes.
21
+ * Not performance critical, neither from speed nor from a memory consumption point of view.
22
+
23
+ As you will see wxRuby3 extends the support in this area and provides means to forego a lot of these restrictions.
24
+
25
+ The config classes also are intended to abstract away a lot of platform differences. In this area wxRuby3 extends the
26
+ support also.
27
+
28
+ ## Default configuration support
29
+
30
+ When the default, global, config instance is used (by using {Wx::ConfigBase.get} with default argument) this will be
31
+ a platform specific instance. On Windows platforms a Windows registry based implementation is used and on other
32
+ platforms a text format configuration file.
33
+
34
+ wxRuby3 provides a single wrapper class for these with {Wx::ConfigWx}. This is an abstract class that cannot be
35
+ instantiated in Ruby which provides a common, Ruby-fied interface supported by all config classes in wxRuby3.
36
+
37
+ While wxWidgets does a decent job of abstracting platform differences it is in no way perfect in this area. With the
38
+ text format configuration files for example the stored values loose all type information since everything is stored
39
+ as strings. This also differs from the registry based implementation where some type information is not lost but some
40
+ (like boolean types) is.
41
+ This is not a problem when accessing information for which the structure and types are exactly known as the config
42
+ classes offer type specific readers (as well as writers) which coerce values to their expected types but may offer
43
+ nasty surprises when more reflectively accessing data of which the exact typing and structure is not known.
44
+
45
+ In Ruby where we more or less expect to have common API-s that can return or accept any type of object needing to be
46
+ type specific is awkward. wxRuby3 works around this as much as possible for the {Wx::ConfigWx} wrapper class but also
47
+ provides an alternative config class integrated with the wxWidgets framework that does not suffer from these restrictions.
48
+
49
+ ## Enhanced Ruby configuration support
50
+
51
+ Instead of the default, platform specific, config classes it is also possible to use a custom wxRuby3 extension providing
52
+ a config class which is implemented in pure Ruby and integrated in the wxWidgets configuration framework.
53
+ To use an instance of this class as the global config instance the {Wx::ConfigBase.create} should be called at application
54
+ initialization time with it's `:use_hash_config` keyword argument set to `true` (and possibly, to be sure, it's
55
+ `forced_create` argument set to `true` also). This would create an instance of {Wx::Config} and install that as the global config instance (if no other instance was
56
+ yet installed or, overruling that condition, if `forced_create` was set to `true`).<br>
57
+ Alternatively a {Wx::Config} (or derivative) instance could be explicitly instantiated in code and assigned as global
58
+ instance with {Wx::ConfigBase.set}.
59
+
60
+ As the keyword argument indicates {Wx::Config} is a Ruby `Hash` based config class implementation.
61
+
62
+ Value objects are stored Ruby-style as-is into it's internal hash table (maintaining full type information) and are also
63
+ retrieved as-is by default (to maintain compatibility with the {Wx::ConfigWx} wrapper type coercion options are provided).
64
+ Grouping is based of nested `Hash` instances.
65
+
66
+ Because of the `Hash` based implementation and lack of (the need for) type coercion the {Wx::Config} class does have **any**
67
+ restrictions of the type of data stored. The only possible type restrictions to enforce may come from usage contexts:
68
+
69
+ * In case of value entries shared with wxWidgets framework code (like for example entries save by the persistence
70
+ framework; see [here](15_persistence.md)) value types should be restricted to those supported by the wxWidget platform
71
+ specific classes and correspond to what the framework code expects.
72
+ * In case of the need to save/restore the configuration data to/from persistent storage which imposes type restrictions these
73
+ should be applied.
74
+
75
+ With {Wx::Config} it would be perfectly alright to store arrays or any kind of arbitrary object (only be aware that `Hash`
76
+ instances will always be expected to provide configuration structure by default) as long as these do not conflict with
77
+ expectations of framework code or storage mechanisms.
78
+
79
+ With the standard Ruby YAML and JSON serialization support this also provides improved platform independent configuration
80
+ persistence options with full type information maintainability.
81
+
82
+ ## Differences between default and enhanced configuration support
83
+
84
+ The major difference is, as described above, the absence of type restrictions in the enhanced Ruby config class {Wx::Config}.
85
+
86
+ Another difference is that {Wx::Config} will not automatically create missing groups or entries on reading. This will only
87
+ happen when writing configuration values.
88
+
89
+ A last difference is that the default support is by default backed up by persistent storage (windows registry or file) and
90
+ the wxRuby enhanced support only provides in-memory storage (`Hash` instance) by default. +
91
+ Persisting configuration data from {Wx::Config} will require coding customized storage and retrieval operations (which is
92
+ trivial using standard YAML or JSON support).
93
+
94
+ ## Differences between wxWidgets config interface and wxRuby
95
+
96
+ In wxRuby there is no option to provide a default value argument when reading values. The reasoning is that Ruby itself
97
+ provides more than enough options to elegantly provide for defaults with statement options like `var ||= default` or
98
+ `var = get('something') || default`.
99
+
100
+ As a consequence wxRuby also does not support recording defaults on read operations (and also does not provide the
101
+ corresponding option setter/getter in the interface).
@@ -0,0 +1,148 @@
1
+ <!--
2
+ # @markup markdown
3
+ # @title 15. Persistence support
4
+ -->
5
+
6
+ # 15. Persistence support
7
+
8
+ ## Introduction
9
+
10
+ wxRuby3 fully supports the wxWidgets persistence framework.
11
+
12
+ This framework provides the means to persist window (and other object) states which can than be restored when
13
+ re-creating these objects.
14
+
15
+ The persistence framework depends on the configuration framework (see [here](14_config.md)).
16
+
17
+ The persistence framework includes the following components:
18
+
19
+ * {Wx::PersistenceManager} which all persistent objects register themselves with. This class handles actual saving
20
+ and restoring of persistent data.
21
+ * Persistent object adapters for persistent objects. These adapters provide a bridge between the associated class –
22
+ which has no special persistence support – and {Wx::PersistenceManager}. All Persistent object adapters need to derive
23
+ from {Wx::PersistentObject} (like {Wx::PersistentWindowBase} and it's derivatives).
24
+ * The {Wx.create_persistent_object} and {Wx.persistent_register_and_restore} methods (mainly convenience methods for
25
+ wxWidgets compatibility).
26
+
27
+ ## Persistence manager
28
+
29
+ By default a global singleton manager instance is available through {Wx::PersistenceManager.get} which will be used
30
+ by all available persistent object adapters for saving/restoring state values.
31
+
32
+ An alternate (possibly customized) manager instance can be installed through {Wx::PersistenceManager.set}.
33
+
34
+ ## Persistent object adapters
35
+
36
+ All persistent object adapters must be derived from {Wx::PersistentObject}. This class provides common methods for
37
+ saving and restoring state values connecting to the persistence manager for actual writing and reading.
38
+
39
+ All windows/objects to be persisted need to be registered with the persistence manager. Creating the correct persistent
40
+ object adapter instance for an object to persist is abstracted away in wxWidgets by using template methods allowing
41
+ to simply only provide the object to persist instead of having to explicitly instantiate an adapter instance and provide
42
+ both to the persistence manager (which is however still possible).
43
+
44
+ wxRuby3 replaces this convenience interface (incompatible with Ruby) by a Ruby-fied approach which relies on Rubies
45
+ trusted *duck typing*.<br>
46
+ In wxRuby3 any class supported by a specific persistent object adapter class should implement the method
47
+ `#create_persistent_object` which should return a unique adapter instance for the object instance to be persisted
48
+ like this:
49
+
50
+ ```ruby
51
+ class MyPersistentObject < Wx::PersistentObject
52
+
53
+ # Save the object properties.
54
+ # The implementation of this method should use {Wx::PersistentObject#save_value}.
55
+ # @return [void]
56
+ def save
57
+ # ...
58
+ end
59
+
60
+ # Restore the object properties.
61
+ # The implementation of this method should use {Wx::PersistentObject#restore_value}.
62
+ # @return [Boolean]
63
+ def restore
64
+ # ...
65
+ end
66
+
67
+ # Returns the string uniquely identifying the objects supported by this adapter.
68
+ # This method has default implementations in any of the built-in derived adapter classes.
69
+ # @return [String]
70
+ def get_kind
71
+ 'MyObject'
72
+ end
73
+
74
+ # Returns the string uniquely identifying the object we're associated with among all the other objects of the same type.
75
+ # This method has a default implementation in Wx::PersistentWindowBase returning the window name.
76
+ # @return [String]
77
+ def get_name
78
+ 'object_1'
79
+ end
80
+
81
+ end
82
+
83
+ class MyObject
84
+
85
+ # ...
86
+
87
+ def create_persistent_object
88
+ MyPersistentObject.new(self)
89
+ end
90
+
91
+ # ...
92
+
93
+ end
94
+ ```
95
+
96
+ ## Persistent windows
97
+
98
+ A number of classes provide built-in support for persistence of a number of windows or controls:
99
+
100
+ * {Wx::PersistentTLW} supports top level windows (including {Wx::Frame} and {Wx::Dialog}).
101
+ * {Wx::PersistentBookCtrl} supports the book controls {Wx::Notebook}, {Wx::Listbook}, {Wx::Toolbook} and {Wx::Choicebook}.
102
+ * {Wx::PersistentTreeBookCtrl} supports {Wx::Treebook}
103
+
104
+ All persistent window adapters are derived from {Wx::PersistentWindowBase}. This class makes sure that any window
105
+ registered for persisting gets automatically saved when the window is destroyed. Intermittently explicit saving still
106
+ remains possible of course.
107
+
108
+ User defined persistent window adapters can be derived from this class or any of the built-in derivatives to support
109
+ otherwise unsupported or custom windows/controls like this:
110
+
111
+ ```ruby
112
+ class PersistentButton < Wx::PersistentWindowBase
113
+
114
+ def get_kind
115
+ 'Button'
116
+ end
117
+
118
+ def save
119
+ save_value('w', get.size.width)
120
+ save_value('h', get.size.height)
121
+ save_value('label', get.label)
122
+ save_value('my_custom_value', get.my_custom_value)
123
+ end
124
+
125
+ def restore
126
+ get.size = [Integer(restore_value('w')), Integer(restore_value('h'))]
127
+ get.label = restore_value('label')
128
+ get.my_custom_value = Float(restore_value('my_custom_value'))
129
+ true
130
+ end
131
+
132
+ end
133
+
134
+ class MyButton < Wx::Button
135
+
136
+ def initialize(parent=nil, name)
137
+ super(parent, label: '', name: name)
138
+ @my_custom_value = ''
139
+ end
140
+
141
+ attr_accessor :my_custom_value
142
+
143
+ def create_persistent_object
144
+ PersistentButton.new(self)
145
+ end
146
+
147
+ end
148
+ ```
@@ -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