wxruby3 1.6.1 → 1.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (530) hide show
  1. checksums.yaml +4 -4
  2. data/CREDITS.md +32 -25
  3. data/INSTALL.md +19 -4
  4. data/README.md +5 -5
  5. data/assets/repo-social-preview.odg +0 -0
  6. data/assets/repo-social-preview.xcf +0 -0
  7. data/ext/wxruby3/include/wxRubyApp.h +58 -45
  8. data/ext/wxruby3/include/wxruby-runtime.h +78 -1
  9. data/ext/wxruby3/swig/common.i +2 -2
  10. data/ext/wxruby3/swig/custom/director.swg +2 -2
  11. data/ext/wxruby3/swig/custom/rubyprimtypes.swg +59 -15
  12. data/ext/wxruby3/swig/custom/rubyrun.swg +4 -0
  13. data/ext/wxruby3/swig/custom/rubytracking.swg +4 -0
  14. data/ext/wxruby3/swig/custom/swiglabels.swg +129 -0
  15. data/ext/wxruby3/swig/custom/swigrun.swg +15 -0
  16. data/ext/wxruby3/swig/custom/typemaps/swigtypemaps.swg +20 -0
  17. data/ext/wxruby3/swig/mark_free_impl.i +152 -88
  18. data/ext/wxruby3/swig/memory_management.i +1 -0
  19. data/ext/wxruby3/swig/wx.i +73 -44
  20. data/lib/wx/aui/events/evt_list.rb +148 -0
  21. data/lib/wx/aui/require.rb +0 -1
  22. data/lib/wx/core/calendar_ctrl.rb +15 -0
  23. data/lib/wx/core/clipboard.rb +9 -13
  24. data/lib/wx/core/config.rb +1 -1
  25. data/lib/wx/core/events/evt_list.rb +1458 -0
  26. data/lib/wx/core/font/encoding.rb +113 -0
  27. data/lib/wx/core/generic_validator.rb +83 -31
  28. data/lib/wx/core/tipwindow.rb +16 -0
  29. data/lib/wx/doc/aui/auitabctrl.rb +35 -0
  30. data/lib/wx/doc/config.rb +2 -2
  31. data/lib/wx/doc/functions.rb +1 -1
  32. data/lib/wx/doc/gen/about_dialog_info.rb +330 -0
  33. data/lib/wx/doc/gen/accelerator.rb +178 -0
  34. data/lib/wx/doc/gen/activity_indicator.rb +83 -0
  35. data/lib/wx/doc/gen/affine_matrix2d.rb +284 -0
  36. data/lib/wx/doc/gen/animation.rb +275 -0
  37. data/lib/wx/doc/gen/animation_ctrl.rb +300 -0
  38. data/lib/wx/doc/gen/any_button.rb +191 -0
  39. data/lib/wx/doc/gen/app.rb +463 -0
  40. data/lib/wx/doc/gen/app_traits.rb +396 -0
  41. data/lib/wx/doc/gen/art_provider.rb +605 -0
  42. data/lib/wx/doc/gen/aui/aui_dock_art.rb +455 -0
  43. data/lib/wx/doc/gen/aui/aui_floating_frame.rb +54 -0
  44. data/lib/wx/doc/gen/aui/aui_manager.rb +847 -0
  45. data/lib/wx/doc/gen/aui/aui_manager_event.rb +131 -0
  46. data/lib/wx/doc/gen/aui/aui_mdi_child_frame.rb +180 -0
  47. data/lib/wx/doc/gen/aui/aui_mdi_client_window.rb +59 -0
  48. data/lib/wx/doc/gen/aui/aui_mdi_parent_frame.rb +130 -0
  49. data/lib/wx/doc/gen/aui/aui_notebook.rb +631 -0
  50. data/lib/wx/doc/gen/aui/aui_notebook_event.rb +233 -0
  51. data/lib/wx/doc/gen/aui/aui_pane_info.rb +769 -0
  52. data/lib/wx/doc/gen/aui/aui_tab_art.rb +352 -0
  53. data/lib/wx/doc/gen/aui/aui_tab_ctrl.rb +14 -0
  54. data/lib/wx/doc/gen/aui/aui_tool_bar.rb +510 -0
  55. data/lib/wx/doc/gen/aui/aui_tool_bar_art.rb +340 -0
  56. data/lib/wx/doc/gen/aui/aui_tool_bar_event.rb +244 -0
  57. data/lib/wx/doc/gen/aui/aui_tool_bar_item.rb +257 -0
  58. data/lib/wx/doc/gen/aui/event_list.rb +179 -0
  59. data/lib/wx/doc/gen/banner_window.rb +124 -0
  60. data/lib/wx/doc/gen/bitmap.rb +731 -0
  61. data/lib/wx/doc/gen/bitmap_button.rb +123 -0
  62. data/lib/wx/doc/gen/bitmap_combo_box.rb +221 -0
  63. data/lib/wx/doc/gen/book_ctrl_base.rb +273 -0
  64. data/lib/wx/doc/gen/book_ctrl_event.rb +66 -0
  65. data/lib/wx/doc/gen/box_sizer.rb +85 -0
  66. data/lib/wx/doc/gen/brush.rb +251 -0
  67. data/lib/wx/doc/gen/busy_info.rb +157 -0
  68. data/lib/wx/doc/gen/button.rb +182 -0
  69. data/lib/wx/doc/gen/calculate_layout_event.rb +62 -0
  70. data/lib/wx/doc/gen/calendar_ctrl.rb +505 -0
  71. data/lib/wx/doc/gen/calendar_date_attr.rb +138 -0
  72. data/lib/wx/doc/gen/calendar_event.rb +147 -0
  73. data/lib/wx/doc/gen/caret.rb +97 -0
  74. data/lib/wx/doc/gen/check_box.rb +175 -0
  75. data/lib/wx/doc/gen/check_list_box.rb +121 -0
  76. data/lib/wx/doc/gen/choice.rb +175 -0
  77. data/lib/wx/doc/gen/choicebook.rb +116 -0
  78. data/lib/wx/doc/gen/client_dc.rb +43 -0
  79. data/lib/wx/doc/gen/clipboard.rb +144 -0
  80. data/lib/wx/doc/gen/collapsible_pane.rb +138 -0
  81. data/lib/wx/doc/gen/collapsible_pane_event.rb +46 -0
  82. data/lib/wx/doc/gen/colour.rb +333 -0
  83. data/lib/wx/doc/gen/colour_dialog.rb +190 -0
  84. data/lib/wx/doc/gen/colour_picker_ctrl.rb +110 -0
  85. data/lib/wx/doc/gen/colour_picker_event.rb +77 -0
  86. data/lib/wx/doc/gen/combo_box.rb +292 -0
  87. data/lib/wx/doc/gen/combo_ctrl.rb +662 -0
  88. data/lib/wx/doc/gen/command_link_button.rb +134 -0
  89. data/lib/wx/doc/gen/config_base.rb +10 -0
  90. data/lib/wx/doc/gen/context_help_button.rb +109 -0
  91. data/lib/wx/doc/gen/control.rb +277 -0
  92. data/lib/wx/doc/gen/control_with_items.rb +253 -0
  93. data/lib/wx/doc/gen/core.rb +45 -0
  94. data/lib/wx/doc/gen/credential_entry_dialog.rb +137 -0
  95. data/lib/wx/doc/gen/cursor.rb +193 -0
  96. data/lib/wx/doc/gen/data_format.rb +85 -0
  97. data/lib/wx/doc/gen/data_object.rb +436 -0
  98. data/lib/wx/doc/gen/data_object_simple_base.rb +10 -0
  99. data/lib/wx/doc/gen/date_event.rb +49 -0
  100. data/lib/wx/doc/gen/date_picker_ctrl.rb +161 -0
  101. data/lib/wx/doc/gen/dc.rb +1631 -0
  102. data/lib/wx/doc/gen/dc_overlay.rb +102 -0
  103. data/lib/wx/doc/gen/defs.rb +2802 -0
  104. data/lib/wx/doc/gen/dial_up_event.rb +45 -0
  105. data/lib/wx/doc/gen/dial_up_manager.rb +149 -0
  106. data/lib/wx/doc/gen/dialog.rb +541 -0
  107. data/lib/wx/doc/gen/dir_dialog.rb +164 -0
  108. data/lib/wx/doc/gen/dir_filter_list_ctrl.rb +90 -0
  109. data/lib/wx/doc/gen/dir_picker_ctrl.rb +125 -0
  110. data/lib/wx/doc/gen/display.rb +238 -0
  111. data/lib/wx/doc/gen/drag_drop.rb +299 -0
  112. data/lib/wx/doc/gen/drag_image.rb +116 -0
  113. data/lib/wx/doc/gen/editable_list_box.rb +109 -0
  114. data/lib/wx/doc/gen/event.rb +990 -0
  115. data/lib/wx/doc/gen/event_blocker.rb +50 -0
  116. data/lib/wx/doc/gen/event_filter.rb +92 -0
  117. data/lib/wx/doc/gen/event_list.rb +1644 -0
  118. data/lib/wx/doc/gen/events.rb +2809 -0
  119. data/lib/wx/doc/gen/evt_handler.rb +229 -0
  120. data/lib/wx/doc/gen/ext_help_controller.rb +109 -0
  121. data/lib/wx/doc/gen/file_ctrl.rb +231 -0
  122. data/lib/wx/doc/gen/file_ctrl_event.rb +83 -0
  123. data/lib/wx/doc/gen/file_dialog.rb +353 -0
  124. data/lib/wx/doc/gen/file_dialog_custom_control.rb +165 -0
  125. data/lib/wx/doc/gen/file_dialog_customize_hook.rb +158 -0
  126. data/lib/wx/doc/gen/file_dir_picker_event.rb +100 -0
  127. data/lib/wx/doc/gen/file_picker_ctrl.rb +132 -0
  128. data/lib/wx/doc/gen/file_system.rb +232 -0
  129. data/lib/wx/doc/gen/find_dialog_event.rb +126 -0
  130. data/lib/wx/doc/gen/find_replace_data.rb +60 -0
  131. data/lib/wx/doc/gen/find_replace_dialog.rb +58 -0
  132. data/lib/wx/doc/gen/flex_grid_sizer.rb +199 -0
  133. data/lib/wx/doc/gen/font.rb +1379 -0
  134. data/lib/wx/doc/gen/font_data.rb +151 -0
  135. data/lib/wx/doc/gen/font_dialog.rb +88 -0
  136. data/lib/wx/doc/gen/font_picker_ctrl.rb +143 -0
  137. data/lib/wx/doc/gen/font_picker_event.rb +65 -0
  138. data/lib/wx/doc/gen/frame.rb +352 -0
  139. data/lib/wx/doc/gen/fs_file.rb +337 -0
  140. data/lib/wx/doc/gen/functions.rb +10 -0
  141. data/lib/wx/doc/gen/gauge.rb +157 -0
  142. data/lib/wx/doc/gen/gb_sizer_item.rb +68 -0
  143. data/lib/wx/doc/gen/gcdc.rb +46 -0
  144. data/lib/wx/doc/gen/gdi_common.rb +1271 -0
  145. data/lib/wx/doc/gen/gdi_object.rb +31 -0
  146. data/lib/wx/doc/gen/generic_about_dialog.rb +140 -0
  147. data/lib/wx/doc/gen/generic_dir_ctrl.rb +223 -0
  148. data/lib/wx/doc/gen/geometry.rb +661 -0
  149. data/lib/wx/doc/gen/graphics_context.rb +1184 -0
  150. data/lib/wx/doc/gen/graphics_object.rb +750 -0
  151. data/lib/wx/doc/gen/grid/event_list.rb +191 -0
  152. data/lib/wx/doc/gen/grid/grid_cell_activatable_editor.rb +40 -0
  153. data/lib/wx/doc/gen/grid/grid_cell_attr.rb +280 -0
  154. data/lib/wx/doc/gen/grid/grid_cell_auto_wrap_string_editor.rb +35 -0
  155. data/lib/wx/doc/gen/grid/grid_cell_auto_wrap_string_renderer.rb +37 -0
  156. data/lib/wx/doc/gen/grid/grid_cell_bool_editor.rb +49 -0
  157. data/lib/wx/doc/gen/grid/grid_cell_bool_renderer.rb +35 -0
  158. data/lib/wx/doc/gen/grid/grid_cell_choice_editor.rb +46 -0
  159. data/lib/wx/doc/gen/grid/grid_cell_date_editor.rb +38 -0
  160. data/lib/wx/doc/gen/grid/grid_cell_date_renderer.rb +45 -0
  161. data/lib/wx/doc/gen/grid/grid_cell_date_time_renderer.rb +40 -0
  162. data/lib/wx/doc/gen/grid/grid_cell_editor.rb +197 -0
  163. data/lib/wx/doc/gen/grid/grid_cell_enum_editor.rb +39 -0
  164. data/lib/wx/doc/gen/grid/grid_cell_enum_renderer.rb +44 -0
  165. data/lib/wx/doc/gen/grid/grid_cell_float_editor.rb +45 -0
  166. data/lib/wx/doc/gen/grid/grid_cell_float_renderer.rb +79 -0
  167. data/lib/wx/doc/gen/grid/grid_cell_number_editor.rb +46 -0
  168. data/lib/wx/doc/gen/grid/grid_cell_number_renderer.rb +35 -0
  169. data/lib/wx/doc/gen/grid/grid_cell_renderer.rb +108 -0
  170. data/lib/wx/doc/gen/grid/grid_cell_string_renderer.rb +35 -0
  171. data/lib/wx/doc/gen/grid/grid_cell_text_editor.rb +49 -0
  172. data/lib/wx/doc/gen/grid/grid_ctrl.rb +3002 -0
  173. data/lib/wx/doc/gen/grid/grid_editor_created_event.rb +95 -0
  174. data/lib/wx/doc/gen/grid/grid_event.rb +129 -0
  175. data/lib/wx/doc/gen/grid/grid_range_select_event.rb +104 -0
  176. data/lib/wx/doc/gen/grid/grid_size_event.rb +85 -0
  177. data/lib/wx/doc/gen/grid/grid_string_table.rb +142 -0
  178. data/lib/wx/doc/gen/grid/grid_table_base.rb +317 -0
  179. data/lib/wx/doc/gen/grid/grid_table_message.rb +81 -0
  180. data/lib/wx/doc/gen/grid_bag_sizer.rb +323 -0
  181. data/lib/wx/doc/gen/grid_sizer.rb +195 -0
  182. data/lib/wx/doc/gen/gui_event_loop.rb +159 -0
  183. data/lib/wx/doc/gen/h_scrolled_window.rb +562 -0
  184. data/lib/wx/doc/gen/header_ctrl.rb +880 -0
  185. data/lib/wx/doc/gen/header_ctrl_event.rb +133 -0
  186. data/lib/wx/doc/gen/help_controller.rb +195 -0
  187. data/lib/wx/doc/gen/help_provider.rb +98 -0
  188. data/lib/wx/doc/gen/html/event_list.rb +38 -0
  189. data/lib/wx/doc/gen/html/html_cell.rb +536 -0
  190. data/lib/wx/doc/gen/html/html_cell_event.rb +69 -0
  191. data/lib/wx/doc/gen/html/html_data_object.rb +42 -0
  192. data/lib/wx/doc/gen/html/html_easy_printing.rb +203 -0
  193. data/lib/wx/doc/gen/html/html_help_controller.rb +340 -0
  194. data/lib/wx/doc/gen/html/html_help_data.rb +159 -0
  195. data/lib/wx/doc/gen/html/html_help_window.rb +258 -0
  196. data/lib/wx/doc/gen/html/html_link_event.rb +41 -0
  197. data/lib/wx/doc/gen/html/html_list_box.rb +346 -0
  198. data/lib/wx/doc/gen/html/html_printout.rb +109 -0
  199. data/lib/wx/doc/gen/html/html_window.rb +461 -0
  200. data/lib/wx/doc/gen/hyperlink_ctrl.rb +311 -0
  201. data/lib/wx/doc/gen/hyperlink_event.rb +44 -0
  202. data/lib/wx/doc/gen/icon.rb +267 -0
  203. data/lib/wx/doc/gen/icon_location.rb +40 -0
  204. data/lib/wx/doc/gen/image.rb +1371 -0
  205. data/lib/wx/doc/gen/image_list.rb +168 -0
  206. data/lib/wx/doc/gen/info_bar.rb +195 -0
  207. data/lib/wx/doc/gen/keyboard_state.rb +140 -0
  208. data/lib/wx/doc/gen/list_box.rb +304 -0
  209. data/lib/wx/doc/gen/list_ctrl.rb +1774 -0
  210. data/lib/wx/doc/gen/list_event.rb +208 -0
  211. data/lib/wx/doc/gen/listbook.rb +116 -0
  212. data/lib/wx/doc/gen/locale.rb +4293 -0
  213. data/lib/wx/doc/gen/log.rb +603 -0
  214. data/lib/wx/doc/gen/mdi_client_window.rb +47 -0
  215. data/lib/wx/doc/gen/mdi_frame.rb +324 -0
  216. data/lib/wx/doc/gen/media_ctrl.rb +269 -0
  217. data/lib/wx/doc/gen/media_event.rb +117 -0
  218. data/lib/wx/doc/gen/memory_dc.rb +174 -0
  219. data/lib/wx/doc/gen/menu.rb +509 -0
  220. data/lib/wx/doc/gen/menu_bar.rb +287 -0
  221. data/lib/wx/doc/gen/menu_item.rb +362 -0
  222. data/lib/wx/doc/gen/message_dialog.rb +238 -0
  223. data/lib/wx/doc/gen/mini_frame.rb +108 -0
  224. data/lib/wx/doc/gen/mirror_dc.rb +22 -0
  225. data/lib/wx/doc/gen/mouse_state.rb +150 -0
  226. data/lib/wx/doc/gen/multi_choice_dialog.rb +80 -0
  227. data/lib/wx/doc/gen/non_owned_window.rb +49 -0
  228. data/lib/wx/doc/gen/notebook.rb +278 -0
  229. data/lib/wx/doc/gen/num_validator.rb +37 -0
  230. data/lib/wx/doc/gen/number_entry_dialog.rb +93 -0
  231. data/lib/wx/doc/gen/object.rb +59 -0
  232. data/lib/wx/doc/gen/owner_drawn_combo_box.rb +395 -0
  233. data/lib/wx/doc/gen/paint_dc.rb +27 -0
  234. data/lib/wx/doc/gen/palette.rb +92 -0
  235. data/lib/wx/doc/gen/panel.rb +127 -0
  236. data/lib/wx/doc/gen/pen.rb +511 -0
  237. data/lib/wx/doc/gen/persistence_manager.rb +135 -0
  238. data/lib/wx/doc/gen/persistent_object.rb +52 -0
  239. data/lib/wx/doc/gen/persistent_window.rb +241 -0
  240. data/lib/wx/doc/gen/pg/event_list.rb +106 -0
  241. data/lib/wx/doc/gen/pg/numeric_property_validator.rb +54 -0
  242. data/lib/wx/doc/gen/pg/pg_array_editor_dialog.rb +292 -0
  243. data/lib/wx/doc/gen/pg/pg_cell.rb +177 -0
  244. data/lib/wx/doc/gen/pg/pg_editor.rb +721 -0
  245. data/lib/wx/doc/gen/pg/pg_multi_button.rb +152 -0
  246. data/lib/wx/doc/gen/pg/pg_properties.rb +2829 -0
  247. data/lib/wx/doc/gen/pg/pg_property.rb +2078 -0
  248. data/lib/wx/doc/gen/pg/pg_validation_info.rb +344 -0
  249. data/lib/wx/doc/gen/pg/property_grid.rb +740 -0
  250. data/lib/wx/doc/gen/pg/property_grid_event.rb +184 -0
  251. data/lib/wx/doc/gen/pg/property_grid_interface.rb +1098 -0
  252. data/lib/wx/doc/gen/pg/property_grid_manager.rb +415 -0
  253. data/lib/wx/doc/gen/pg/property_grid_page.rb +354 -0
  254. data/lib/wx/doc/gen/pg/property_grid_page_state.rb +165 -0
  255. data/lib/wx/doc/gen/picker_base.rb +152 -0
  256. data/lib/wx/doc/gen/platform_info.rb +622 -0
  257. data/lib/wx/doc/gen/popup_window.rb +107 -0
  258. data/lib/wx/doc/gen/progress_dialog.rb +100 -0
  259. data/lib/wx/doc/gen/property_sheet_dialog.rb +216 -0
  260. data/lib/wx/doc/gen/prt/event_list.rb +17 -0
  261. data/lib/wx/doc/gen/prt/page_setup_dialog.rb +44 -0
  262. data/lib/wx/doc/gen/prt/post_script_dc.rb +30 -0
  263. data/lib/wx/doc/gen/prt/preview_frame.rb +78 -0
  264. data/lib/wx/doc/gen/prt/print_abort_dialog.rb +151 -0
  265. data/lib/wx/doc/gen/prt/print_data.rb +804 -0
  266. data/lib/wx/doc/gen/prt/print_dialog.rb +55 -0
  267. data/lib/wx/doc/gen/prt/printer.rb +518 -0
  268. data/lib/wx/doc/gen/prt/printer_dc.rb +37 -0
  269. data/lib/wx/doc/gen/query_layout_info_event.rb +106 -0
  270. data/lib/wx/doc/gen/radio_box.rb +306 -0
  271. data/lib/wx/doc/gen/radio_button.rb +159 -0
  272. data/lib/wx/doc/gen/rbn/event_list.rb +136 -0
  273. data/lib/wx/doc/gen/rbn/ribbon_art_provider.rb +1132 -0
  274. data/lib/wx/doc/gen/rbn/ribbon_bar.rb +308 -0
  275. data/lib/wx/doc/gen/rbn/ribbon_bar_event.rb +45 -0
  276. data/lib/wx/doc/gen/rbn/ribbon_button_bar.rb +458 -0
  277. data/lib/wx/doc/gen/rbn/ribbon_button_bar_event.rb +63 -0
  278. data/lib/wx/doc/gen/rbn/ribbon_control.rb +143 -0
  279. data/lib/wx/doc/gen/rbn/ribbon_gallery.rb +229 -0
  280. data/lib/wx/doc/gen/rbn/ribbon_gallery_event.rb +55 -0
  281. data/lib/wx/doc/gen/rbn/ribbon_page.rb +174 -0
  282. data/lib/wx/doc/gen/rbn/ribbon_panel.rb +270 -0
  283. data/lib/wx/doc/gen/rbn/ribbon_panel_event.rb +45 -0
  284. data/lib/wx/doc/gen/rbn/ribbon_tool_bar.rb +360 -0
  285. data/lib/wx/doc/gen/rbn/ribbon_tool_bar_event.rb +42 -0
  286. data/lib/wx/doc/gen/rearrange_ctrl.rb +78 -0
  287. data/lib/wx/doc/gen/rearrange_list.rb +123 -0
  288. data/lib/wx/doc/gen/region.rb +380 -0
  289. data/lib/wx/doc/gen/region_iterator.rb +76 -0
  290. data/lib/wx/doc/gen/rich_tool_tip.rb +154 -0
  291. data/lib/wx/doc/gen/rtc/event_list.rb +125 -0
  292. data/lib/wx/doc/gen/rtc/rich_text_box.rb +445 -0
  293. data/lib/wx/doc/gen/rtc/rich_text_buffer.rb +1188 -0
  294. data/lib/wx/doc/gen/rtc/rich_text_buffer_data_object.rb +41 -0
  295. data/lib/wx/doc/gen/rtc/rich_text_composite_object.rb +538 -0
  296. data/lib/wx/doc/gen/rtc/rich_text_ctrl.rb +2103 -0
  297. data/lib/wx/doc/gen/rtc/rich_text_event.rb +173 -0
  298. data/lib/wx/doc/gen/rtc/rich_text_file_handler.rb +181 -0
  299. data/lib/wx/doc/gen/rtc/rich_text_formatting_dialog.rb +319 -0
  300. data/lib/wx/doc/gen/rtc/rich_text_header_footer_data.rb +193 -0
  301. data/lib/wx/doc/gen/rtc/rich_text_html_handler.rb +102 -0
  302. data/lib/wx/doc/gen/rtc/rich_text_image.rb +337 -0
  303. data/lib/wx/doc/gen/rtc/rich_text_object.rb +2922 -0
  304. data/lib/wx/doc/gen/rtc/rich_text_paragraph_layout_box.rb +1240 -0
  305. data/lib/wx/doc/gen/rtc/rich_text_printing.rb +258 -0
  306. data/lib/wx/doc/gen/rtc/rich_text_style_list_box.rb +344 -0
  307. data/lib/wx/doc/gen/rtc/rich_text_style_organiser_dialog.rb +227 -0
  308. data/lib/wx/doc/gen/rtc/rich_text_xml_handler.rb +59 -0
  309. data/lib/wx/doc/gen/rtc/symbol_picker_dialog.rb +169 -0
  310. data/lib/wx/doc/gen/sash_event.rb +147 -0
  311. data/lib/wx/doc/gen/sash_layout_window.rb +232 -0
  312. data/lib/wx/doc/gen/sash_window.rb +171 -0
  313. data/lib/wx/doc/gen/scaled_dc.rb +10 -0
  314. data/lib/wx/doc/gen/screen_dc.rb +30 -0
  315. data/lib/wx/doc/gen/scroll_bar.rb +204 -0
  316. data/lib/wx/doc/gen/scrolled_canvas.rb +410 -0
  317. data/lib/wx/doc/gen/scrolled_control.rb +410 -0
  318. data/lib/wx/doc/gen/scrolled_window.rb +430 -0
  319. data/lib/wx/doc/gen/search_ctrl.rb +159 -0
  320. data/lib/wx/doc/gen/secret_store.rb +116 -0
  321. data/lib/wx/doc/gen/simplebook.rb +110 -0
  322. data/lib/wx/doc/gen/single_choice_dialog.rb +89 -0
  323. data/lib/wx/doc/gen/sizer.rb +945 -0
  324. data/lib/wx/doc/gen/sizer_item.rb +244 -0
  325. data/lib/wx/doc/gen/slider.rb +342 -0
  326. data/lib/wx/doc/gen/spin_button.rb +157 -0
  327. data/lib/wx/doc/gen/spin_ctrl.rb +231 -0
  328. data/lib/wx/doc/gen/spin_ctrl_double.rb +192 -0
  329. data/lib/wx/doc/gen/spin_double_event.rb +55 -0
  330. data/lib/wx/doc/gen/spin_event.rb +51 -0
  331. data/lib/wx/doc/gen/splash_screen.rb +113 -0
  332. data/lib/wx/doc/gen/splitter_event.rb +99 -0
  333. data/lib/wx/doc/gen/splitter_window.rb +498 -0
  334. data/lib/wx/doc/gen/static_bitmap.rb +256 -0
  335. data/lib/wx/doc/gen/static_box.rb +180 -0
  336. data/lib/wx/doc/gen/static_box_sizer.rb +85 -0
  337. data/lib/wx/doc/gen/static_line.rb +83 -0
  338. data/lib/wx/doc/gen/static_text.rb +127 -0
  339. data/lib/wx/doc/gen/status_bar.rb +290 -0
  340. data/lib/wx/doc/gen/stc/event_list.rb +221 -0
  341. data/lib/wx/doc/gen/stc/styled_text_ctrl.rb +4474 -0
  342. data/lib/wx/doc/gen/stc/styled_text_event.rb +8762 -0
  343. data/lib/wx/doc/gen/std_dialog_button_sizer.rb +129 -0
  344. data/lib/wx/doc/gen/svg_file_dc.rb +164 -0
  345. data/lib/wx/doc/gen/system_options.rb +129 -0
  346. data/lib/wx/doc/gen/system_settings.rb +507 -0
  347. data/lib/wx/doc/gen/task_bar_icon.rb +127 -0
  348. data/lib/wx/doc/gen/task_bar_icon_event.rb +88 -0
  349. data/lib/wx/doc/gen/text_attr.rb +756 -0
  350. data/lib/wx/doc/gen/text_ctrl.rb +1033 -0
  351. data/lib/wx/doc/gen/text_entry.rb +441 -0
  352. data/lib/wx/doc/gen/text_entry_dialog.rb +220 -0
  353. data/lib/wx/doc/gen/text_validator.rb +245 -0
  354. data/lib/wx/doc/gen/time_picker_ctrl.rb +128 -0
  355. data/lib/wx/doc/gen/timer.rb +119 -0
  356. data/lib/wx/doc/gen/timer_event.rb +68 -0
  357. data/lib/wx/doc/gen/tip_provider.rb +63 -0
  358. data/lib/wx/doc/gen/tip_window.rb +51 -0
  359. data/lib/wx/doc/gen/toggle_button.rb +182 -0
  360. data/lib/wx/doc/gen/tool_bar.rb +890 -0
  361. data/lib/wx/doc/gen/tool_tip.rb +86 -0
  362. data/lib/wx/doc/gen/toolbook.rb +118 -0
  363. data/lib/wx/doc/gen/top_level_window.rb +497 -0
  364. data/lib/wx/doc/gen/tree_ctrl.rb +1052 -0
  365. data/lib/wx/doc/gen/tree_event.rb +127 -0
  366. data/lib/wx/doc/gen/treebook.rb +180 -0
  367. data/lib/wx/doc/gen/ui_action_simulator.rb +109 -0
  368. data/lib/wx/doc/gen/utils.rb +273 -0
  369. data/lib/wx/doc/gen/v_list_box.rb +272 -0
  370. data/lib/wx/doc/gen/v_scrolled_canvas.rb +195 -0
  371. data/lib/wx/doc/gen/v_scrolled_window.rb +191 -0
  372. data/lib/wx/doc/gen/validator.rb +68 -0
  373. data/lib/wx/doc/gen/variant.rb +294 -0
  374. data/lib/wx/doc/gen/window.rb +2917 -0
  375. data/lib/wx/doc/gen/window_dc.rb +38 -0
  376. data/lib/wx/doc/gen/window_disabler.rb +30 -0
  377. data/lib/wx/doc/gen/with_images.rb +84 -0
  378. data/lib/wx/doc/gen/wizard.rb +257 -0
  379. data/lib/wx/doc/gen/wizard_event.rb +113 -0
  380. data/lib/wx/doc/gen/wizard_page.rb +65 -0
  381. data/lib/wx/doc/gen/wizard_page_simple.rb +88 -0
  382. data/lib/wx/doc/gen/wrap_sizer.rb +79 -0
  383. data/lib/wx/doc/gen/xml_node.rb +316 -0
  384. data/lib/wx/doc/gen/xml_resource.rb +320 -0
  385. data/lib/wx/doc/generic_validator.rb +5 -0
  386. data/lib/wx/doc/tip_window.rb +18 -6
  387. data/lib/wx/grid/events/evt_list.rb +166 -0
  388. data/lib/wx/html/events/evt_list.rb +27 -0
  389. data/lib/wx/html/simple_html_listbox.rb +46 -33
  390. data/lib/wx/keyword_defs.rb +9 -0
  391. data/lib/wx/pg/events/evt_list.rb +73 -0
  392. data/lib/wx/pg/pg_property.rb +26 -0
  393. data/lib/wx/pg/property_grid_interface.rb +2 -2
  394. data/lib/wx/rbn/events/evt_list.rb +102 -0
  395. data/lib/wx/rtc/events/evt_list.rb +98 -0
  396. data/lib/wx/rtc/ext/rich_text_ctrl.rb +24 -0
  397. data/lib/wx/stc/events/evt_list.rb +178 -0
  398. data/lib/wx/version.rb +1 -1
  399. data/lib/wx/wxruby/cmd/setup.rb +6 -0
  400. data/rakelib/configure.rb +9 -0
  401. data/rakelib/gem.rake +3 -2
  402. data/rakelib/lib/config/linux.rb +1 -1
  403. data/rakelib/lib/config/macosx.rb +15 -1
  404. data/rakelib/lib/config/pkgman/linux.rb +7 -2
  405. data/rakelib/lib/config/unixish.rb +3 -3
  406. data/rakelib/lib/config.rb +16 -5
  407. data/rakelib/lib/core/include/swigdirector.inc +3 -3
  408. data/rakelib/lib/core/include/swigrubyerrors.inc +4 -8
  409. data/rakelib/lib/core/include/swigrubyrun.inc +20 -4
  410. data/rakelib/lib/core/include/swigrun.inc +189 -0
  411. data/rakelib/lib/core/package.rb +3 -1
  412. data/rakelib/lib/director/accelerator.rb +1 -1
  413. data/rakelib/lib/director/animation.rb +1 -0
  414. data/rakelib/lib/director/app_traits.rb +1 -1
  415. data/rakelib/lib/director/aui_manager.rb +21 -14
  416. data/rakelib/lib/director/aui_mdi_child_frame.rb +2 -0
  417. data/rakelib/lib/director/aui_mdi_parent_frame.rb +4 -0
  418. data/rakelib/lib/director/aui_notebook.rb +20 -3
  419. data/rakelib/lib/director/aui_tab_ctrl.rb +64 -106
  420. data/rakelib/lib/director/calendar_ctrl.rb +72 -14
  421. data/rakelib/lib/director/clipboard.rb +2 -0
  422. data/rakelib/lib/director/data_object.rb +15 -7
  423. data/rakelib/lib/director/date_picker_ctrl.rb +4 -1
  424. data/rakelib/lib/director/display.rb +81 -0
  425. data/rakelib/lib/director/event.rb +33 -16
  426. data/rakelib/lib/director/event_handler.rb +27 -2
  427. data/rakelib/lib/director/functions.rb +9 -0
  428. data/rakelib/lib/director/geometry.rb +5 -0
  429. data/rakelib/lib/director/grid_ctrl.rb +123 -28
  430. data/rakelib/lib/director/help_provider.rb +1 -1
  431. data/rakelib/lib/director/html_listbox.rb +16 -3
  432. data/rakelib/lib/director/hvscrolled.rb +7 -106
  433. data/rakelib/lib/director/image_list.rb +1 -0
  434. data/rakelib/lib/director/mdi_frame.rb +4 -0
  435. data/rakelib/lib/director/menu.rb +56 -15
  436. data/rakelib/lib/director/menu_bar.rb +62 -0
  437. data/rakelib/lib/director/menu_item.rb +7 -1
  438. data/rakelib/lib/director/num_validator.rb +27 -0
  439. data/rakelib/lib/director/numeric_property_validator.rb +9 -0
  440. data/rakelib/lib/director/popup_window.rb +2 -0
  441. data/rakelib/lib/director/preview_frame.rb +29 -6
  442. data/rakelib/lib/director/printer.rb +59 -5
  443. data/rakelib/lib/director/property_grid.rb +37 -18
  444. data/rakelib/lib/director/property_grid_interface.rb +10 -8
  445. data/rakelib/lib/director/property_grid_manager.rb +99 -39
  446. data/rakelib/lib/director/property_grid_page.rb +60 -0
  447. data/rakelib/lib/director/rich_tooltip.rb +22 -0
  448. data/rakelib/lib/director/richtext_ctrl.rb +5 -0
  449. data/rakelib/lib/director/richtext_object.rb +13 -4
  450. data/rakelib/lib/director/richtext_style_listbox.rb +4 -1
  451. data/rakelib/lib/director/scrolled_t.rb +3 -0
  452. data/rakelib/lib/director/searchctrl.rb +1 -0
  453. data/rakelib/lib/director/task_bar_icon.rb +14 -8
  454. data/rakelib/lib/director/text_validator.rb +9 -0
  455. data/rakelib/lib/director/tip_window.rb +117 -6
  456. data/rakelib/lib/director/tool_bar.rb +6 -0
  457. data/rakelib/lib/director/validator.rb +12 -0
  458. data/rakelib/lib/director/variant.rb +36 -20
  459. data/rakelib/lib/director/vlistbox.rb +25 -22
  460. data/rakelib/lib/director/window.rb +10 -1
  461. data/rakelib/lib/director/xml_resource.rb +6 -0
  462. data/rakelib/lib/generate/doc/aui_manager.yaml +1 -1
  463. data/rakelib/lib/generate/doc/rich_tool_tip.yaml +26 -0
  464. data/rakelib/lib/generate/doc.rb +12 -7
  465. data/rakelib/lib/generate/interface.rb +16 -1
  466. data/rakelib/lib/specs/interfaces.rb +3 -1
  467. data/rakelib/lib/swig_runner.rb +10 -10
  468. data/rakelib/lib/typemap/aui_tabctrl.rb +46 -0
  469. data/rakelib/lib/typemap/common.rb +3 -3
  470. data/rakelib/lib/typemap/print_page_range.rb +32 -8
  471. data/samples/art/wxruby-512x512.png +0 -0
  472. data/samples/calendar/calendar.rb +64 -1
  473. data/samples/dialogs/dialogs.rb +172 -0
  474. data/samples/dialogs/tip.xpm +157 -0
  475. data/samples/drawing/maths_images.rb +1 -1
  476. data/samples/event/event.rb +1 -1
  477. data/samples/printing/printing2.rb +1 -1
  478. data/samples/sampler.rb +26 -8
  479. data/samples/text/textctrl.rb +2 -2
  480. data/samples/treectrl/treectrl.rb +2 -2
  481. data/tests/lib/leaked_process_event_exception_test.rb +1 -1
  482. data/tests/lib/leaked_queued_event_exception_test.rb +1 -1
  483. data/tests/lib/wxapp_runner.rb +31 -41
  484. data/tests/lib/wxframe_runner.rb +23 -11
  485. data/tests/lib/wxrb_test.rb +58 -0
  486. data/tests/test_app_event_filter.rb +1 -1
  487. data/tests/test_app_exit_exception.rb +3 -3
  488. data/tests/test_app_init_exception.rb +3 -3
  489. data/tests/test_app_traits.rb +24 -21
  490. data/tests/test_art.rb +7 -7
  491. data/tests/test_art_provider.rb +1 -1
  492. data/tests/test_basic.rb +2 -2
  493. data/tests/test_book_controls.rb +1 -1
  494. data/tests/test_box_sizer.rb +1 -1
  495. data/tests/test_clipboard.rb +5 -5
  496. data/tests/test_combo_ctrl.rb +2 -2
  497. data/tests/test_config.rb +11 -1
  498. data/tests/test_dc.rb +1 -1
  499. data/tests/test_dialog.rb +1 -1
  500. data/tests/test_event_handling.rb +1 -1
  501. data/tests/test_events.rb +1 -1
  502. data/tests/test_exceptions.rb +2 -2
  503. data/tests/test_ext_controls.rb +10 -10
  504. data/tests/test_file_dialog.rb +1 -1
  505. data/tests/test_font.rb +1 -1
  506. data/tests/test_gdi_object.rb +1 -1
  507. data/tests/test_geometry.rb +2 -2
  508. data/tests/test_grid_sizer.rb +2 -2
  509. data/tests/test_intl.rb +1 -1
  510. data/tests/test_item_data.rb +12 -12
  511. data/tests/test_list_ctrl.rb +1 -1
  512. data/tests/test_log.rb +2 -2
  513. data/tests/test_media_ctrl.rb +1 -1
  514. data/tests/test_menu.rb +114 -43
  515. data/tests/test_proof_check.rb +1 -1
  516. data/tests/test_propgrid.rb +31 -31
  517. data/tests/test_richtext.rb +10 -24
  518. data/tests/test_secret_store.rb +1 -1
  519. data/tests/test_sizer.rb +1 -1
  520. data/tests/test_std_controls.rb +8 -8
  521. data/tests/test_styled_text_ctrl.rb +1 -1
  522. data/tests/test_timer.rb +1 -1
  523. data/tests/test_tree_ctrl.rb +1 -1
  524. data/tests/test_validators.rb +79 -36
  525. data/tests/test_variant.rb +1 -1
  526. data/tests/test_window.rb +11 -11
  527. data/tests/testapp.rb +2 -2
  528. data/tests/testapp_noframe.rb +2 -2
  529. metadata +400 -11
  530. data/lib/wx/aui/aui_tab_ctrl.rb +0 -18
