fxruby 1.6.19-x86-mingw32

Sign up to get free protection for your applications and to get access to all the features.
Files changed (497) hide show
  1. data/LICENSE +456 -0
  2. data/README +39 -0
  3. data/doc/apes02.html +21 -0
  4. data/doc/apes03.html +39 -0
  5. data/doc/book.html +3 -0
  6. data/doc/build.html +132 -0
  7. data/doc/ch03s02.html +23 -0
  8. data/doc/ch03s03.html +52 -0
  9. data/doc/ch03s04.html +36 -0
  10. data/doc/ch03s05.html +60 -0
  11. data/doc/ch04s02.html +71 -0
  12. data/doc/ch04s03.html +37 -0
  13. data/doc/ch04s04.html +72 -0
  14. data/doc/ch05s02.html +260 -0
  15. data/doc/ch05s03.html +127 -0
  16. data/doc/changes.html +777 -0
  17. data/doc/clipboardtut.html +67 -0
  18. data/doc/differences.html +190 -0
  19. data/doc/dragdroptut.html +263 -0
  20. data/doc/events.html +36 -0
  21. data/doc/examples.html +104 -0
  22. data/doc/gems.html +73 -0
  23. data/doc/goals.html +41 -0
  24. data/doc/images/babelfish.png +0 -0
  25. data/doc/images/browser.png +0 -0
  26. data/doc/images/button.png +0 -0
  27. data/doc/images/call-chain-example.png +0 -0
  28. data/doc/images/colordialog.png +0 -0
  29. data/doc/images/datatarget.png +0 -0
  30. data/doc/images/dialog.png +0 -0
  31. data/doc/images/dilbert.png +0 -0
  32. data/doc/images/dirlist.png +0 -0
  33. data/doc/images/dropsite-droprejected.png +0 -0
  34. data/doc/images/foursplit.png +0 -0
  35. data/doc/images/gltest.png +0 -0
  36. data/doc/images/glviewer.png +0 -0
  37. data/doc/images/groupbox.png +0 -0
  38. data/doc/images/header.png +0 -0
  39. data/doc/images/hello-with-button.png +0 -0
  40. data/doc/images/hello-with-icon-1.png +0 -0
  41. data/doc/images/hello-with-icon-2.png +0 -0
  42. data/doc/images/hello-with-icon-3.png +0 -0
  43. data/doc/images/hello-with-tooltip.png +0 -0
  44. data/doc/images/hello-without-button.png +0 -0
  45. data/doc/images/hello.png +0 -0
  46. data/doc/images/hello2.png +0 -0
  47. data/doc/images/iconlist-bigicons.png +0 -0
  48. data/doc/images/iconlist-details.png +0 -0
  49. data/doc/images/image.png +0 -0
  50. data/doc/images/imageviewer.png +0 -0
  51. data/doc/images/inheritance.png +0 -0
  52. data/doc/images/mditest.png +0 -0
  53. data/doc/images/raabrowser.png +0 -0
  54. data/doc/images/scribble.png +0 -0
  55. data/doc/images/shutter.png +0 -0
  56. data/doc/images/splitter.png +0 -0
  57. data/doc/images/tabbook.png +0 -0
  58. data/doc/images/table.png +0 -0
  59. data/doc/images/tutorial1.png +0 -0
  60. data/doc/implementation.html +16 -0
  61. data/doc/infosources.html +33 -0
  62. data/doc/library.html +30 -0
  63. data/doc/opengl.html +73 -0
  64. data/doc/pt01.html +3 -0
  65. data/doc/pt02.html +3 -0
  66. data/doc/scintilla.html +36 -0
  67. data/doc/style.css +247 -0
  68. data/doc/subversion.html +21 -0
  69. data/doc/tutorial1.html +90 -0
  70. data/doc/unicode.html +56 -0
  71. data/examples/RAA.rb +25 -0
  72. data/examples/README +53 -0
  73. data/examples/babelfish.rb +72 -0
  74. data/examples/bounce.rb +159 -0
  75. data/examples/browser.rb +191 -0
  76. data/examples/button.rb +168 -0
  77. data/examples/charts.rb +35 -0
  78. data/examples/custom_table_item.rb +170 -0
  79. data/examples/datatarget.rb +223 -0
  80. data/examples/dctest.rb +696 -0
  81. data/examples/dialog.rb +143 -0
  82. data/examples/dilbert.rb +66 -0
  83. data/examples/dirlist.rb +63 -0
  84. data/examples/dragdrop.rb +97 -0
  85. data/examples/dragsource.rb +80 -0
  86. data/examples/dropsite.rb +59 -0
  87. data/examples/foursplit.rb +97 -0
  88. data/examples/gltest.rb +330 -0
  89. data/examples/glviewer.rb +576 -0
  90. data/examples/groupbox.rb +392 -0
  91. data/examples/header.rb +149 -0
  92. data/examples/hello.rb +12 -0
  93. data/examples/hello2.rb +51 -0
  94. data/examples/iRAA.rb +153 -0
  95. data/examples/iconlist.rb +92 -0
  96. data/examples/icons/AngryGuyInBunnySuit.ico +0 -0
  97. data/examples/icons/FatBot.ico +0 -0
  98. data/examples/icons/FlippedySwitch.ico +0 -0
  99. data/examples/icons/LeGoon.ico +0 -0
  100. data/examples/icons/Net.ico +0 -0
  101. data/examples/icons/RedMacOS.ico +0 -0
  102. data/examples/icons/SawBlade.ico +0 -0
  103. data/examples/icons/backview.png +0 -0
  104. data/examples/icons/big.png +0 -0
  105. data/examples/icons/bigfolder.png +0 -0
  106. data/examples/icons/bigpenguin.png +0 -0
  107. data/examples/icons/bottomview.png +0 -0
  108. data/examples/icons/camera.png +0 -0
  109. data/examples/icons/capbutt.png +0 -0
  110. data/examples/icons/capnotlast.png +0 -0
  111. data/examples/icons/capproj.png +0 -0
  112. data/examples/icons/capround.png +0 -0
  113. data/examples/icons/colorpal.png +0 -0
  114. data/examples/icons/copy.png +0 -0
  115. data/examples/icons/cut.png +0 -0
  116. data/examples/icons/delimit.png +0 -0
  117. data/examples/icons/dippy.png +0 -0
  118. data/examples/icons/double_dash.png +0 -0
  119. data/examples/icons/filenew.png +0 -0
  120. data/examples/icons/fileopen.png +0 -0
  121. data/examples/icons/filesave.png +0 -0
  122. data/examples/icons/filesaveas.png +0 -0
  123. data/examples/icons/fonts.png +0 -0
  124. data/examples/icons/fox.png +0 -0
  125. data/examples/icons/foxicon.png +0 -0
  126. data/examples/icons/frontview.png +0 -0
  127. data/examples/icons/gem_big.png +0 -0
  128. data/examples/icons/gem_small.png +0 -0
  129. data/examples/icons/hello2.png +0 -0
  130. data/examples/icons/help.png +0 -0
  131. data/examples/icons/indent.png +0 -0
  132. data/examples/icons/jbevel.png +0 -0
  133. data/examples/icons/jmiter.png +0 -0
  134. data/examples/icons/jround.png +0 -0
  135. data/examples/icons/kill.png +0 -0
  136. data/examples/icons/leftview.png +0 -0
  137. data/examples/icons/light.png +0 -0
  138. data/examples/icons/minidoc.png +0 -0
  139. data/examples/icons/minifolder.png +0 -0
  140. data/examples/icons/minifolderopen.png +0 -0
  141. data/examples/icons/newfolder.png +0 -0
  142. data/examples/icons/nolight.png +0 -0
  143. data/examples/icons/onoff_dash.png +0 -0
  144. data/examples/icons/palette.png +0 -0
  145. data/examples/icons/parallel.png +0 -0
  146. data/examples/icons/paste.png +0 -0
  147. data/examples/icons/pattern.png +0 -0
  148. data/examples/icons/penguin.png +0 -0
  149. data/examples/icons/perspective.png +0 -0
  150. data/examples/icons/printicon.png +0 -0
  151. data/examples/icons/prop.png +0 -0
  152. data/examples/icons/redo.png +0 -0
  153. data/examples/icons/rightview.png +0 -0
  154. data/examples/icons/saveas.png +0 -0
  155. data/examples/icons/shutter1.png +0 -0
  156. data/examples/icons/shutter2.png +0 -0
  157. data/examples/icons/small.png +0 -0
  158. data/examples/icons/smoothlight.png +0 -0
  159. data/examples/icons/solid_line.png +0 -0
  160. data/examples/icons/tbuplevel.png +0 -0
  161. data/examples/icons/topview.png +0 -0
  162. data/examples/icons/undo.png +0 -0
  163. data/examples/icons/winapp.png +0 -0
  164. data/examples/icons/zoom.png +0 -0
  165. data/examples/image.rb +279 -0
  166. data/examples/imageviewer.rb +509 -0
  167. data/examples/inputs.rb +83 -0
  168. data/examples/mditest.rb +180 -0
  169. data/examples/pig.rb +77 -0
  170. data/examples/raabrowser.rb +122 -0
  171. data/examples/ratio.rb +80 -0
  172. data/examples/rulerview.rb +27 -0
  173. data/examples/scintilla-test.rb +81 -0
  174. data/examples/scribble-orig.rb +186 -0
  175. data/examples/scribble.rb +162 -0
  176. data/examples/shutter.rb +158 -0
  177. data/examples/splitter.rb +211 -0
  178. data/examples/styledtext.rb +82 -0
  179. data/examples/tabbook.rb +165 -0
  180. data/examples/table.rb +182 -0
  181. data/examples/textedit/commands.rb +114 -0
  182. data/examples/textedit/helpwindow.rb +299 -0
  183. data/examples/textedit/prefdialog.rb +239 -0
  184. data/examples/textedit/textedit.rb +1763 -0
  185. data/examples/unicode.rb +36 -0
  186. data/ext/fox16/fox16.so +0 -0
  187. data/index.html +14 -0
  188. data/lib/fox16/accel_table.rb +70 -0
  189. data/lib/fox16/aliases.rb +5611 -0
  190. data/lib/fox16/calendar.rb +217 -0
  191. data/lib/fox16/chore.rb +105 -0
  192. data/lib/fox16/colors.rb +280 -0
  193. data/lib/fox16/core.rb +700 -0
  194. data/lib/fox16/dict.rb +35 -0
  195. data/lib/fox16/exceptions_for_fxerror.rb +17 -0
  196. data/lib/fox16/execute_nonmodal.rb +70 -0
  197. data/lib/fox16/glgroup.rb +166 -0
  198. data/lib/fox16/glshapes.rb +456 -0
  199. data/lib/fox16/input.rb +59 -0
  200. data/lib/fox16/irb.rb +178 -0
  201. data/lib/fox16/iterators.rb +420 -0
  202. data/lib/fox16/keys.rb +1374 -0
  203. data/lib/fox16/kwargs.rb +2740 -0
  204. data/lib/fox16/missingdep.rb +14 -0
  205. data/lib/fox16/pseudokeyboard.rb +40 -0
  206. data/lib/fox16/pseudomouse.rb +87 -0
  207. data/lib/fox16/responder.rb +70 -0
  208. data/lib/fox16/responder2.rb +132 -0
  209. data/lib/fox16/scintilla.rb +3641 -0
  210. data/lib/fox16/settings.rb +18 -0
  211. data/lib/fox16/signal.rb +71 -0
  212. data/lib/fox16/splashscreen.rb +82 -0
  213. data/lib/fox16/timeout.rb +136 -0
  214. data/lib/fox16/undolist.rb +455 -0
  215. data/lib/fox16/version.rb +9 -0
  216. data/rdoc-sources/FX4Splitter.rb +156 -0
  217. data/rdoc-sources/FX7Segment.rb +54 -0
  218. data/rdoc-sources/FXAccelTable.rb +84 -0
  219. data/rdoc-sources/FXApp.rb +545 -0
  220. data/rdoc-sources/FXArrowButton.rb +69 -0
  221. data/rdoc-sources/FXBMPIcon.rb +67 -0
  222. data/rdoc-sources/FXBMPImage.rb +30 -0
  223. data/rdoc-sources/FXBitmap.rb +115 -0
  224. data/rdoc-sources/FXBitmapFrame.rb +31 -0
  225. data/rdoc-sources/FXBitmapView.rb +44 -0
  226. data/rdoc-sources/FXButton.rb +59 -0
  227. data/rdoc-sources/FXCURCursor.rb +13 -0
  228. data/rdoc-sources/FXCanvas.rb +18 -0
  229. data/rdoc-sources/FXCheckButton.rb +58 -0
  230. data/rdoc-sources/FXChoiceBox.rb +49 -0
  231. data/rdoc-sources/FXColorBar.rb +48 -0
  232. data/rdoc-sources/FXColorDialog.rb +37 -0
  233. data/rdoc-sources/FXColorList.rb +55 -0
  234. data/rdoc-sources/FXColorRing.rb +49 -0
  235. data/rdoc-sources/FXColorSelector.rb +65 -0
  236. data/rdoc-sources/FXColorWell.rb +65 -0
  237. data/rdoc-sources/FXColorWheel.rb +57 -0
  238. data/rdoc-sources/FXComboBox.rb +214 -0
  239. data/rdoc-sources/FXComposite.rb +34 -0
  240. data/rdoc-sources/FXCursor.rb +67 -0
  241. data/rdoc-sources/FXDC.rb +720 -0
  242. data/rdoc-sources/FXDCPrint.rb +127 -0
  243. data/rdoc-sources/FXDCWindow.rb +33 -0
  244. data/rdoc-sources/FXDataTarget.rb +66 -0
  245. data/rdoc-sources/FXDebugTarget.rb +25 -0
  246. data/rdoc-sources/FXDelegator.rb +23 -0
  247. data/rdoc-sources/FXDial.rb +107 -0
  248. data/rdoc-sources/FXDialogBox.rb +32 -0
  249. data/rdoc-sources/FXDict.rb +79 -0
  250. data/rdoc-sources/FXDirBox.rb +55 -0
  251. data/rdoc-sources/FXDirDialog.rb +47 -0
  252. data/rdoc-sources/FXDirList.rb +149 -0
  253. data/rdoc-sources/FXDirSelector.rb +64 -0
  254. data/rdoc-sources/FXDockBar.rb +151 -0
  255. data/rdoc-sources/FXDockHandler.rb +26 -0
  256. data/rdoc-sources/FXDockSite.rb +104 -0
  257. data/rdoc-sources/FXDockTitle.rb +26 -0
  258. data/rdoc-sources/FXDocument.rb +29 -0
  259. data/rdoc-sources/FXDragCorner.rb +19 -0
  260. data/rdoc-sources/FXDrawable.rb +27 -0
  261. data/rdoc-sources/FXDriveBox.rb +46 -0
  262. data/rdoc-sources/FXExtentd.rb +85 -0
  263. data/rdoc-sources/FXExtentf.rb +85 -0
  264. data/rdoc-sources/FXFileDialog.rb +217 -0
  265. data/rdoc-sources/FXFileDict.rb +131 -0
  266. data/rdoc-sources/FXFileList.rb +208 -0
  267. data/rdoc-sources/FXFileSelector.rb +184 -0
  268. data/rdoc-sources/FXFileStream.rb +27 -0
  269. data/rdoc-sources/FXFoldingList.rb +504 -0
  270. data/rdoc-sources/FXFont.rb +361 -0
  271. data/rdoc-sources/FXFontDialog.rb +14 -0
  272. data/rdoc-sources/FXFontSelector.rb +37 -0
  273. data/rdoc-sources/FXFrame.rb +53 -0
  274. data/rdoc-sources/FXGIFCursor.rb +50 -0
  275. data/rdoc-sources/FXGIFIcon.rb +31 -0
  276. data/rdoc-sources/FXGIFImage.rb +29 -0
  277. data/rdoc-sources/FXGLCanvas.rb +45 -0
  278. data/rdoc-sources/FXGLContext.rb +40 -0
  279. data/rdoc-sources/FXGLObject.rb +75 -0
  280. data/rdoc-sources/FXGLShape.rb +69 -0
  281. data/rdoc-sources/FXGLViewer.rb +332 -0
  282. data/rdoc-sources/FXGLVisual.rb +94 -0
  283. data/rdoc-sources/FXGradientBar.rb +301 -0
  284. data/rdoc-sources/FXGroupBox.rb +36 -0
  285. data/rdoc-sources/FXHeader.rb +411 -0
  286. data/rdoc-sources/FXHorizontalFrame.rb +29 -0
  287. data/rdoc-sources/FXICOIcon.rb +65 -0
  288. data/rdoc-sources/FXICOImage.rb +31 -0
  289. data/rdoc-sources/FXIcon.rb +38 -0
  290. data/rdoc-sources/FXIconDict.rb +48 -0
  291. data/rdoc-sources/FXIconList.rb +450 -0
  292. data/rdoc-sources/FXIconSource.rb +100 -0
  293. data/rdoc-sources/FXId.rb +34 -0
  294. data/rdoc-sources/FXImage.rb +292 -0
  295. data/rdoc-sources/FXImageFrame.rb +36 -0
  296. data/rdoc-sources/FXImageView.rb +35 -0
  297. data/rdoc-sources/FXInputDialog.rb +80 -0
  298. data/rdoc-sources/FXJPGIcon.rb +70 -0
  299. data/rdoc-sources/FXJPGImage.rb +38 -0
  300. data/rdoc-sources/FXKnob.rb +76 -0
  301. data/rdoc-sources/FXLabel.rb +72 -0
  302. data/rdoc-sources/FXList.rb +443 -0
  303. data/rdoc-sources/FXListBox.rb +191 -0
  304. data/rdoc-sources/FXMDIButton.rb +67 -0
  305. data/rdoc-sources/FXMDIChild.rb +155 -0
  306. data/rdoc-sources/FXMDIClient.rb +65 -0
  307. data/rdoc-sources/FXMainWindow.rb +26 -0
  308. data/rdoc-sources/FXMatrix.rb +57 -0
  309. data/rdoc-sources/FXMemoryBuffer.rb +28 -0
  310. data/rdoc-sources/FXMemoryStream.rb +50 -0
  311. data/rdoc-sources/FXMenuBar.rb +23 -0
  312. data/rdoc-sources/FXMenuButton.rb +84 -0
  313. data/rdoc-sources/FXMenuCaption.rb +53 -0
  314. data/rdoc-sources/FXMenuCascade.rb +18 -0
  315. data/rdoc-sources/FXMenuCheck.rb +30 -0
  316. data/rdoc-sources/FXMenuCommand.rb +26 -0
  317. data/rdoc-sources/FXMenuPane.rb +13 -0
  318. data/rdoc-sources/FXMenuRadio.rb +33 -0
  319. data/rdoc-sources/FXMenuSeparator.rb +21 -0
  320. data/rdoc-sources/FXMenuTitle.rb +27 -0
  321. data/rdoc-sources/FXMessageBox.rb +73 -0
  322. data/rdoc-sources/FXObject.rb +28 -0
  323. data/rdoc-sources/FXOptionMenu.rb +83 -0
  324. data/rdoc-sources/FXPCXIcon.rb +63 -0
  325. data/rdoc-sources/FXPCXImage.rb +31 -0
  326. data/rdoc-sources/FXPNGIcon.rb +66 -0
  327. data/rdoc-sources/FXPNGImage.rb +34 -0
  328. data/rdoc-sources/FXPPMIcon.rb +36 -0
  329. data/rdoc-sources/FXPPMImage.rb +31 -0
  330. data/rdoc-sources/FXPacker.rb +63 -0
  331. data/rdoc-sources/FXPicker.rb +27 -0
  332. data/rdoc-sources/FXPopup.rb +53 -0
  333. data/rdoc-sources/FXPrintDialog.rb +36 -0
  334. data/rdoc-sources/FXProgressBar.rb +57 -0
  335. data/rdoc-sources/FXProgressDialog.rb +36 -0
  336. data/rdoc-sources/FXQuatd.rb +164 -0
  337. data/rdoc-sources/FXQuatf.rb +173 -0
  338. data/rdoc-sources/FXRGBIcon.rb +64 -0
  339. data/rdoc-sources/FXRGBImage.rb +31 -0
  340. data/rdoc-sources/FXRadioButton.rb +70 -0
  341. data/rdoc-sources/FXRanged.rb +100 -0
  342. data/rdoc-sources/FXRangef.rb +100 -0
  343. data/rdoc-sources/FXRealSlider.rb +101 -0
  344. data/rdoc-sources/FXRealSpinner.rb +140 -0
  345. data/rdoc-sources/FXRecentFiles.rb +77 -0
  346. data/rdoc-sources/FXRectangle.rb +149 -0
  347. data/rdoc-sources/FXRegion.rb +64 -0
  348. data/rdoc-sources/FXRegistry.rb +56 -0
  349. data/rdoc-sources/FXReplaceDialog.rb +56 -0
  350. data/rdoc-sources/FXRootWindow.rb +17 -0
  351. data/rdoc-sources/FXRuler.rb +130 -0
  352. data/rdoc-sources/FXRulerView.rb +225 -0
  353. data/rdoc-sources/FXScintilla.rb +121 -0
  354. data/rdoc-sources/FXScrollArea.rb +86 -0
  355. data/rdoc-sources/FXScrollBar.rb +107 -0
  356. data/rdoc-sources/FXScrollPane.rb +28 -0
  357. data/rdoc-sources/FXScrollWindow.rb +38 -0
  358. data/rdoc-sources/FXSearchDialog.rb +24 -0
  359. data/rdoc-sources/FXSeparator.rb +74 -0
  360. data/rdoc-sources/FXSettings.rb +248 -0
  361. data/rdoc-sources/FXShell.rb +8 -0
  362. data/rdoc-sources/FXShutter.rb +102 -0
  363. data/rdoc-sources/FXSize.rb +95 -0
  364. data/rdoc-sources/FXSlider.rb +98 -0
  365. data/rdoc-sources/FXSphered.rb +80 -0
  366. data/rdoc-sources/FXSpheref.rb +80 -0
  367. data/rdoc-sources/FXSpinner.rb +136 -0
  368. data/rdoc-sources/FXSplashWindow.rb +27 -0
  369. data/rdoc-sources/FXSplitter.rb +89 -0
  370. data/rdoc-sources/FXSpring.rb +61 -0
  371. data/rdoc-sources/FXStatusBar.rb +42 -0
  372. data/rdoc-sources/FXStatusLine.rb +60 -0
  373. data/rdoc-sources/FXStream.rb +142 -0
  374. data/rdoc-sources/FXStringDict.rb +38 -0
  375. data/rdoc-sources/FXSwitcher.rb +78 -0
  376. data/rdoc-sources/FXTGAIcon.rb +63 -0
  377. data/rdoc-sources/FXTGAImage.rb +31 -0
  378. data/rdoc-sources/FXTIFIcon.rb +70 -0
  379. data/rdoc-sources/FXTIFImage.rb +37 -0
  380. data/rdoc-sources/FXTabBar.rb +80 -0
  381. data/rdoc-sources/FXTabBook.rb +41 -0
  382. data/rdoc-sources/FXTabItem.rb +58 -0
  383. data/rdoc-sources/FXTable.rb +975 -0
  384. data/rdoc-sources/FXText.rb +581 -0
  385. data/rdoc-sources/FXTextField.rb +151 -0
  386. data/rdoc-sources/FXToggleButton.rb +70 -0
  387. data/rdoc-sources/FXToolBar.rb +61 -0
  388. data/rdoc-sources/FXToolBarGrip.rb +50 -0
  389. data/rdoc-sources/FXToolBarShell.rb +44 -0
  390. data/rdoc-sources/FXToolBarTab.rb +74 -0
  391. data/rdoc-sources/FXToolTip.rb +39 -0
  392. data/rdoc-sources/FXTopWindow.rb +163 -0
  393. data/rdoc-sources/FXTranslator.rb +32 -0
  394. data/rdoc-sources/FXTreeList.rb +514 -0
  395. data/rdoc-sources/FXTreeListBox.rb +219 -0
  396. data/rdoc-sources/FXTriStateButton.rb +49 -0
  397. data/rdoc-sources/FXVec2d.rb +96 -0
  398. data/rdoc-sources/FXVec2f.rb +96 -0
  399. data/rdoc-sources/FXVec3d.rb +118 -0
  400. data/rdoc-sources/FXVec3f.rb +118 -0
  401. data/rdoc-sources/FXVec4d.rb +139 -0
  402. data/rdoc-sources/FXVec4f.rb +139 -0
  403. data/rdoc-sources/FXVerticalFrame.rb +29 -0
  404. data/rdoc-sources/FXVisual.rb +79 -0
  405. data/rdoc-sources/FXWindow.rb +725 -0
  406. data/rdoc-sources/FXWizard.rb +59 -0
  407. data/rdoc-sources/FXXBMIcon.rb +37 -0
  408. data/rdoc-sources/FXXBMImage.rb +32 -0
  409. data/rdoc-sources/FXXPMIcon.rb +65 -0
  410. data/rdoc-sources/FXXPMImage.rb +31 -0
  411. data/rdoc-sources/README.rdoc +53 -0
  412. data/rdoc-sources/fxdefs.rb +90 -0
  413. data/tests/README +19 -0
  414. data/tests/TC_FXAccelTable.rb +57 -0
  415. data/tests/TC_FXApp.rb +16 -0
  416. data/tests/TC_FXArc.rb +26 -0
  417. data/tests/TC_FXBMPIcon.rb +15 -0
  418. data/tests/TC_FXBMPImage.rb +15 -0
  419. data/tests/TC_FXButton.rb +78 -0
  420. data/tests/TC_FXCheckButton.rb +57 -0
  421. data/tests/TC_FXComboBox.rb +63 -0
  422. data/tests/TC_FXDC.rb +372 -0
  423. data/tests/TC_FXDCPrint.rb +101 -0
  424. data/tests/TC_FXDCWindow.rb +23 -0
  425. data/tests/TC_FXDataTarget.rb +24 -0
  426. data/tests/TC_FXDialogBox.rb +12 -0
  427. data/tests/TC_FXDirList.rb +30 -0
  428. data/tests/TC_FXExtentd.rb +21 -0
  429. data/tests/TC_FXExtentf.rb +21 -0
  430. data/tests/TC_FXFileAssoc.rb +62 -0
  431. data/tests/TC_FXFileStream.rb +89 -0
  432. data/tests/TC_FXFoldingList.rb +32 -0
  433. data/tests/TC_FXFont.rb +69 -0
  434. data/tests/TC_FXFontDesc.rb +58 -0
  435. data/tests/TC_FXGLGroup.rb +32 -0
  436. data/tests/TC_FXGLShape.rb +28 -0
  437. data/tests/TC_FXGLViewer.rb +20 -0
  438. data/tests/TC_FXGradientBar.rb +89 -0
  439. data/tests/TC_FXHeader.rb +82 -0
  440. data/tests/TC_FXHiliteStyle.rb +23 -0
  441. data/tests/TC_FXIconDict.rb +52 -0
  442. data/tests/TC_FXIconList.rb +192 -0
  443. data/tests/TC_FXId.rb +19 -0
  444. data/tests/TC_FXImage.rb +155 -0
  445. data/tests/TC_FXLight.rb +33 -0
  446. data/tests/TC_FXList.rb +116 -0
  447. data/tests/TC_FXListBox.rb +49 -0
  448. data/tests/TC_FXMainWindow.rb +19 -0
  449. data/tests/TC_FXMat4f.rb +228 -0
  450. data/tests/TC_FXMaterial.rb +89 -0
  451. data/tests/TC_FXMemoryStream.rb +97 -0
  452. data/tests/TC_FXMenuCheck.rb +57 -0
  453. data/tests/TC_FXMenuCommand.rb +12 -0
  454. data/tests/TC_FXMenuRadio.rb +57 -0
  455. data/tests/TC_FXMessageBox.rb +25 -0
  456. data/tests/TC_FXPoint.rb +57 -0
  457. data/tests/TC_FXQuatf.rb +93 -0
  458. data/tests/TC_FXRadioButton.rb +57 -0
  459. data/tests/TC_FXRanged.rb +42 -0
  460. data/tests/TC_FXRangef.rb +42 -0
  461. data/tests/TC_FXRectangle.rb +88 -0
  462. data/tests/TC_FXRegion.rb +54 -0
  463. data/tests/TC_FXRegistry.rb +27 -0
  464. data/tests/TC_FXScrollArea.rb +28 -0
  465. data/tests/TC_FXScrollWindow.rb +28 -0
  466. data/tests/TC_FXSegment.rb +22 -0
  467. data/tests/TC_FXSettings.rb +34 -0
  468. data/tests/TC_FXShell.rb +26 -0
  469. data/tests/TC_FXSize.rb +54 -0
  470. data/tests/TC_FXStream.rb +11 -0
  471. data/tests/TC_FXTable.rb +561 -0
  472. data/tests/TC_FXTableItem.rb +48 -0
  473. data/tests/TC_FXText.rb +96 -0
  474. data/tests/TC_FXTopWindow.rb +32 -0
  475. data/tests/TC_FXTreeList.rb +100 -0
  476. data/tests/TC_FXTreeListBox.rb +41 -0
  477. data/tests/TC_FXUndoList.rb +43 -0
  478. data/tests/TC_FXVec2d.rb +142 -0
  479. data/tests/TC_FXVec2f.rb +137 -0
  480. data/tests/TC_FXVec3d.rb +150 -0
  481. data/tests/TC_FXVec3f.rb +150 -0
  482. data/tests/TC_FXVec4f.rb +158 -0
  483. data/tests/TC_FXViewport.rb +30 -0
  484. data/tests/TC_FXXBMIcon.rb +15 -0
  485. data/tests/TC_FXXBMImage.rb +15 -0
  486. data/tests/TC_FXXPMIcon.rb +15 -0
  487. data/tests/TC_FXXPMImage.rb +15 -0
  488. data/tests/TC_Misc.rb +157 -0
  489. data/tests/TC_downcast.rb +15 -0
  490. data/tests/TS_All.rb +25 -0
  491. data/tests/blankpage.ps +166 -0
  492. data/tests/howdypage.ps +181 -0
  493. data/tests/stress1.rb +92 -0
  494. data/tests/stress2.rb +51 -0
  495. data/tests/stress3.rb +117 -0
  496. data/tests/testcase.rb +37 -0
  497. metadata +556 -0