@@ -0,0 +1,86 @@
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
8
+
9
+ # This class holds information about a tooltip associated with a window (see {Wx::Window#set_tool_tip}).
10
+ #
11
+ # The four static methods, {Wx::ToolTip.enable}, {Wx::ToolTip.set_delay} {Wx::ToolTip.set_auto_pop} and {Wx::ToolTip.set_reshow} can be used to globally alter tooltips behaviour.
12
+ #
13
+ # Category: {Wx::HELP}
14
+ #
15
+ # @wxrb_require USE_TOOLTIPS
16
+ class ToolTip < Object
17
+
18
+ # Constructor.
19
+ # @param tip [String]
20
+ # @return [Wx::ToolTip]
21
+ def initialize(tip) end
22
+
23
+ # Get the tooltip text.
24
+ # @return [String]
25
+ def get_tip; end
26
+ alias_method :tip, :get_tip
27
+
28
+ # Get the associated window.
29
+ # @return [Wx::Window]
30
+ def get_window; end
31
+ alias_method :window, :get_window
32
+
33
+ # Set the tooltip text.
34
+ # @param tip [String]
35
+ # @return [void]
36
+ def set_tip(tip) end
37
+ alias_method :tip=, :set_tip
38
+
39
+ # Enable or disable tooltips globally.
40
+ #
41
+ # <div class="wxrb-note">
42
+ # <b>Note:</b>
43
+ # <p>May not be supported on all platforms (eg. {Wx::Cocoa}).
44
+ # </p>
45
+ # </div>
46
+ # @param flag [Boolean]
47
+ # @return [void]
48
+ def self.enable(flag) end
49
+
50
+ # Set the delay after which the tooltip disappears or how long a tooltip remains visible.
51
+ #
52
+ # <div class="wxrb-note">
53
+ # <b>Note:</b>
54
+ # <p>May not be supported on all platforms (eg. {Wx::Cocoa}, GTK).
55
+ # </p>
56
+ # </div>
57
+ # @param msecs [Integer]
58
+ # @return [void]
59
+ def self.set_auto_pop(msecs) end
60
+
61
+ # Set the delay after which the tooltip appears.
62
+ #
63
+ # <div class="wxrb-note">
64
+ # <b>Note:</b>
65
+ # <p>May not be supported on all platforms.
66
+ # </p>
67
+ # </div>
68
+ # @param msecs [Integer]
69
+ # @return [void]
70
+ def self.set_delay(msecs) end
71
+
72
+ # Set the delay between subsequent tooltips to appear.
73
+ #
74
+ # <div class="wxrb-note">
75
+ # <b>Note:</b>
76
+ # <p>May not be supported on all platforms (eg. {Wx::Cocoa}, GTK).
77
+ # </p>
78
+ # </div>
79
+ # @param msecs [Integer]
80
+ # @return [void]
81
+ def self.set_reshow(msecs) end
82
+
83
+ end # ToolTip
84
+
85
+
86
+ end
@@ -0,0 +1,118 @@
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
8
+
9
+ #
10
+ TBK_BUTTONBAR = 256
11
+
12
+ #
13
+ TBK_HORZ_LAYOUT = 32768
14
+
15
+ #
16
+ #
17
+ EVT_TOOLBOOK_PAGE_CHANGED = 10244
18
+
19
+ #
20
+ #
21
+ EVT_TOOLBOOK_PAGE_CHANGING = 10243
22
+
23
+ # {Wx::Toolbook} is a class similar to {Wx::Notebook} but which uses a {Wx::ToolBar} to show the labels instead of the tabs.
24
+ #
25
+ # There is no documentation for this class yet but its usage is identical to {Wx::Notebook} (except for the features clearly related to tabs only), so please refer to that class documentation for now. You can also use the page_samples_notebook to see {Wx::Toolbook} in action.
26
+ # One feature of this class not supported by {Wx::BookCtrlBase} is the support for disabling some of the pages, see {Wx::Toolbook#enable_page}.
27
+ # ### Styles
28
+ #
29
+ # This class supports the following styles:
30
+ #
31
+ # - {Wx::TBK_BUTTONBAR}: Use {Wx::ButtonToolBar}-based implementation under macOS (ignored under other platforms).
32
+ #
33
+ # - {Wx::TBK_HORZ_LAYOUT}: Shows the text and the icons alongside, not vertically stacked (only implement under Windows and GTK 2 platforms as it relies on {Wx::TB_HORZ_LAYOUT} flag support).
34
+ #
35
+ # The common {Wx::BookCtrl} styles described in the wxBookCtrl Overview are also supported.
36
+ # ### Events emitted by this class
37
+ #
38
+ # The following event-handler methods redirect the events to member method or handler blocks for {Wx::BookCtrlEvent} events.
39
+ # Event handler methods for events emitted by this class:
40
+ #
41
+ # - {Wx::EvtHandler#evt_toolbook_page_changed}(id, meth = nil, &block): The page selection was changed. Processes a {Wx::EVT_TOOLBOOK_PAGE_CHANGED} event.
42
+ #
43
+ # - {Wx::EvtHandler#evt_toolbook_page_changing}(id, meth = nil, &block): The page selection is about to be changed. Processes a {Wx::EVT_TOOLBOOK_PAGE_CHANGING} event. This event can be vetoed (using {Wx::NotifyEvent#veto}).
44
+ #
45
+ # Category: Book Controls
46
+ # @see wxBookCtrl Overview
47
+ # @see Wx::BookCtrlBase
48
+ # @see Wx::Notebook
49
+ # @see page_samples_notebook
50
+ #
51
+ #
52
+ # @wxrb_require USE_TOOLBOOK
53
+ class Toolbook < BookCtrlBase
54
+
55
+ # @overload initialize()
56
+ # Constructs a choicebook control.
57
+ # @return [Wx::Toolbook]
58
+ # @overload initialize(parent, id, pos=Wx::DEFAULT_POSITION, size=Wx::DEFAULT_SIZE, style=0, name=(''))
59
+ # Constructs a choicebook control.
60
+ # @param parent [Wx::Window]
61
+ # @param id [Integer]
62
+ # @param pos [Array(Integer, Integer), Wx::Point]
63
+ # @param size [Array(Integer, Integer), Wx::Size]
64
+ # @param style [Integer]
65
+ # @param name [String]
66
+ # @return [Wx::Toolbook]
67
+ # @overload initialize(parent, id, pos=Wx::DEFAULT_POSITION, size=Wx::DEFAULT_SIZE, style=0, name=(''), &block)
68
+ # Constructs a choicebook control.
69
+ # @param parent [Wx::Window]
70
+ # @param id [Integer]
71
+ # @param pos [Array(Integer, Integer), Wx::Point]
72
+ # @param size [Array(Integer, Integer), Wx::Size]
73
+ # @param style [Integer]
74
+ # @param name [String]
75
+ # @yieldparam [Wx::Toolbook] win new instance
76
+ # @return [Wx::Toolbook]
77
+ def initialize(*args) end
78
+
79
+ # Create the tool book control that has already been constructed with the default constructor.
80
+ # @param parent [Wx::Window]
81
+ # @param id [Integer]
82
+ # @param pos [Array(Integer, Integer), Wx::Point]
83
+ # @param size [Array(Integer, Integer), Wx::Size]
84
+ # @param style [Integer]
85
+ # @param name [String]
86
+ # @return [Boolean]
87
+ def create(parent, id, pos=Wx::DEFAULT_POSITION, size=Wx::DEFAULT_SIZE, style=0, name=('')) end
88
+
89
+ # Returns the {Wx::ToolBarBase} associated with the control.
90
+ # @return [Wx::ToolBar]
91
+ def get_tool_bar; end
92
+ alias_method :tool_bar, :get_tool_bar
93
+
94
+ # @overload enable_page(page, enable)
95
+ # Enables or disables the specified page.
96
+ #
97
+ # Using this function, a page can be disabled when it can't be used, while still remaining present to let the users know that more functionality is available, even if currently inaccessible.
98
+ # Icons for disabled pages are created by {Wx::Bitmap#convert_to_disabled}.
99
+ #
100
+ # true if successful, false otherwise (currently only if the index is invalid).
101
+ # @param page [Integer] The index of the page.
102
+ # @param enable [Boolean] true to enable the page and false to disable it.
103
+ # @return [Boolean]
104
+ # @overload enable_page(page, enable)
105
+ # Enables or disables the specified page.
106
+ #
107
+ # This is similar to the overload above, but finds the index of the specified page.
108
+ #
109
+ # true if successful, false otherwise, e.g. if page is not one of the pages of this control.
110
+ # @param page [Wx::Window] Pointer of a page windows inside the book control.
111
+ # @param enable [Boolean] true to enable the page and false to disable it.
112
+ # @return [Boolean]
113
+ def enable_page(*args) end
114
+
115
+ end # Toolbook
116
+
117
+
118
+ end
@@ -0,0 +1,497 @@
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
8
+
9
+ #
10
+ DEFAULT_FRAME_STYLE = 541072960
11
+
12
+ # Requests user attention,.
13
+ #
14
+ USER_ATTENTION_INFO = 1
15
+
16
+ # Results in a more drastic action.
17
+ #
18
+ USER_ATTENTION_ERROR = 2
19
+
20
+ #
21
+ #
22
+ #
23
+ #
24
+ class ContentProtection < Wx::Enum
25
+
26
+ # Window contents are visible in screen captures.
27
+ #
28
+ CONTENT_PROTECTION_NONE = Wx::ContentProtection.new(0)
29
+
30
+ # Window contents are not visible in screen captures.
31
+ #
32
+ CONTENT_PROTECTION_ENABLED = Wx::ContentProtection.new(1)
33
+
34
+ end # ContentProtection
35
+
36
+ # Don't display the menu bar.
37
+ #
38
+ FULLSCREEN_NOMENUBAR = 1
39
+
40
+ # Don't display toolbar bars.
41
+ #
42
+ FULLSCREEN_NOTOOLBAR = 2
43
+
44
+ # Don't display the status bar.
45
+ #
46
+ FULLSCREEN_NOSTATUSBAR = 4
47
+
48
+ # Don't display any border.
49
+ #
50
+ FULLSCREEN_NOBORDER = 8
51
+
52
+ # Don't display a caption.
53
+ #
54
+ FULLSCREEN_NOCAPTION = 16
55
+
56
+ # Combination of all above, will display the least possible.
57
+ #
58
+ FULLSCREEN_ALL = 31
59
+
60
+ # Possible parameters for {Wx::Frame#set_window_modality}.
61
+ #
62
+ #
63
+ #
64
+ class WindowMode < Wx::Enum
65
+
66
+ # Show the frame non-modally, and this is the default.
67
+ #
68
+ Normal = Wx::WindowMode.new(0)
69
+
70
+ # Disable only the parent window while the frame is shown.
71
+ #
72
+ WindowModal = Wx::WindowMode.new(1)
73
+
74
+ # Disable all the other TLWs while the frame is shown.
75
+ #
76
+ AppModal = Wx::WindowMode.new(2)
77
+
78
+ end # WindowMode
79
+
80
+ # {Wx::TopLevelWindow} is a common base class for {Wx::Dialog} and {Wx::Frame}.
81
+ #
82
+ # It is an abstract base class meaning that you never work with objects of this class directly, but all of its methods are also applicable for the two classes above.
83
+ # Note that the instances of {Wx::TopLevelWindow} are managed by wxWidgets in the internal top level window list.
84
+ # ### Events emitted by this class
85
+ #
86
+ # Event handler methods for events emitted by this class:
87
+ #
88
+ # - {Wx::EvtHandler#evt_maximize}(meth = nil, &block): Process a {Wx::EVT_MAXIMIZE} event. See {Wx::MaximizeEvent}.
89
+ #
90
+ # - {Wx::EvtHandler#evt_move}(meth = nil, &block): Process a {Wx::EVT_MOVE} event, which is generated when a window is moved. See {Wx::MoveEvent}.
91
+ #
92
+ # - {Wx::EvtHandler#evt_move_start}(meth = nil, &block): Process a {Wx::EVT_MOVE_START} event, which is generated when the user starts to move or size a window. WXMSW only. See {Wx::MoveEvent}.
93
+ #
94
+ # - {Wx::EvtHandler#evt_move_end}(meth = nil, &block): Process a {Wx::EVT_MOVE_END} event, which is generated when the user stops moving or sizing a window. WXMSW only. See {Wx::MoveEvent}.
95
+ #
96
+ # - {Wx::EvtHandler#evt_show}(meth = nil, &block): Process a {Wx::EVT_SHOW} event. See {Wx::ShowEvent}.
97
+ #
98
+ # - {Wx::EvtHandler#evt_fullscreen}(meth = nil, &block): Process a {Wx::EVT_FULLSCREEN} event. See {Wx::FullScreenEvent}.
99
+ #
100
+ # Category: Managed Windows
101
+ # @see Wx::Dialog
102
+ # @see Wx::Frame
103
+ #
104
+ #
105
+ class TopLevelWindow < NonOwnedWindow
106
+
107
+ # @overload initialize()
108
+ # Default ctor.
109
+ # @return [Wx::TopLevelWindow]
110
+ # @overload initialize(parent, id, title, pos=Wx::DEFAULT_POSITION, size=Wx::DEFAULT_SIZE, style=Wx::DEFAULT_FRAME_STYLE, name=Wx::FRAME_NAME_STR)
111
+ # Constructor creating the top level window.
112
+ # @param parent [Wx::Window]
113
+ # @param id [Integer]
114
+ # @param title [String]
115
+ # @param pos [Array(Integer, Integer), Wx::Point]
116
+ # @param size [Array(Integer, Integer), Wx::Size]
117
+ # @param style [Integer]
118
+ # @param name [String]
119
+ # @return [Wx::TopLevelWindow]
120
+ def initialize(*args) end
121
+
122
+ # Creates the top level window.
123
+ # @param parent [Wx::Window]
124
+ # @param id [Integer]
125
+ # @param title [String]
126
+ # @param pos [Array(Integer, Integer), Wx::Point]
127
+ # @param size [Array(Integer, Integer), Wx::Size]
128
+ # @param style [Integer]
129
+ # @param name [String]
130
+ # @return [Boolean]
131
+ def create(parent, id, title, pos=Wx::DEFAULT_POSITION, size=Wx::DEFAULT_SIZE, style=Wx::DEFAULT_FRAME_STYLE, name=Wx::FRAME_NAME_STR) end
132
+
133
+ # Returns true if the platform supports making the window translucent.
134
+ #
135
+ #
136
+ # @see Wx::TopLevelWindow#set_transparent
137
+ # @return [Boolean]
138
+ def can_set_transparent; end
139
+ alias_method :can_set_transparent?, :can_set_transparent
140
+
141
+ # A synonym for {Wx::TopLevelWindow#centre_on_screen}.
142
+ # @param direction [Integer]
143
+ # @return [void]
144
+ def center_on_screen(direction=Wx::Orientation::BOTH) end
145
+
146
+ # Centres the window on screen.
147
+ #
148
+ #
149
+ # @see Wx::Window#centre_on_parent
150
+ # @param direction [Integer] Specifies the direction for the centering. May be {Wx::Orientation::HORIZONTAL}, {Wx::Orientation::VERTICAL} or {Wx::Orientation::BOTH}.
151
+ # @return [void]
152
+ def centre_on_screen(direction=Wx::Orientation::BOTH) end
153
+
154
+ # Enables or disables the Close button (most often in the right upper corner of a dialog) and the Close entry of the system menu (most often in the left upper corner of the dialog).
155
+ #
156
+ # Returns true if operation was successful. This may be wrong on X11 (including GTK+) where the window manager may not support this operation and there is no way to find out.
157
+ # @param enable [Boolean]
158
+ # @return [Boolean]
159
+ def enable_close_button(enable=true) end
160
+
161
+ # Enables or disables the Maximize button (in the right or left upper corner of a frame or dialog).
162
+ #
163
+ # Currently only implemented for WXMSW and WXOSX.
164
+ # The window style must contain {Wx::MAXIMIZE_BOX}.
165
+ # Returns true if operation was successful. Note that a successful operation does not change the window style flags.
166
+ # @param enable [Boolean]
167
+ # @return [Boolean]
168
+ def enable_maximize_button(enable=true) end
169
+
170
+ # Enables or disables the Minimize button (in the right or left upper corner of a frame or dialog).
171
+ #
172
+ # Currently only implemented for WXMSW and WXOSX.
173
+ # The window style must contain {Wx::MINIMIZE_BOX}.
174
+ # Note that in WXMSW a successful operation will change the window style flags.
175
+ # Returns true if operation was successful. Note that a successful operation does not change the window style flags.
176
+ # @param enable [Boolean]
177
+ # @return [Boolean]
178
+ def enable_minimize_button(enable=true) end
179
+
180
+ # Returns a pointer to the button which is the default for this window, or nil.
181
+ #
182
+ # The default button is the one activated by pressing the Enter key.
183
+ # @return [Wx::Window]
184
+ def get_default_item; end
185
+ alias_method :default_item, :get_default_item
186
+
187
+ # Returns the standard icon of the window.
188
+ #
189
+ # The icon will be invalid if it hadn't been previously set by {Wx::TopLevelWindow#set_icon}.
190
+ # @see Wx::TopLevelWindow#get_icons
191
+ # @return [Wx::Icon]
192
+ def get_icon; end
193
+ alias_method :icon, :get_icon
194
+
195
+ # Returns all icons associated with the window, there will be none of them if neither {Wx::TopLevelWindow#set_icon} nor {Wx::TopLevelWindow#set_icons} had been called before.
196
+ #
197
+ # Use {Wx::TopLevelWindow#get_icon} to get the main icon of the window.
198
+ # @see Wx::IconBundle
199
+ # @return [Wx::IconBundle]
200
+ def get_icons; end
201
+ alias_method :icons, :get_icons
202
+
203
+ # Get the window title.
204
+ #
205
+ # This base class function is overridden in this class to behave as {Wx::TopLevelWindow#get_title} and is useful when having only a <code>wxWindow*</code> pointer.
206
+ # Please call {Wx::TopLevelWindow#get_title} directly instead of this function for clarity if possible.
207
+ # @return [String]
208
+ def get_label; end
209
+ alias_method :label, :get_label
210
+
211
+ # Gets a string containing the window title.
212
+ #
213
+ #
214
+ # @see Wx::TopLevelWindow#set_title
215
+ # @return [String]
216
+ def get_title; end
217
+ alias_method :title, :get_title
218
+
219
+ # Iconizes or restores the window.
220
+ #
221
+ # Note that in WXGTK the change to the window state is not immediate, i.e. {Wx::TopLevelWindow#is_iconized} will typically return false right after a call to {Wx::TopLevelWindow#iconize} and its return value will only change after the control flow returns to the event loop and the notification about the window being really iconized is received.
222
+ # @see Wx::TopLevelWindow#is_iconized
223
+ # @see Wx::TopLevelWindow#restore
224
+ # @see Wx::IconizeEvent.
225
+ # @param iconize [Boolean] If true, iconizes the window; if false, shows and restores it.
226
+ # @return [void]
227
+ def iconize(iconize=true) end
228
+
229
+ # Returns true if this window is currently active, i.e. if the user is currently working with it.
230
+ # @return [Boolean]
231
+ def is_active; end
232
+ alias_method :active?, :is_active
233
+
234
+ # Returns true if this window is expected to be always maximized, either due to platform policy or due to local policy regarding particular class.
235
+ # @return [Boolean]
236
+ def is_always_maximized; end
237
+ alias_method :always_maximized?, :is_always_maximized
238
+
239
+ # Returns true if the window is in fullscreen mode.
240
+ #
241
+ #
242
+ # @see Wx::TopLevelWindow#show_full_screen
243
+ # @return [Boolean]
244
+ def is_full_screen; end
245
+ alias_method :full_screen?, :is_full_screen
246
+
247
+ # Returns true if the window is iconized.
248
+ # @return [Boolean]
249
+ def is_iconized; end
250
+ alias_method :iconized?, :is_iconized
251
+
252
+ # Returns true if the window is maximized.
253
+ # @return [Boolean]
254
+ def is_maximized; end
255
+ alias_method :maximized?, :is_maximized
256
+
257
+ # Lays out the children using the window sizer or resizes the only child of the window to cover its entire area.
258
+ #
259
+ # This class overrides the base class {Wx::TopLevelWindow#layout} method to check if this window contains exactly one child which is commonly the case, with {Wx::Panel} being often created as the only child of {Wx::TopLevelWindow} and, if this is the case, resizes this child window to cover the entire client area.
260
+ # Note that if you associate a sizer with this window, the sizer takes precedence and the only-child-resizing is only used as fallback.
261
+ # false if nothing was done because the window has neither a sizer nor a single child, true otherwise.
262
+ # @return [Boolean]
263
+ def layout; end
264
+
265
+ # Maximizes or restores the window.
266
+ #
267
+ # Note that, just as with {Wx::TopLevelWindow#iconize}, the change to the window state is not immediate in at least WXGTK port.
268
+ # @see Wx::TopLevelWindow#restore
269
+ # @see Wx::TopLevelWindow#iconize
270
+ # @param maximize [Boolean] If true, maximizes the window, otherwise it restores it.
271
+ # @return [void]
272
+ def maximize(maximize=true) end
273
+
274
+ # Use a system-dependent way to attract users attention to the window when it is in background.
275
+ #
276
+ # flags may have the value of either {Wx::USER_ATTENTION_INFO} (default) or {Wx::USER_ATTENTION_ERROR} which results in a more drastic action. When in doubt, use the default value.
277
+ #
278
+ # <div class="wxrb-note">
279
+ # <b>Note:</b>
280
+ # <p>This function should normally be only used when the application is not already in foreground.
281
+ # </p>
282
+ # </div>
283
+ #
284
+ # This function is currently implemented for Win32 where it flashes the window icon in the taskbar, and for WXGTK with task bars supporting it.
285
+ # @param flags [Integer]
286
+ # @return [void]
287
+ def request_user_attention(flags=Wx::USER_ATTENTION_INFO) end
288
+
289
+ # Restore a previously iconized or maximized window to its normal state.
290
+ #
291
+ # In WXGTK this method currently doesn't return the maximized window to its normal state and you must use {Wx::TopLevelWindow#maximize} with false argument explicitly for this. In the other ports, it both unmaximizes the maximized windows and uniconizes the iconized ones.
292
+ # @see Wx::TopLevelWindow#iconize
293
+ # @see Wx::TopLevelWindow#maximize
294
+ # @return [void]
295
+ def restore; end
296
+
297
+ # Changes the default item for the panel, usually win is a button.
298
+ #
299
+ #
300
+ # @see Wx::TopLevelWindow#get_default_item
301
+ # @param win [Wx::Window]
302
+ # @return [Wx::Window]
303
+ def set_default_item(win) end
304
+ alias_method :default_item=, :set_default_item
305
+
306
+ # @param win [Wx::Window]
307
+ # @return [Wx::Window]
308
+ def set_tmp_default_item(win) end
309
+ alias_method :tmp_default_item=, :set_tmp_default_item
310
+
311
+ # @return [Wx::Window]
312
+ def get_tmp_default_item; end
313
+ alias_method :tmp_default_item, :get_tmp_default_item
314
+
315
+ # Sets the icon for this window.
316
+ #
317
+ # <div class="wxrb-remark">
318
+ # <b>Remark:</b>
319
+ # <p>The window takes a 'copy' of icon, but since it uses reference counting, the copy is very quick. It is safe to delete icon after calling this function.
320
+ # </p>
321
+ # </div>
322
+ #
323
+ # <div class="wxrb-note">
324
+ # <b>Note:</b>
325
+ # <p>In WXMSW, icon must be either 16x16 or 32x32 icon.
326
+ # </p>
327
+ # </div>
328
+ #
329
+ # <div class="wxrb-note">
330
+ # <b>Note:</b>
331
+ # <p>In WXGTK this function currently doesn't do anything when using Wayland, which doesn't allow setting the icon for a window. Please create a .desktop file for your application to set the icon for its windows.
332
+ # </p>
333
+ # </div>
334
+ # @see Wx::Icon
335
+ # @see Wx::TopLevelWindow#set_icons
336
+ # @param icon [Wx::Icon] The {Wx::Icon} to associate with this window.
337
+ # @return [void]
338
+ def set_icon(icon) end
339
+ alias_method :icon=, :set_icon
340
+
341
+ # Sets several icons of different sizes for this window: this allows using different icons for different situations (e.g.
342
+ #
343
+ # task switching bar, taskbar, window title bar) instead of scaling, with possibly bad looking results, the only icon set by {Wx::TopLevelWindow#set_icon}.
344
+ #
345
+ # <div class="wxrb-note">
346
+ # <b>Note:</b>
347
+ # <p>In WXMSW, icons must contain a 16x16 or 32x32 icon, preferably both.
348
+ # </p>
349
+ # </div>
350
+ #
351
+ # <div class="wxrb-note">
352
+ # <b>Note:</b>
353
+ # <p>In WXGTK this function currently doesn't do anything when using Wayland, which doesn't allow setting the icon for a window. Please create a .desktop file for your application to set the icon for its windows.
354
+ # </p>
355
+ # </div>
356
+ # @see Wx::IconBundle
357
+ # @param icons [Wx::IconBundle] The icons to associate with this window.
358
+ # @return [void]
359
+ def set_icons(icons) end
360
+ alias_method :icons=, :set_icons
361
+
362
+ # A simpler interface for setting the size hints than {Wx::TopLevelWindow#set_size_hints}.
363
+ # @param size [Array(Integer, Integer), Wx::Size]
364
+ # @return [void]
365
+ def set_max_size(size) end
366
+ alias_method :max_size=, :set_max_size
367
+
368
+ # A simpler interface for setting the size hints than {Wx::TopLevelWindow#set_size_hints}.
369
+ # @param size [Array(Integer, Integer), Wx::Size]
370
+ # @return [void]
371
+ def set_min_size(size) end
372
+ alias_method :min_size=, :set_min_size
373
+
374
+ # @overload set_size_hints(minW, minH, maxW=-1, maxH=-1, incW=-1, incH=-1)
375
+ # Allows specification of minimum and maximum window sizes, and window size increments.
376
+ #
377
+ # If a pair of values is not set (or set to -1), no constraints will be used.
378
+ #
379
+ # <div class="wxrb-remark">
380
+ # <b>Remark:</b>
381
+ # <p>Notice that this function not only prevents the user from resizing the window outside the given bounds but it also prevents the program itself from doing it using {Wx::Window#set_size}.
382
+ # </p>
383
+ # </div>
384
+ # @param minW [Integer] The minimum width.
385
+ # @param minH [Integer] The minimum height.
386
+ # @param maxW [Integer] The maximum width.
387
+ # @param maxH [Integer] The maximum height.
388
+ # @param incW [Integer] Specifies the increment for sizing the width (GTK/X11 only).
389
+ # @param incH [Integer] Specifies the increment for sizing the height (GTK/X11 only).
390
+ # @return [void]
391
+ # @overload set_size_hints(minSize, maxSize=Wx::DEFAULT_SIZE, incSize=Wx::DEFAULT_SIZE)
392
+ # Allows specification of minimum and maximum window sizes, and window size increments.
393
+ #
394
+ # If a pair of values is not set (or set to -1), no constraints will be used.
395
+ #
396
+ # <div class="wxrb-remark">
397
+ # <b>Remark:</b>
398
+ # <p>Notice that this function not only prevents the user from resizing the window outside the given bounds but it also prevents the program itself from doing it using {Wx::Window#set_size}.
399
+ # </p>
400
+ # </div>
401
+ # @param minSize [Array(Integer, Integer), Wx::Size] The minimum size of the window.
402
+ # @param maxSize [Array(Integer, Integer), Wx::Size] The maximum size of the window.
403
+ # @param incSize [Array(Integer, Integer), Wx::Size] Increment size (only taken into account under X11-based ports such as WXGTK and WXX11).
404
+ # @return [void]
405
+ def set_size_hints(*args) end
406
+ alias_method :size_hints=, :set_size_hints
407
+
408
+ # Sets the window title.
409
+ #
410
+ # This base class function is overridden in this class to behave as {Wx::TopLevelWindow#set_title} and is useful when having only a <code>wxWindow*</code> pointer.
411
+ # Please call {Wx::TopLevelWindow#set_title} directly instead of this function for clarity if possible.
412
+ # @param title [String] The window title.
413
+ # @return [void]
414
+ def set_label(title) end
415
+ alias_method :label=, :set_label
416
+
417
+ # Sets the window title.
418
+ #
419
+ #
420
+ # @see Wx::TopLevelWindow#get_title
421
+ # @param title [String] The window title.
422
+ # @return [void]
423
+ def set_title(title) end
424
+ alias_method :title=, :set_title
425
+
426
+ # If the platform supports it will set the window to be translucent.
427
+ #
428
+ # Note that in WXGTK this function must be called before the window is shown the first time it's called (but it can be called again after showing the window too).
429
+ # See the shaped sample for an example of using this function.
430
+ # @param alpha [Integer] Determines how opaque or transparent the window will be, if the platform supports the operation. A value of 0 sets the window to be fully transparent, and a value of 255 sets the window to be fully opaque.
431
+ # @return [Boolean]
432
+ def set_transparent(alpha) end
433
+ alias_method :transparent=, :set_transparent
434
+
435
+ # This virtual function is not meant to be called directly but can be overridden to return false (it returns true by default) to allow the application to close even if this, presumably not very important, window is still opened.
436
+ #
437
+ # By default, the application stays alive as long as there are any open top level windows.
438
+ # @return [Boolean]
439
+ def should_prevent_app_exit; end
440
+
441
+ # Sets the file name represented by this {Wx::TopLevelWindow}.
442
+ #
443
+ # Under macOS, this file name is used to set the "proxy icon", which appears in the window title bar near its title, corresponding to this file name. Under other platforms it currently doesn't do anything but it is harmless to call it now and it might be implemented to do something useful in the future so you're encouraged to use it for any window representing a file-based document.
444
+ # @param filename [String]
445
+ # @return [void]
446
+ def set_represented_filename(filename) end
447
+ alias_method :represented_filename=, :set_represented_filename
448
+
449
+ # Show the {Wx::TopLevelWindow}, but do not give it keyboard focus.
450
+ #
451
+ # This can be used for pop up or notification windows that should not steal the current focus.
452
+ # @return [void]
453
+ def show_without_activating; end
454
+
455
+ # Depending on the value of show parameter the window is either shown full screen or restored to its normal state.
456
+ #
457
+ # style is a bit list containing some or all of the following values, which indicate what elements of the window to hide in full-screen mode:
458
+ #
459
+ # - {Wx::FULLSCREEN_NOMENUBAR}
460
+ # - {Wx::FULLSCREEN_NOTOOLBAR}
461
+ # - {Wx::FULLSCREEN_NOSTATUSBAR}
462
+ # - {Wx::FULLSCREEN_NOBORDER}
463
+ # - {Wx::FULLSCREEN_NOCAPTION}
464
+ # - {Wx::FULLSCREEN_ALL} (all of the above)
465
+ #
466
+ # This function has not been tested with MDI frames.
467
+ #
468
+ # <div class="wxrb-note">
469
+ # <b>Note:</b>
470
+ # <p>Showing a window full screen also actually {Wx::TopLevelWindow#show}s the window if it isn't shown.
471
+ # </p>
472
+ # </div>
473
+ # @see Wx::TopLevelWindow#enable_full_screen_view
474
+ # @see Wx::TopLevelWindow#is_full_screen
475
+ # @param show [Boolean]
476
+ # @param style [Integer]
477
+ # @return [Boolean]
478
+ def show_full_screen(show, style=Wx::FULLSCREEN_ALL) end
479
+
480
+ # Get the current content protection of the window.
481
+ #
482
+ #
483
+ # @see Wx::TopLevelWindow#set_content_protection
484
+ # @return [Wx::ContentProtection]
485
+ def get_content_protection; end
486
+ alias_method :content_protection, :get_content_protection
487
+
488
+ # Get the default size for a new top level window.
489
+ #
490
+ # This is used internally by wxWidgets on some platforms to determine the default size for a window created using {Wx::DEFAULT_SIZE} so it is not necessary to use it when creating a {Wx::TopLevelWindow}, however it may be useful if a rough estimation of the window size is needed for some other reason.
491
+ # @return [Wx::Size]
492
+ def self.get_default_size; end
493
+
494
+ end # TopLevelWindow
495
+
496
+
497
+ end