@@ -0,0 +1,31 @@
1
+ module Fox
2
+ #
3
+ # Targa Image
4
+ #
5
+ class FXTGAImage < FXImage
6
+ #
7
+ # Return the suggested file extension for this image type ("tga").
8
+ #
9
+ def FXTGAImage.fileExt; end
10
+
11
+ #
12
+ # Return the MIME type for this image type
13
+ #
14
+ def FXTGAImage.mimeType; end
15
+
16
+ #
17
+ # Return an initialized FXTGAImage instance.
18
+ #
19
+ # ==== Parameters:
20
+ #
21
+ # +a+:: an application instance [FXApp]
22
+ # +pix+:: a memory buffer formatted in Targa file format [String]
23
+ # +opts+:: options [Integer]
24
+ # +width+:: width [Integer]
25
+ # +height+:: height [Integer]
26
+ #
27
+ def initialize(a, pix=nil, opts=0, width=1, height=1) # :yields: theTGAImage
28
+ end
29
+ end
30
+ end
31
+
@@ -0,0 +1,70 @@
1
+ module Fox
2
+ #
3
+ # Tagged Image File Format (TIFF) Icon
4
+ #
5
+ class FXTIFIcon < FXIcon
6
+ #
7
+ # Return the suggested file extension for this image type ("tif").
8
+ #
9
+ def FXTIFIcon.fileExt; end
10
+
11
+ #
12
+ # Return the MIME type for this image type
13
+ #
14
+ def FXTIFIcon.mimeType; end
15
+
16
+ # Return +true+ if TIF image file format is supported.
17
+ def FXTIFIcon.supported? ; end
18
+
19
+ # Codec setting [Integer]
20
+ attr_accessor :codec
21
+
22
+ #
23
+ # Return an initialized FXTIFIcon instance.
24
+ #
25
+ # ==== Parameters:
26
+ #
27
+ # +a+:: an application instance [FXApp]
28
+ # +pix+:: a memory buffer formatted in TIFF file format [String]
29
+ # +clr+:: transparency color [FXColor]
30
+ # +opts+:: options [Integer]
31
+ # +width+:: width [Integer]
32
+ # +height+:: height [Integer]
33
+ #
34
+ def initialize(a, pix=nil, clr=0, opts=0, width=1, height=1) # :yields: theTIFIcon
35
+ end
36
+ end
37
+
38
+ #
39
+ # Load a TIFF file from a stream.
40
+ # If successful, returns an array containing the image pixel data (as a
41
+ # String), transparency color, width, height and codec setting.
42
+ # If it fails, the function returns +nil+.
43
+ #
44
+ # ==== Parameters:
45
+ #
46
+ # +store+:: stream from which to read the file data [FXStream]
47
+ #
48
+ def Fox.fxloadTIF(store); end
49
+
50
+ #
51
+ # Save a TIFF image to a stream.
52
+ # Returns +true+ on success, +false+ on failure.
53
+ #
54
+ # ==== Parameters:
55
+ #
56
+ # +store+:: stream to which to write the image data [FXStream]
57
+ # +data+:: the image pixel data [String]
58
+ # +transp+:: transparency color [FXColor]
59
+ # +width+:: width [Integer]
60
+ # +height+:: height [Integer]
61
+ # +codec+:: codec setting [Integer]
62
+ #
63
+ def Fox.fxsaveTIF(store, data, transp, width, height, codec); end
64
+
65
+ #
66
+ # Return +true+ if _store_ (an FXStream instance) contains a TIFF image.
67
+ #
68
+ def Fox.fxcheckTIF(store); end
69
+ end
70
+
@@ -0,0 +1,37 @@
1
+ module Fox
2
+ #
3
+ # Tagged Image File Format (TIFF) Image
4
+ #
5
+ class FXTIFImage < FXImage
6
+ #
7
+ # Return the suggested file extension for this image type ("tif").
8
+ #
9
+ def FXTIFImage.fileExt; end
10
+
11
+ #
12
+ # Return the MIME type for this image type
13
+ #
14
+ def FXTIFImage.mimeType; end
15
+
16
+ # Return +true+ if TIF image file format is supported.
17
+ def FXTIFImage.supported? ; end
18
+
19
+ # Codec setting [Integer]
20
+ attr_accessor :codec
21
+
22
+ #
23
+ # Return an initialized FXTIFImage instance.
24
+ #
25
+ # ==== Parameters:
26
+ #
27
+ # +a+:: an application instance [FXApp]
28
+ # +pix+:: a memory buffer formatted in TIF file format [String]
29
+ # +opts+:: options [Integer]
30
+ # +width+:: width [Integer]
31
+ # +height+:: height [Integer]
32
+ #
33
+ def initialize(a, pix=nil, opts=0, width=1, height=1) # :yields: theTIFImage
34
+ end
35
+ end
36
+ end
37
+
@@ -0,0 +1,80 @@
1
+ module Fox
2
+ #
3
+ # The FXTabBar layout manager arranges tab items side by side,
4
+ # and raises the active tab item above the neighboring tab items.
5
+ # In a the horizontal arrangement, the tab bar can have the tab
6
+ # items on the top or on the bottom. In the vertical arrangement,
7
+ # the tabs can be on the left or on the right.
8
+ # When one of the tab items is pressed, the tab bar's #setCurrent()
9
+ # method is called with _notify_ of +true+. This in turn causes the tab bar
10
+ # to send a +SEL_COMMAND+ message to its target.
11
+ #
12
+ # === Events
13
+ #
14
+ # The following messages are sent by FXTabBar to its target:
15
+ #
16
+ # +SEL_COMMAND+::
17
+ # sent whenever the current tab item changes;
18
+ # the message data is an integer indicating the new current tab item's index.
19
+ #
20
+ # === Tab book options
21
+ #
22
+ # +TABBOOK_TOPTABS+:: Tabs on top (default)
23
+ # +TABBOOK_BOTTOMTABS+:: Tabs on bottom
24
+ # +TABBOOK_SIDEWAYS+:: Tabs on left
25
+ # +TABBOOK_LEFTTABS+:: Tabs on left
26
+ # +TABBOOK_RIGHTTABS+:: Tabs on right
27
+ # +TABBOOK_NORMAL+:: same as <tt>TABBOOK_TOPTABS</tt>
28
+ #
29
+ # === Message identifiers
30
+ #
31
+ # +ID_OPEN_ITEM+:: Sent from one of the FXTabItems
32
+ # +ID_OPEN_FIRST+:: Switch to the first panel
33
+ # +ID_OPEN_SECOND+:: x
34
+ # +ID_OPEN_THIRD+:: x
35
+ # +ID_OPEN_FOURTH+:: x
36
+ # +ID_OPEN_FIFTH+:: x
37
+ # +ID_OPEN_SIXTH+:: x
38
+ # +ID_OPEN_SEVENTH+:: x
39
+ # +ID_OPEN_EIGHTH+:: x
40
+ # +ID_OPEN_NINETH+:: x
41
+ # +ID_OPEN_TENTH+:: x
42
+ # +ID_OPEN_LAST+:: x
43
+ #
44
+ class FXTabBar < FXPacker
45
+ # Currently active tab item's index [Integer]
46
+ attr_accessor :current
47
+
48
+ # Tab bar style [Integer]
49
+ attr_accessor :tabStyle
50
+
51
+ #
52
+ # Return an initialized FXTabBar instance.
53
+ #
54
+ # ==== Parameters:
55
+ #
56
+ # +p+:: the parent window for this tar bar [FXComposite]
57
+ # +target+:: the message target, if any, for this tar bar [FXObject]
58
+ # +selector+:: the message identifier for this tab bar [Integer]
59
+ # +opts+:: tar bar options [Integer]
60
+ # +x+:: initial x-position [Integer]
61
+ # +y+:: initial y-position [Integer]
62
+ # +width+:: initial width [Integer]
63
+ # +height+:: initial height [Integer]
64
+ # +padLeft+:: internal padding on the left side, in pixels [Integer]
65
+ # +padRight+:: internal padding on the right side, in pixels [Integer]
66
+ # +padTop+:: internal padding on the top side, in pixels [Integer]
67
+ # +padBottom+:: internal padding on the bottom side, in pixels [Integer]
68
+ #
69
+ def initialize(p, target=nil, selector=0, opts=TABBOOK_NORMAL, x=0, y=0, width=0, height=0, padLeft=DEFAULT_SPACING, padRight=DEFAULT_SPACING, padTop=DEFAULT_SPACING, padBottom=DEFAULT_SPACING) # :yields: theTabBar
70
+ end
71
+
72
+ #
73
+ # Change currently active tab item; this raises the active tab item
74
+ # slightly above the neighboring tab items.
75
+ # If _notify_ is +true+, a +SEL_COMMAND+ message is sent to the tab bar's message target
76
+ #
77
+ def setCurrent(index, notify=false); end
78
+ end
79
+ end
80
+
@@ -0,0 +1,41 @@
1
+ module Fox
2
+ #
3
+ # The tab book layout manager arranges pairs of children;
4
+ # the even numbered children (0,2,4,...) are usually tab items,
5
+ # and are placed on the top. The odd numbered children are
6
+ # usually layout managers, and are placed below; all the odd
7
+ # numbered children are placed on top of each other, similar
8
+ # to the switcher widget. When the user presses one of the
9
+ # tab items, the tab item is raised above the neighboring tabs,
10
+ # and the corresponding panel is raised to the top.
11
+ # Thus, a tab book can be used to present many GUI controls
12
+ # in a small space by placing several panels on top of each
13
+ # other and using tab items to select the desired panel.
14
+ # When one of the tab items is pressed, the tab book's #setCurrent method
15
+ # is called with _notify+=true. This causes the tab book to send a
16
+ # +SEL_COMMAND+ message to its target.
17
+ #
18
+ class FXTabBook < FXTabBar
19
+ #
20
+ # Return an initialized FXTabBook instance.
21
+ #
22
+ # ==== Parameters:
23
+ #
24
+ # +p+:: the parent window for this tar book [FXComposite]
25
+ # +target+:: the message target, if any, for this tar book [FXObject]
26
+ # +selector+:: the message identifier for this tab book [Integer]
27
+ # +opts+:: tar book options [Integer]
28
+ # +x+:: initial x-position [Integer]
29
+ # +y+:: initial y-position [Integer]
30
+ # +width+:: initial width [Integer]
31
+ # +height+:: initial height [Integer]
32
+ # +padLeft+:: internal padding on the left side, in pixels [Integer]
33
+ # +padRight+:: internal padding on the right side, in pixels [Integer]
34
+ # +padTop+:: internal padding on the top side, in pixels [Integer]
35
+ # +padBottom+:: internal padding on the bottom side, in pixels [Integer]
36
+ #
37
+ def initialize(p, target=nil, selector=0, opts=TABBOOK_NORMAL, x=0, y=0, width=0, height=0, padLeft=DEFAULT_SPACING, padRight=DEFAULT_SPACING, padTop=DEFAULT_SPACING, padBottom=DEFAULT_SPACING) # :yields: theTabBook
38
+ end
39
+ end
40
+ end
41
+
@@ -0,0 +1,58 @@
1
+ module Fox
2
+ #
3
+ # A tab item is placed in a tab bar or tab book.
4
+ # When selected, the tab item sends a message to its
5
+ # parent, and causes itself to become the active tab,
6
+ # and raised slightly above the other tabs.
7
+ # In the tab book, activating a tab item also causes
8
+ # the corresponding panel to be raised to the top.
9
+ #
10
+ # === Events
11
+ #
12
+ # The following messages are sent by FXTabItem to its target:
13
+ #
14
+ # +SEL_KEYPRESS+:: sent when a key goes down; the message data is an FXEvent instance.
15
+ # +SEL_KEYRELEASE+:: sent when a key goes up; the message data is an FXEvent instance.
16
+ #
17
+ # === Tab item orientations (which affect border)
18
+ #
19
+ # +TAB_TOP+:: Top side tabs
20
+ # +TAB_LEFT+:: Left side tabs
21
+ # +TAB_RIGHT+:: Right side tabs
22
+ # +TAB_BOTTOM+:: Bottom side tabs
23
+ # +TAB_TOP_NORMAL+:: same as <tt>JUSTIFY_NORMAL|ICON_BEFORE_TEXT|TAB_TOP|FRAME_RAISED|FRAME_THICK</tt>
24
+ # +TAB_BOTTOM_NORMAL+:: same as <tt>JUSTIFY_NORMAL|ICON_BEFORE_TEXT|TAB_BOTTOM|FRAME_RAISED|FRAME_THICK</tt>
25
+ # +TAB_LEFT_NORMAL+:: same as <tt>JUSTIFY_LEFT|JUSTIFY_CENTER_Y|ICON_BEFORE_TEXT|TAB_LEFT|FRAME_RAISED|FRAME_THICK</tt>
26
+ # +TAB_RIGHT_NORMAL+:: same as <tt>JUSTIFY_LEFT|JUSTIFY_CENTER_Y|ICON_BEFORE_TEXT|TAB_RIGHT|FRAME_RAISED|FRAME_THICK</tt>
27
+ #
28
+ class FXTabItem < FXLabel
29
+
30
+ #
31
+ # Current tab item orientation, one of +TAB_TOP+, +TAB_LEFT+, +TAB_RIGHT+
32
+ # or +TAB_BOTTOM+ [Integer].
33
+ #
34
+ attr_accessor :tabOrientation
35
+
36
+ #
37
+ # Return an initialized FXTabItem instance.
38
+ #
39
+ # ==== Parameters:
40
+ #
41
+ # +p+:: the parent tab book (or tab bar) for this tab item [FXTabBar]
42
+ # +text+:: the text for this tab item [String]
43
+ # +ic+:: the icon for this tab item, if any [FXIcon]
44
+ # +opts+:: tab item options [Integer]
45
+ # +x+:: initial x-position [Integer]
46
+ # +y+:: initial y-position [Integer]
47
+ # +width+:: initial width [Integer]
48
+ # +height+:: initial height [Integer]
49
+ # +padLeft+:: internal padding on the left side, in pixels [Integer]
50
+ # +padRight+:: internal padding on the right side, in pixels [Integer]
51
+ # +padTop+:: internal padding on the top side, in pixels [Integer]
52
+ # +padBottom+:: internal padding on the bottom side, in pixels [Integer]
53
+ #
54
+ def initialize(p, text, ic=nil, opts=TAB_TOP_NORMAL, x=0, y=0, width=0, height=0, padLeft=DEFAULT_PAD, padRight=DEFAULT_PAD, padTop=DEFAULT_PAD, padBottom=DEFAULT_PAD) # :yields: theTabItem
55
+ end
56
+ end
57
+ end
58
+
@@ -0,0 +1,975 @@
1
+ module Fox
2
+ #
3
+ # Represents a cell position in an FXTable.
4
+ #
5
+ class FXTablePos
6
+ # Cell row (zero-based) [Integer]
7
+ attr_accessor :row
8
+
9
+ # Cell column (zero-based) [Integer]
10
+ attr_accessor :col
11
+
12
+ #
13
+ # Returns an initialized FXTablePos instance.
14
+ #
15
+ def initialize; end
16
+ end
17
+
18
+ #
19
+ # Represents a range of cells in an FXTable.
20
+ #
21
+ class FXTableRange
22
+ # Starting position for this range of cells [FXTablePos]
23
+ attr_accessor :fm
24
+
25
+ # Ending position for this range of cells [FXTablePos]
26
+ attr_accessor :to
27
+
28
+ #
29
+ # Returns an initialized FXTableRange instance.
30
+ #
31
+ def initialize; end
32
+ end
33
+
34
+ #
35
+ # Represents a particular cell in an FXTable.
36
+ #
37
+ class FXTableItem < FXObject
38
+
39
+ # Text associated with this cell [String]
40
+ attr_accessor :text
41
+
42
+ # Icon associated with this cell [FXIcon]
43
+ attr_accessor :icon
44
+
45
+ # User data associated with this cell [Object]
46
+ attr_accessor :data
47
+
48
+ # Indicates whether this item has the focus [Boolean]
49
+ attr_writer :focus
50
+
51
+ # Indicates whether this item is selected [Boolean]
52
+ attr_writer :selected
53
+
54
+ # Indicates whether this item is enabled [Boolean]
55
+ attr_writer :enabled
56
+
57
+ # Indicates whether this item is draggable [Boolean]
58
+ attr_writer :draggable
59
+
60
+ #
61
+ # Indicates how the text in the cell will be justified.
62
+ # This value is some combination of the horizontal justification
63
+ # flags +LEFT+, +CENTER_X+ and +RIGHT+, and the vertical
64
+ # justification flags +TOP+, +CENTER_Y+ and +BOTTOM+.
65
+ #
66
+ attr_accessor :justify
67
+
68
+ # The icon's position in the cell, relative to the text (one
69
+ # of +BEFORE+, +AFTER+, +ABOVE+ or +BELOW+) [Integer]
70
+ attr_accessor :iconPosition
71
+
72
+ # Which borders will be drawn for this cell (some combination of
73
+ # +LBORDER+, +RBORDER+, +TBORDER+ and +BBORDER+) [Integer]
74
+ attr_accessor :borders
75
+
76
+ # The background stipple pattern for this cell [Integer]
77
+ attr_accessor :stipple
78
+
79
+ #
80
+ # Return an initialized FXTableItem instance.
81
+ #
82
+ # ==== Parameters:
83
+ #
84
+ # +text+:: the text for this table item [String]
85
+ # +icon+:: the icon, if any, for this table item [FXIcon]
86
+ # +data+:: the user data for this table item [Object]
87
+ #
88
+ def initialize(text, icon=nil, data=nil); end
89
+
90
+ # Return the width of this item (in pixels)
91
+ def getWidth(table); end
92
+
93
+ # Return the height of this item (in pixels)
94
+ def getHeight(table); end
95
+
96
+ # Return true if this item has the focus
97
+ def hasFocus?; end
98
+
99
+ # Return true if this item is selected
100
+ def selected?; end
101
+
102
+ # Return true if this item is enabled
103
+ def enabled?; end
104
+
105
+ # Return true if this item is draggable
106
+ def draggable?; end
107
+
108
+ # Return the text for this table item
109
+ def to_s
110
+ text
111
+ end
112
+
113
+ # Change item icon, deleting the previous item icon if it was owned
114
+ # by this table item.
115
+ def setIcon(icn, owned=false); end
116
+
117
+ # Draw this table item
118
+ def draw(table, dc, x, y, w, h); end
119
+
120
+ # Draw borders
121
+ def drawBorders(table, dc, x, y, w, h); end
122
+
123
+ # Draw content
124
+ def drawContent(table, dc, x, y, w, h); end
125
+
126
+ # Draw hatch pattern
127
+ def drawPattern(table, dc, x, y, w, h); end
128
+
129
+ # Draw background behind the cell
130
+ def drawBackground(table, dc, x, y, w, h)
131
+ hg = table.horizontalGridShown? ? 1 : 0
132
+ vg = table.verticalGridShown? ? 1 : 0
133
+ dc.fillRectangle(x + vg, y + hg, w - vg, h - hg)
134
+ end
135
+
136
+ #
137
+ # Create input control for editing this item.
138
+ # Should return a new instance of some subclass of FXWindow.
139
+ #
140
+ def getControlFor(table); end
141
+
142
+ #
143
+ # Set item value from input _control_ (an instance of some subclass
144
+ # of FXWindow).
145
+ #
146
+ def setFromControl(control); end
147
+
148
+ # Create the server-side resources associated with this table item
149
+ def create; end
150
+
151
+ # Detach the server-side resources associated with this table item
152
+ def detach; end
153
+
154
+ # Destroy the server-side resources associated with this table item
155
+ def destroy; end
156
+ end
157
+
158
+ #
159
+ # The FXTable widget displays a table of items, each with some text and optional
160
+ # icon. A column Header control provide captions for each column, and a row
161
+ # Header control provides captions for each row. Columns are resizable by
162
+ # means of the column Header control if the TABLE_COL_SIZABLE option is passed.
163
+ # Likewise, rows in the table are resizable if the TABLE_ROW_SIZABLE option is
164
+ # specified. An entire row (column) can be selected by clicking on the a button
165
+ # in the row (column) Header control. Passing TABLE_NO_COLSELECT disables column
166
+ # selection, and passing TABLE_NO_ROWSELECT disables column selection.
167
+ # When TABLE_COL_RENUMBER is specified, columns are automatically renumbered when
168
+ # columns are added or removed. Similarly, TABLE_ROW_RENUMBER will cause row numbers
169
+ # to be recalculated automatically when rows are added or removed.
170
+ # To disable editing of cells in the table, the TABLE_READONLY can be specified.
171
+ # Cells in the table may or may not have items in them. When populating a cell
172
+ # for the first time, an item will be automatically created if necessary. Thus,
173
+ # a cell in the table takes no space unless it has actual contents.
174
+ # Moreover, a contiguous, rectangular region of cells in the table may refer to
175
+ # one single item; in that case, the item will be stretched to cover all the
176
+ # cells in the region, and no grid lines will be drawn interior to the spanning
177
+ # item.
178
+ #
179
+ # The Table widget issues SEL_SELECTED or SEL_DESELECTED when cells are selected
180
+ # or deselected, respectively. The table position affected is passed along as the
181
+ # 3rd parameter of these messages.
182
+ # Whenever the current (focus) item is changed, a SEL_CHANGED message is sent with
183
+ # the new table position as a parameter.
184
+ # When items are added to the table, a SEL_INSERTED message is sent, with the table
185
+ # range of the newly added cells as the parameter in the message.
186
+ # When items are removed from the table, a SEL_DELETED message is sent prior to the
187
+ # removal of the items, and the table range of the removed cells is passed as a parameter.
188
+ # A SEL_REPLACED message is sent when the contents of a cell are changed, either through
189
+ # editing or by other means; the parameter is the range of affected cells. This message
190
+ # is sent prior to the change.
191
+ # SEL_CLICKED, SEL_DOUBLECLICKED, and SEL_TRIPLECLICKED messages are sent when a cell
192
+ # is clicked, double-clicked, or triple-clicked, respectively.
193
+ # A SEL_COMMAND is sent when an enabled item is clicked inside the table.
194
+ #
195
+ # === Events
196
+ #
197
+ # The following messages are sent by FXTable to its target:
198
+ #
199
+ # +SEL_COMMAND+:: sent when a new item is clicked; the message data is an FXTablePos instance indicating the current cell.
200
+ # +SEL_KEYPRESS+:: sent when a key goes down; the message data is an FXEvent instance.
201
+ # +SEL_KEYRELEASE+:: sent when a key goes up; the message data is an FXEvent instance.
202
+ # +SEL_LEFTBUTTONPRESS+:: sent when the left mouse button goes down; the message data is an FXEvent instance.
203
+ # +SEL_LEFTBUTTONRELEASE+:: sent when the left mouse button goes up; the message data is an FXEvent instance.
204
+ # +SEL_RIGHTBUTTONPRESS+:: sent when the left mouse button goes down; the message data is an FXEvent instance.
205
+ # +SEL_RIGHTBUTTONRELEASE+:: sent when the left mouse button goes up; the message data is an FXEvent instance.
206
+ # +SEL_SELECTED+:: sent when a cell is selected; the message data is an FXTablePos instance indicating the position of the selected cell.
207
+ # +SEL_DESELECTED+:: sent when a cell is deselected; the message data is an FXTablePos instance indicating the position of the deselected cell.
208
+ # +SEL_CHANGED+:: sent when the current cell changes; the message data is an FXTablePos instance indicating the current cell.
209
+ # +SEL_CLICKED+:: sent when a cell is single-clicked; the message data is an FXTablePos instance indicating the current cell.
210
+ # +SEL_DOUBLECLICKED+:: sent when a cell is double-clicked; the message data is an FXTablePos instance indicating the current cell.
211
+ # +SEL_TRIPLECLICKED+:: sent when a cell is triple-clicked; the message data is an FXTablePos instance indicating the current cell.
212
+ # +SEL_DELETED+:: sent when a range of cells is about to be removed; the message data is an FXTableRange instance indicating the cells to be removed.
213
+ # +SEL_INSERTED+:: sent when a range of cells has been inserted; the message data is an FXTableRange instance indicating the cells inserted.
214
+ # +SEL_REPLACED+:: sent when a range of cells has been replaced; the message data is an FXTableRange instance indicating the cells replaced.
215
+ #
216
+ # === Table options
217
+ #
218
+ # +TABLE_COL_SIZABLE+:: Columns are resizable
219
+ # +TABLE_ROW_SIZABLE+:: Rows are resizable
220
+ # +TABLE_NO_COLSELECT+:: Disallow column selections
221
+ # +TABLE_NO_ROWSELECT+:: Disallow row selections
222
+ # +TABLE_READONLY+:: Table is not editable
223
+ # +TABLE_COL_RENUMBER+:: Renumber columns
224
+ # +TABLE_ROW_RENUMBER+:: Renumber rows
225
+ #
226
+ # === Message identifiers
227
+ #
228
+ # +ID_HORZ_GRID+:: x
229
+ # +ID_VERT_GRID+:: x
230
+ # +ID_TOGGLE_EDITABLE+:: x
231
+ # +ID_DELETE_COLUMN+:: x
232
+ # +ID_DELETE_ROW+:: x
233
+ # +ID_INSERT_COLUMN+:: x
234
+ # +ID_INSERT_ROW+:: x
235
+ # +ID_SELECT_COLUMN_INDEX+:: x
236
+ # +ID_SELECT_ROW_INDEX+:: x
237
+ # +ID_SELECT_COLUMN+:: x
238
+ # +ID_SELECT_ROW+:: x
239
+ # +ID_SELECT_CELL+:: x
240
+ # +ID_SELECT_ALL+:: x
241
+ # +ID_DESELECT_ALL+:: x
242
+ # +ID_MOVE_LEFT+:: x
243
+ # +ID_MOVE_RIGHT+:: x
244
+ # +ID_MOVE_UP+:: x
245
+ # +ID_MOVE_DOWN+:: x
246
+ # +ID_MOVE_HOME+:: x
247
+ # +ID_MOVE_END+:: x
248
+ # +ID_MOVE_TOP+:: x
249
+ # +ID_MOVE_BOTTOM+:: x
250
+ # +ID_MOVE_PAGEDOWN+:: x
251
+ # +ID_MOVE_PAGEUP+:: x
252
+ # +ID_START_INPUT+:: x
253
+ # +ID_CANCEL_INPUT+:: x
254
+ # +ID_ACCEPT_INPUT+:: x
255
+ # +ID_MARK+:: x
256
+ # +ID_EXTEND+:: x
257
+ # +ID_CUT_SEL+:: x
258
+ # +ID_COPY_SEL+:: x
259
+ # +ID_PASTE_SEL+:: x
260
+ # +ID_DELETE_SEL+:: x
261
+
262
+ class FXTable < FXScrollArea
263
+
264
+ # Button in the upper left corner [FXButton]
265
+ attr_reader :cornerButton
266
+
267
+ # Column header control [FXHeader]
268
+ attr_reader :columnHeader
269
+
270
+ # Row header control [FXHeader]
271
+ attr_reader :rowHeader
272
+
273
+ # Number of visible rows [Integer]
274
+ attr_accessor :visibleRows
275
+
276
+ # Number of visible columns [Integer]
277
+ attr_accessor :visibleColumns
278
+
279
+ # Number of rows [Integer]
280
+ attr_reader :numRows
281
+
282
+ # Number of columns [Integer]
283
+ attr_reader :numColumns
284
+
285
+ # Top cell margin, in pixels [Integer]
286
+ attr_accessor :marginTop
287
+
288
+ # Bottom cell margin, in pixels [Integer]
289
+ attr_accessor :marginBottom
290
+
291
+ # Left cell margin, in pixels [Integer]
292
+ attr_accessor :marginLeft
293
+
294
+ # Right cell margin, in pixels [Integer]
295
+ attr_accessor :marginRight
296
+
297
+ # Table style [Integer]
298
+ attr_accessor :tableStyle
299
+
300
+ # The column header height mode is either fixed (LAYOUT_FIX_HEIGHT) or variable.
301
+ # In variable height mode, the column header will size to fit the contents in it.
302
+ # In fixed height mode, the size is explicitly set via the _columnHeaderHeight_
303
+ # attribute.
304
+ attr_accessor :columnHeaderMode
305
+
306
+ # The row header width mode is either fixed (LAYOUT_FIX_WIDTH) or variable.
307
+ # In variable width mode, the row header will size to fit the contents in it.
308
+ # In fixed width mode, the size is explicitly set via the _rowHeaderWidth_
309
+ # attribute.
310
+ attr_accessor :rowHeaderMode
311
+
312
+ # Row header font [FXFont]
313
+ attr_accessor :rowHeaderFont
314
+
315
+ # Column header font [FXFont]
316
+ attr_accessor :columnHeaderFont
317
+
318
+ # The fixed column header height, if _columnHeaderMode_ is +LAYOUT_FIX_HEIGHT+.
319
+ attr_accessor :columnHeaderHeight
320
+
321
+ # The fixed row header width, if _rowHeaderMode_ is +LAYOUT_FIX_WIDTH+.
322
+ attr_accessor :rowHeaderWidth
323
+
324
+ # Default column width, in pixels [Integer]
325
+ attr_accessor :defColumnWidth
326
+
327
+ # Default row height, in pixels [Integer]
328
+ attr_accessor :defRowHeight
329
+
330
+ # Row number for current cell [Integer]
331
+ attr_reader :currentRow
332
+
333
+ # Column number for current cell [Integer]
334
+ attr_reader :currentColumn
335
+
336
+ # Row number for anchor cell [Integer]
337
+ attr_reader :anchorRow
338
+
339
+ # Column number for anchor cell [Integer]
340
+ attr_reader :anchorColumn
341
+
342
+ # Starting row number for selection, or -1 if there is no selection [Integer]
343
+ attr_reader :selStartRow
344
+
345
+ # Starting column number for selection, or -1 if there is no selection [Integer]
346
+ attr_reader :selStartColumn
347
+
348
+ # Ending row number for selection, or -1 if there is no selection [Integer]
349
+ attr_reader :selEndRow
350
+
351
+ # Ending column number for selection, or -1 if there is no selection [Integer]
352
+ attr_reader :selEndColumn
353
+
354
+ # Text font [FXFont]
355
+ attr_accessor :font
356
+
357
+ # Text color [FXColor]
358
+ attr_accessor :textColor
359
+
360
+ # Base GUI color [FXColor]
361
+ attr_accessor :baseColor
362
+
363
+ # Highlight color [FXColor]
364
+ attr_accessor :hiliteColor
365
+
366
+ # Shadow color [FXColor]
367
+ attr_accessor :shadowColor
368
+
369
+ # Border color [FXColor]
370
+ attr_accessor :borderColor
371
+
372
+ # Background color for selected cell(s) [FXColor]
373
+ attr_accessor :selBackColor
374
+
375
+ # Text color for selected cell(s) [FXColor]
376
+ attr_accessor :selTextColor
377
+
378
+ # Grid color [FXColor]
379
+ attr_accessor :gridColor
380
+
381
+ # Stipple color [FXColor]
382
+ attr_accessor :stippleColor
383
+
384
+ # Cell border color [FXColor]
385
+ attr_accessor :cellBorderColor
386
+
387
+ # Cell border width, in pixels [Integer]
388
+ attr_accessor :cellBorderWidth
389
+
390
+ # Status line help text [String]
391
+ attr_accessor :helpText
392
+
393
+ # Returns the drag type for CSV data
394
+ def FXTable.csvType; end
395
+
396
+ # Returns the drag type name for CSV data
397
+ def FXTable.csvTypeName; end
398
+
399
+ #
400
+ # Construct a new FXTable instance.
401
+ # The table is initially empty, and reports a default size based on
402
+ # the scroll areas's scrollbar placement policy.
403
+ #
404
+ # ==== Parameters:
405
+ #
406
+ # +p+:: the parent window for this table [FXComposite]
407
+ # +target+:: the message target (if any) for this table [FXObject]
408
+ # +selector+:: the message identifier for this table [Integer]
409
+ # +opts+:: table options [Integer]
410
+ # +x+:: initial x-position [Integer]
411
+ # +y+:: initial y-position [Integer]
412
+ # +width+:: initial width [Integer]
413
+ # +height+:: initial height [Integer]
414
+ # +padLeft+:: internal padding on the left side, in pixels [Integer]
415
+ # +padRight+:: internal padding on the right side, in pixels [Integer]
416
+ # +padTop+:: internal padding on the top side, in pixels [Integer]
417
+ # +padBottom+:: internal padding on the bottom side, in pixels [Integer]
418
+ #
419
+ def initialize(p, target=nil, selector=0, opts=0, x=0, y=0, width=0, height=0, padLeft=DEFAULT_MARGIN, padRight=DEFAULT_MARGIN, padTop=DEFAULT_MARGIN, padBottom=DEFAULT_MARGIN) # :yields: theTable
420
+ end
421
+
422
+ # Set visibility of horizontal grid to +true+ or +false+.
423
+ def horizontalGridShown=(vis); end
424
+
425
+ # Return +true+ if horizontal grid is shown.
426
+ def horizontalGridShown? ; end
427
+
428
+ # Set visibility of vertical grid to +true+ or +false+.
429
+ def verticalGridShown=(vis); end
430
+
431
+ # Is vertical grid shown?
432
+ def verticalGridShown? ; end
433
+
434
+ #
435
+ # Show or hide horizontal grid.
436
+ # Note that this is equivalent to the #horizontalGridShown=() method.
437
+ #
438
+ def showHorzGrid(on=true) ; end
439
+
440
+ #
441
+ # Show or hide vertical grid.
442
+ # Note that this is equivalent to the #verticalGridShown=() method.
443
+ #
444
+ def showVertGrid(on=true) ; end
445
+
446
+ # Set editability of this table to +true+ or +false+.
447
+ def editable=(edit); end
448
+
449
+ # Return +true+ if this table is editable.
450
+ def editable? ; end
451
+
452
+ #
453
+ # Start input mode for the cell at the given position.
454
+ # An input control is created which is used to edit the cell;
455
+ # it is filled by the original item's contents if the cell contained
456
+ # an item. You can enter input mode also by sending the table an
457
+ # <tt>ID_START_INPUT</tt> message.
458
+ #
459
+ def startInput(row, col); end
460
+
461
+ #
462
+ # Cancel input mode. The input control is immediately deleted
463
+ # and the cell will retain its old value. You can also cancel
464
+ # input mode by sending the table an <tt>ID_CANCEL_INPUT</tt> message.
465
+ #
466
+ def cancelInput(); end
467
+
468
+ #
469
+ # End input mode and accept the new value from the control.
470
+ # The item in the cell will be set to the value from the control,
471
+ # and the control will be deleted. If +true+ is passed, a +SEL_REPLACED+
472
+ # callback will be generated to signify to the target that this call
473
+ # has a new value. You can also accept the input by sending the table
474
+ # an <tt>ID_ACCEPT_INPUT</tt> message.
475
+ #
476
+ def acceptInput(notify=false); end
477
+
478
+ #
479
+ # Determine row containing _y_.
480
+ # Returns -1 if _y_ is above the first row, and _numRows_ if _y_ is below the last row.
481
+ # Otherwise, returns the row in the table containing _y_.
482
+ #
483
+ def rowAtY(y) ; end
484
+
485
+ #
486
+ # Determine column containing _x_.
487
+ # Returns -1 if _x_ is to the left of the first column, and _numColumns_ if _x_ is
488
+ # to the right of the last column. Otherwise, returns the column in the table
489
+ # containing _x_.
490
+ #
491
+ def colAtX(x) ; end
492
+
493
+ # Return the item (a reference to an FXTableItem) at the given _row_ and _column_.
494
+ # Raises IndexError if either _row_ or _column_ is out of bounds.
495
+ def getItem(row, column) ; end
496
+
497
+ # Replace the item at the given _row_ and _column_ with a (possibly subclassed) _item_.
498
+ # Raises IndexError if either _row_ or _column_ is out of bounds.
499
+ def setItem(row, column, item) ; end
500
+
501
+ #
502
+ # Resize the table content to _numRows_ rows and _numCols_ columns.
503
+ # Note that all existing items in the table will be destroyed and new
504
+ # items will be constructed.
505
+ # If _notify_ is +true+, then
506
+ # * a +SEL_DELETED+ message will be sent to the table's message target
507
+ # indicating which cells (if any) are about to be destroyed as a result of the resize;
508
+ # * a +SEL_INSERTED+ message will be sent to the table's message target
509
+ # indicating which cells (if any) were added as a result of the resize; and,
510
+ # * a +SEL_CHANGED+ message will be sent to the table's message target
511
+ # indicating the new current cell.
512
+ #
513
+ # Raises ArgError if either _numRows_ or _numCols_ is less than zero.
514
+ #
515
+ def setTableSize(numRows, numCols, notify=false) ; end
516
+
517
+ #
518
+ # Insert _numRows_ rows beginning at the specified _row_ number.
519
+ # If _row_ is equal to the number of rows in the table, the new
520
+ # rows are added to the bottom of the table.
521
+ # If _notify_ is +true+, a +SEL_INSERTED+ message is sent to the table's
522
+ # message target for each cell that is inserted.
523
+ # Raises IndexError if _row_ is out of bounds.
524
+ #
525
+ def insertRows(row, numRows=1, notify=false) ; end
526
+
527
+ #
528
+ # Insert _numColumns_ columns beginning at the specified _column_ number.
529
+ # If _column_ is equal to the number of columns in the table, the
530
+ # new columns are added to the right of the table.
531
+ # If _notify_ is +true+, a +SEL_INSERTED+ message is sent to the table's
532
+ # message target for each cell that is inserted.
533
+ # Raises IndexError if _column_ is out of bounds.
534
+ #
535
+ def insertColumns(column, numColumns=1, notify=false) ; end
536
+
537
+ #
538
+ # Remove the _nr_ rows starting at the specified _row_.
539
+ # If _notify_ is +true+, a +SEL_DELETED+ message is sent to the table's
540
+ # message target for each cell that is removed.
541
+ # Raises IndexError if _row_ is less than zero, or if _row_ + _nr_
542
+ # is greater than the current number of table rows.
543
+ #
544
+ def removeRows(row, nr=1, notify=false) ; end
545
+
546
+ #
547
+ # Remove the _nc_ columns starting at the specified _column_.
548
+ # If _notify_ is +true+, a +SEL_DELETED+ message is sent to the table's
549
+ # message target for each cell that is removed.
550
+ # Raises IndexError if _column_ is less than zero, or if
551
+ # _column_ + _nc_ is greater than the current number of table columns.
552
+ #
553
+ def removeColumns(column, nc=1, notify=false) ; end
554
+
555
+ #
556
+ # Extract item from table and return a reference to it.
557
+ # If _notify_ is +true+, a +SEL_REPLACED+ message is sent to the table's
558
+ # message target before this cell is removed.
559
+ # Raises IndexError if either _row_ or _col_ is out of bounds.
560
+ #
561
+ def extractItem(r, c, notify=false); end
562
+
563
+ #
564
+ # Remove item at (_row_, _col_), replacing it with +nil+.
565
+ # If _notify_ is +true+, a +SEL_REPLACED+ message is sent to the table's
566
+ # message target before this cell is removed.
567
+ # Raises IndexError if either _row_ or _col_ is out of bounds.
568
+ #
569
+ def removeItem(row, col, notify=false) ; end
570
+
571
+ #
572
+ # Remove all cells in the specified range of rows and columns.
573
+ # If _notify_ is +true+, a +SEL_REPLACED+ message is sent to the table's
574
+ # message target before each cell is removed.
575
+ # Raises IndexError if _startrow_, _endrow_, _startcol_ or
576
+ # _endcol_ is out of bounds.
577
+ #
578
+ def removeRange(startrow, endrow, startcol, endcol, notify=false); end
579
+
580
+ #
581
+ # Remove all items from table.
582
+ # If _notify_ is +true+, a +SEL_DELETED+ message is sent to the table's
583
+ # message target before the cells are removed.
584
+ #
585
+ def clearItems(notify=false); end
586
+
587
+ # Scroll to make cell at (_row_, _column_) fully visible.
588
+ # Raises IndexError if either _row_ or _column_ is out of bounds.
589
+ def makePositionVisible(row, column) ; end
590
+
591
+ # Returns +true+ if the cell at position (_row_, _column_) is visible.
592
+ # Raises IndexError if either _row_ or _column_ is out of bounds.
593
+ def itemVisible?(row, column) ; end
594
+
595
+ # Set column width.
596
+ # Raises IndexError if _column_ is out of bounds.
597
+ def setColumnWidth(column, columnWidth) ; end
598
+
599
+ # Get column width.
600
+ # Raises IndexError if _column_ is out of bounds.
601
+ def getColumnWidth(column) ; end
602
+
603
+ # Set row height.
604
+ # Raises IndexError if _row_ is out of bounds.
605
+ def setRowHeight(row, rowHeight) ; end
606
+
607
+ # Get row height.
608
+ # Raises IndexError if _row_ is out of bounds.
609
+ def getRowHeight(row) ; end
610
+
611
+ # Get x-coordinate of column.
612
+ # Raises IndexError if _column_ is out of bounds.
613
+ def getColumnX(column) ; end
614
+
615
+ # Get y-coordinate of row.
616
+ # Raises IndexError if _row_ is out of bounds.
617
+ def getRowY(row) ; end
618
+
619
+ # Return minimum row height for row _r_.
620
+ # Raises IndexError if _r_ is out of bounds.
621
+ def minRowHeight(r); end
622
+
623
+ # Return minimum column width for column _c_.
624
+ # Raises IndexError if _c_ is out of bounds.
625
+ def minColumnWidth(c); end
626
+
627
+ #
628
+ # Fit row heights to contents, for the _nr_ rows beginning with row index
629
+ # _row_.
630
+ #
631
+ def fitRowsToContents(row, nr=1); end
632
+
633
+ #
634
+ # Fit column widths to contents, for the _nc_ columns beginning with
635
+ # column index _col_.
636
+ #
637
+ def fitColumnsToContents(col, nc=1); end
638
+
639
+ # Set column header at _index_ to _text_.
640
+ # Raises IndexError if _index_ is out of bounds.
641
+ def setColumnText(index, text); end
642
+
643
+ # Return text of column header at _index_.
644
+ # Raises IndexError if _index_ is out of bounds.
645
+ def getColumnText(index); end
646
+
647
+ # Set row header at _index_ to _text_.
648
+ # Raises IndexError if _index_ is out of bounds.
649
+ def setRowText(index, text); end
650
+
651
+ # Return text of row header at _index_.
652
+ # Raises IndexError if _index_ is out of bounds.
653
+ def getRowText(index); end
654
+
655
+ # Change column header icon.
656
+ # Raises IndexError if _index_ is out of bounds.
657
+ def setColumnIcon(FXint index,FXIcon* icon);
658
+
659
+ # Return icon of column header at _index_.
660
+ # Raises IndexError if _index_ is out of bounds.
661
+ def getColumnIcon(index); end
662
+
663
+ # Change row header icon.
664
+ # Raises IndexError if _index_ is out of bounds.
665
+ def setRowIcon(index, icon); end
666
+
667
+ # Return icon of row header at _index_.
668
+ # Raises IndexError if _index_ is out of bounds.
669
+ def getRowIcon(index); end
670
+
671
+ # Change column header icon position, e.g. FXHeaderItem::BEFORE, etc.
672
+ # Raises IndexError if _index_ is out of bounds.
673
+ def setColumnIconPosition(index, mode); end
674
+
675
+ # Return icon position of column header at _index_.
676
+ # Raises IndexError if _index_ is out of bounds.
677
+ def getColumnIconPosition(index); end
678
+
679
+ # Change row header icon position, e.g. FXHeaderItem::BEFORE, etc.
680
+ # Raises IndexError if _index_ is out of bounds.
681
+ def setRowIconPosition(index, mode); end
682
+
683
+ # Return icon position of row header at _index_.
684
+ # Raises IndexError if _index_ is out of bounds.
685
+ def getRowIconPosition(index); end
686
+
687
+ # Change column header justify, e.g. FXHeaderItem::RIGHT, etc.
688
+ # Raises IndexError if _index_ is out of bounds.
689
+ def setColumnJustify(index, justify); end
690
+
691
+ # Return justify of column header at _index_.
692
+ # Raises IndexError if _index_ is out of bounds.
693
+ def getColumnJustify(index); end
694
+
695
+ # Change row header justify, e.g. FXHeaderItem::RIGHT, etc.
696
+ # Raises IndexError if _index_ is out of bounds.
697
+ def setRowJustify(index, justify); end
698
+
699
+ # Return justify of row header at _index_.
700
+ # Raises IndexError if _index_ is out of bounds.
701
+ def getRowJustify(index); end
702
+
703
+ #
704
+ # Modify cell text for item at specified _row_ and _col_.
705
+ # If _notify_ is +true+, a +SEL_REPLACED+ message is sent to the table's
706
+ # message target before the item's text is changed..
707
+ # Raises IndexError if either _row_ or _col_ is out of bounds.
708
+ #
709
+ def setItemText(row, col, text, notify=false) ; end
710
+
711
+ # Return cell text for item at specified _row_ and _column_.
712
+ # Raises IndexError if either _row_ or _column_ is out of bounds.
713
+ def getItemText(row, column) ; end
714
+
715
+ #
716
+ # Modify cell icon, deleting the old icon if it was owned.
717
+ # If _notify_ is +true+, a +SEL_REPLACED+ message is sent to the table's
718
+ # message target before the item's icon is changed..
719
+ # Raises IndexError if either _row_ or _col_ is out of bounds.
720
+ #
721
+ def setItemIcon(row, col, icon, notify=false) ; end
722
+
723
+ # Return item icon.
724
+ # Raises IndexError if either _row_ or _column_ is out of bounds.
725
+ def getItemIcon(row, column) ; end
726
+
727
+ # Modify cell user data.
728
+ # Raises IndexError if either _row_ or _column_ is out of bounds.
729
+ def setItemData(row, column, data) ; end
730
+
731
+ # Return cell user data.
732
+ # Raises IndexError if either _row_ or _column_ is out of bounds.
733
+ def getItemData(row, column) ; end
734
+
735
+ #
736
+ # Extract the text from all the cells in the specified range and
737
+ # return the result as a string.
738
+ # Within the result string, each column's text is delimited by
739
+ # the string specified by _cs_, and each row is delimited by
740
+ # the string specified by _rs_.
741
+ # To reverse this operation (i.e. set the table cells' text
742
+ # from a string), see #overlayText.
743
+ # Raises IndexError if any of _startrow_, _endrow_, _startcol_
744
+ # or _endcol_ is out of bounds.
745
+ #
746
+ # ==== Parameters:
747
+ #
748
+ # +startrow+:: the starting row for the range [Integer]
749
+ # +endrow+:: the ending row for the range [Integer]
750
+ # +startcol+:: the starting column for the range [Integer]
751
+ # +endcol+:: the ending column for the range [Integer]
752
+ # +cs+:: the string to insert at each column break [String]
753
+ # +rs+:: the string to insert at each row break [String]
754
+ #
755
+ def extractText(startrow, endrow, startcol, endcol, cs="\t", rs="\n"); end
756
+
757
+ #
758
+ # Overlay the text for the cells in the specified range with
759
+ # the fields specified in _text_.
760
+ # Within the _text_ string, each column's text should delimited by
761
+ # the character specified by _cs_, and each row should be delimited by
762
+ # the character specified by _rs_.
763
+ # To reverse this operation (i.e. extract the table cells' text
764
+ # into a string), see #extractText.
765
+ # Raises IndexError if any of _startrow_, _endrow_, _startcol_
766
+ # or _endcol_ is out of bounds.
767
+ #
768
+ # ==== Parameters:
769
+ #
770
+ # +startrow+:: the starting row for the range [Integer]
771
+ # +endrow+:: the ending row for the range [Integer]
772
+ # +startcol+:: the starting column for the range [Integer]
773
+ # +endcol+:: the ending column for the range [Integer]
774
+ # +text+:: the text containing the new cell text [String]
775
+ # +cs+:: the character to insert at each column break [String]
776
+ # +rs+:: the character to insert at each row break [String]
777
+ #
778
+ def overlayText(startrow, endrow, startcol, endcol, text, cs="\t", rs="\n", notify=false); end
779
+
780
+ #
781
+ # Determine the number of rows and columns in a block of text
782
+ # where columns are separated by characters from the set _cs_, and rows
783
+ # are separated by characters from the set _rs_.
784
+ # Return a two-element array containing the number of rows and
785
+ # columns, respectively.
786
+ #
787
+ def countText(text, cs="\t,", rs="\n"); end
788
+
789
+ # Return +true+ if the cell at position (_r_, _c_) is a spanning cell.
790
+ # Raises IndexError if either _r_ or _c_ is out of bounds.
791
+ def itemSpanning?(r, c); end
792
+
793
+ #
794
+ # Repaint cells between grid lines (_startRow_, _endRow_) and grid lines
795
+ # (_startCol_, _endCol_).
796
+ # Raises IndexError if any of the starting or ending grid lines is out of bounds.
797
+ #
798
+ def updateRange(startRow, endRow, startCol, endCol) ; end
799
+
800
+ # Repaint cell.
801
+ # Raises IndexError if either _row_ or _column_ is out of bounds.
802
+ def updateItem(row, column) ; end
803
+
804
+ # Enable cell.
805
+ # Raises IndexError if either _row_ or _column_ is out of bounds.
806
+ def enableItem(row, column) ; end
807
+
808
+ # Disable cell.
809
+ # Raises IndexError if either _row_ or _column_ is out of bounds.
810
+ def disableItem(row, column) ; end
811
+
812
+ # Returns +true+ if the cell at position (_row_, _column_) is enabled.
813
+ # Raises IndexError if either _row_ or _column_ is out of bounds.
814
+ def itemEnabled?(row, column) ; end
815
+
816
+ #
817
+ # Change item justification for the cell at (_r_, _c_).
818
+ # Horizontal justification is controlled by passing
819
+ # FXTableItem::RIGHT, FXTableItem::LEFT, or FXTableItem::CENTER_X.
820
+ # Vertical justification is controlled by FXTableItem::TOP, FXTableItem::BOTTOM,
821
+ # or FXTableItem::CENTER_Y.
822
+ # The default is a combination of FXTableItem::RIGHT and FXTableItem::CENTER_Y.
823
+ #
824
+ # Raises IndexError if either _r_ or _c_ is out of bounds.
825
+ #
826
+ def setItemJustify(r, c, justify); end
827
+
828
+ # Return item justification for the cell at (_r_, _c_).
829
+ # Raises IndexError if either _r_ or _c_ is out of bounds.
830
+ def getItemJustify(r, c); end
831
+
832
+ #
833
+ # Change relative position of icon and text of item at (_r_, _c_).
834
+ # Passing FXTableItem::BEFORE or FXTableItem::AFTER places the icon
835
+ # before or after the text, and passing FXTableItem::ABOVE or
836
+ # FXTableItem::BELOW places it above or below the text, respectively.
837
+ # The default is 0 which places the text on top of the icon.
838
+ #
839
+ # Raises IndexError if either _r_ or _c_ is out of bounds.
840
+ #
841
+ def setItemIconPosition(r, c, mode); end
842
+
843
+ # Return the relative position of the icon and text for the cell at (_r_, _c_).
844
+ # Raises IndexError if either _r_ or _c_ is out of bounds.
845
+ def getItemIconPosition(r, c); end
846
+
847
+ #
848
+ # Change item borders style for the item at (_r_, _c_).
849
+ # Borders on each side of the item can be turned
850
+ # controlled individually using FXTableItem::LBORDER, FXTableItem::RBORDER,
851
+ # FXTableItem::TBORDER and FXTableItem::BBORDER.
852
+ #
853
+ # Raises IndexError if either _r_ or _c_ is out of bounds.
854
+ #
855
+ def setItemBorders(r, c, borders); end
856
+
857
+ # Return the border style for the cell at (_r_, _c_).
858
+ # Raises IndexError if either _r_ or _c_ is out of bounds.
859
+ def getItemBorders(r, c); end
860
+
861
+ # Set the background stipple style for the cell at (_r_, _c_).
862
+ # Raises IndexError if either _r_ or _c_ is out of bounds.
863
+ def setItemStipple(r, c, pat); end
864
+
865
+ # Return the background stipple style for the cell at (_r_, _c_).
866
+ # Raises IndexError if either _r_ or _c_ is out of bounds.
867
+ def getItemStipple(r, c); end
868
+
869
+ # Change current cell.
870
+ # If _notify_ is +true+, a +SEL_CHANGED+ message is sent to the table's
871
+ # message target after the current item changes.
872
+ # Raises IndexError if either _row_ or _column_ is out of bounds.
873
+ def setCurrentItem(row, column, notify=false) ; end
874
+
875
+ # Returns +true+ if the cell at position (_row_, _column_) is the current cell.
876
+ # Raises IndexError if either _row_ or _column_ is out of bounds.
877
+ def itemCurrent?(row, column) ; end
878
+
879
+ # Change anchored cell.
880
+ # Raises IndexError if either _row_ or _column_ is out of bounds.
881
+ def setAnchorItem(row, column) ; end
882
+
883
+ # Returns +true+ if the cell at position (_row_, _column_) is selected.
884
+ # Raises IndexError if either _row_ or _column_ is out of bounds.
885
+ def itemSelected?(row, column) ; end
886
+
887
+ # Return +true+ if the specified row of cells is selected.
888
+ # Raises IndexError if _r_ is out of bounds.
889
+ def rowSelected?(r); end
890
+
891
+ # Return +true+ if the specified column of cells is selected.
892
+ # Raises IndexError if _c_ is out of bounds.
893
+ def columnSelected?(c); end
894
+
895
+ # Return +true+ if any cells are selected.
896
+ def anythingSelected?; end
897
+
898
+ # Select a row of cells.
899
+ # If _notify_ is +true+, a +SEL_DESELECTED+ message is sent to the table's message
900
+ # target for each previously selected cell that becomes deselected as a result of
901
+ # this operation. Likewise, a +SEL_SELECTED+ message is sent to the table's
902
+ # message target for each newly-selected cell.
903
+ # Raises IndexError if _row_ is out of bounds.
904
+ def selectRow(row, notify=false); end
905
+
906
+ # Select a column of cells.
907
+ # If _notify_ is +true+, a +SEL_DESELECTED+ message is sent to the table's message
908
+ # target for each previously selected cell that becomes deselected as a result of
909
+ # this operation. Likewise, a +SEL_SELECTED+ message is sent to the table's
910
+ # message target for each newly-selected cell.
911
+ # Raises IndexError if _col_ is out of bounds.
912
+ def selectColumn(col, notify=false); end
913
+
914
+ # Select range.
915
+ # If _notify_ is +true+, a +SEL_DESELECTED+ message is sent to the table's message
916
+ # target for each previously selected cell that becomes deselected as a result of
917
+ # this operation. Likewise, a +SEL_SELECTED+ message is sent to the table's
918
+ # message target for each newly-selected cell.
919
+ # Raises IndexError if _startRow_, _endRow_, _startColumn_ or _endColumn_ is out of bounds.
920
+ def selectRange(startRow, endRow, startColumn, endColumn, notify=false) ; end
921
+
922
+ # Extend selection.
923
+ # If _notify_ is +true+, a series of +SEL_SELECTED+ and +SEL_DESELECTED+ messages are sent to the table's message target
924
+ # after each affected item is selected or deselected.
925
+ # Raises IndexError if either _row_ or _column_ is out of bounds.
926
+ def extendSelection(row, column, notify=false) ; end
927
+
928
+ # Kill selection.
929
+ # If _notify_ is +true+, a +SEL_DESELECTED+ message is sent to the table's
930
+ # message target for each cell that was previously selected.
931
+ def killSelection(notify=false) ; end
932
+
933
+ #
934
+ # Change cell background color.
935
+ # The values for _row_ and _column_ are either zero or one.
936
+ # If the value is zero, this background color is used for even-numbered
937
+ # rows (columns). If the value is one, this background color is used
938
+ # for odd-numbered rows (columns).
939
+ # See also #getCellColor.
940
+ #
941
+ def setCellColor(row, column, color) ; end
942
+
943
+ #
944
+ # Obtain cell background color.
945
+ # The values for _row_ and _column_ are either zero or one.
946
+ # If the value is zero, returns the background color used for even-numbered
947
+ # rows (columns). If the value is one, returns the background color used
948
+ # for odd-numbered rows (columns).
949
+ # See also #setCellColor.
950
+ #
951
+ def getCellColor(row, column) ; end
952
+
953
+ # Create a new table item
954
+ def createItem(text, icon, data) ; end
955
+
956
+ # Draw a table cell
957
+ def drawCell(dc, xlo, xhi, ylo, yhi, xoff, yoff, startRow, endRow, startCol, endCol) ; end
958
+
959
+ # Draw a range of cells
960
+ def drawRange(dc, xlo, xhi, ylo, yhi, xoff, yoff, rlo, rhi, clo, chi) ; end
961
+
962
+ # Set column renumbering to +true+ or +false+.
963
+ def columnRenumbering=(renumber); end
964
+
965
+ # Get column renumbering
966
+ def columnRenumbering? ; end
967
+
968
+ # Set row renumbering to +true+ or +false+.
969
+ def rowRenumbering=(renumber); end
970
+
971
+ # Get row renumbering
972
+ def rowRenumbering? ; end
973
+ end
974
+ end
975
+