fxruby 1.6.13-mswin32
Sign up to get free protection for your applications and to get access to all the features.
- data/LICENSE +456 -0
- data/README +39 -0
- data/doc/apes02.html +21 -0
- data/doc/apes03.html +39 -0
- data/doc/book.html +3 -0
- data/doc/build.html +133 -0
- data/doc/ch03s02.html +23 -0
- data/doc/ch03s03.html +52 -0
- data/doc/ch03s04.html +36 -0
- data/doc/ch03s05.html +60 -0
- data/doc/ch04s02.html +71 -0
- data/doc/ch04s03.html +37 -0
- data/doc/ch04s04.html +72 -0
- data/doc/ch05s02.html +260 -0
- data/doc/ch05s03.html +127 -0
- data/doc/changes.html +685 -0
- data/doc/clipboardtut.html +67 -0
- data/doc/differences.html +190 -0
- data/doc/dragdroptut.html +263 -0
- data/doc/events.html +36 -0
- data/doc/examples.html +104 -0
- data/doc/gems.html +73 -0
- data/doc/goals.html +41 -0
- data/doc/images/babelfish.png +0 -0
- data/doc/images/browser.png +0 -0
- data/doc/images/button.png +0 -0
- data/doc/images/call-chain-example.png +0 -0
- data/doc/images/colordialog.png +0 -0
- data/doc/images/datatarget.png +0 -0
- data/doc/images/dialog.png +0 -0
- data/doc/images/dilbert.png +0 -0
- data/doc/images/dirlist.png +0 -0
- data/doc/images/dropsite-droprejected.png +0 -0
- data/doc/images/foursplit.png +0 -0
- data/doc/images/gltest.png +0 -0
- data/doc/images/glviewer.png +0 -0
- data/doc/images/groupbox.png +0 -0
- data/doc/images/header.png +0 -0
- data/doc/images/hello-with-button.png +0 -0
- data/doc/images/hello-with-icon-1.png +0 -0
- data/doc/images/hello-with-icon-2.png +0 -0
- data/doc/images/hello-with-icon-3.png +0 -0
- data/doc/images/hello-with-tooltip.png +0 -0
- data/doc/images/hello-without-button.png +0 -0
- data/doc/images/hello.png +0 -0
- data/doc/images/hello2.png +0 -0
- data/doc/images/iconlist-bigicons.png +0 -0
- data/doc/images/iconlist-details.png +0 -0
- data/doc/images/image.png +0 -0
- data/doc/images/imageviewer.png +0 -0
- data/doc/images/inheritance.png +0 -0
- data/doc/images/mditest.png +0 -0
- data/doc/images/raabrowser.png +0 -0
- data/doc/images/scribble.png +0 -0
- data/doc/images/shutter.png +0 -0
- data/doc/images/splitter.png +0 -0
- data/doc/images/tabbook.png +0 -0
- data/doc/images/table.png +0 -0
- data/doc/images/tutorial1.png +0 -0
- data/doc/implementation.html +16 -0
- data/doc/infosources.html +33 -0
- data/doc/library.html +30 -0
- data/doc/opengl.html +73 -0
- data/doc/pt01.html +3 -0
- data/doc/pt02.html +3 -0
- data/doc/scintilla.html +36 -0
- data/doc/style.css +247 -0
- data/doc/subversion.html +21 -0
- data/doc/tutorial1.html +90 -0
- data/doc/unicode.html +56 -0
- data/examples/RAA.rb +25 -0
- data/examples/README +53 -0
- data/examples/babelfish.rb +93 -0
- data/examples/bounce.rb +159 -0
- data/examples/browser.rb +191 -0
- data/examples/button.rb +168 -0
- data/examples/datatarget.rb +223 -0
- data/examples/dctest.rb +696 -0
- data/examples/dialog.rb +143 -0
- data/examples/dilbert.rb +67 -0
- data/examples/dirlist.rb +63 -0
- data/examples/dragdrop.rb +97 -0
- data/examples/dragsource.rb +80 -0
- data/examples/dropsite.rb +59 -0
- data/examples/foursplit.rb +97 -0
- data/examples/gltest.rb +330 -0
- data/examples/glviewer.rb +576 -0
- data/examples/groupbox.rb +392 -0
- data/examples/header.rb +149 -0
- data/examples/hello.rb +12 -0
- data/examples/hello2.rb +51 -0
- data/examples/iRAA.rb +153 -0
- data/examples/iconlist.rb +92 -0
- data/examples/icons/AngryGuyInBunnySuit.ico +0 -0
- data/examples/icons/FatBot.ico +0 -0
- data/examples/icons/FlippedySwitch.ico +0 -0
- data/examples/icons/LeGoon.ico +0 -0
- data/examples/icons/Net.ico +0 -0
- data/examples/icons/RedMacOS.ico +0 -0
- data/examples/icons/SawBlade.ico +0 -0
- data/examples/icons/backview.png +0 -0
- data/examples/icons/big.png +0 -0
- data/examples/icons/bigfolder.png +0 -0
- data/examples/icons/bigpenguin.png +0 -0
- data/examples/icons/bottomview.png +0 -0
- data/examples/icons/camera.png +0 -0
- data/examples/icons/capbutt.png +0 -0
- data/examples/icons/capnotlast.png +0 -0
- data/examples/icons/capproj.png +0 -0
- data/examples/icons/capround.png +0 -0
- data/examples/icons/colorpal.png +0 -0
- data/examples/icons/copy.png +0 -0
- data/examples/icons/cut.png +0 -0
- data/examples/icons/delimit.png +0 -0
- data/examples/icons/dippy.png +0 -0
- data/examples/icons/double_dash.png +0 -0
- data/examples/icons/filenew.png +0 -0
- data/examples/icons/fileopen.png +0 -0
- data/examples/icons/filesave.png +0 -0
- data/examples/icons/filesaveas.png +0 -0
- data/examples/icons/fonts.png +0 -0
- data/examples/icons/fox.png +0 -0
- data/examples/icons/foxicon.png +0 -0
- data/examples/icons/frontview.png +0 -0
- data/examples/icons/gem_big.png +0 -0
- data/examples/icons/gem_small.png +0 -0
- data/examples/icons/hello2.png +0 -0
- data/examples/icons/help.png +0 -0
- data/examples/icons/indent.png +0 -0
- data/examples/icons/jbevel.png +0 -0
- data/examples/icons/jmiter.png +0 -0
- data/examples/icons/jround.png +0 -0
- data/examples/icons/kill.png +0 -0
- data/examples/icons/leftview.png +0 -0
- data/examples/icons/light.png +0 -0
- data/examples/icons/minidoc.png +0 -0
- data/examples/icons/minifolder.png +0 -0
- data/examples/icons/minifolderopen.png +0 -0
- data/examples/icons/newfolder.png +0 -0
- data/examples/icons/nolight.png +0 -0
- data/examples/icons/onoff_dash.png +0 -0
- data/examples/icons/palette.png +0 -0
- data/examples/icons/parallel.png +0 -0
- data/examples/icons/paste.png +0 -0
- data/examples/icons/pattern.png +0 -0
- data/examples/icons/penguin.png +0 -0
- data/examples/icons/perspective.png +0 -0
- data/examples/icons/printicon.png +0 -0
- data/examples/icons/prop.png +0 -0
- data/examples/icons/redo.png +0 -0
- data/examples/icons/rightview.png +0 -0
- data/examples/icons/saveas.png +0 -0
- data/examples/icons/shutter1.png +0 -0
- data/examples/icons/shutter2.png +0 -0
- data/examples/icons/small.png +0 -0
- data/examples/icons/smoothlight.png +0 -0
- data/examples/icons/solid_line.png +0 -0
- data/examples/icons/tbuplevel.png +0 -0
- data/examples/icons/topview.png +0 -0
- data/examples/icons/undo.png +0 -0
- data/examples/icons/winapp.png +0 -0
- data/examples/icons/zoom.png +0 -0
- data/examples/image.rb +279 -0
- data/examples/imageviewer.rb +509 -0
- data/examples/inputs.rb +83 -0
- data/examples/mditest.rb +180 -0
- data/examples/pig.rb +77 -0
- data/examples/raabrowser.rb +122 -0
- data/examples/ratio.rb +80 -0
- data/examples/rulerview.rb +27 -0
- data/examples/scintilla-test.rb +81 -0
- data/examples/scribble-orig.rb +186 -0
- data/examples/scribble.rb +162 -0
- data/examples/shutter.rb +158 -0
- data/examples/splitter.rb +211 -0
- data/examples/styledtext.rb +82 -0
- data/examples/tabbook.rb +165 -0
- data/examples/table.rb +187 -0
- data/examples/textedit/commands.rb +114 -0
- data/examples/textedit/helpwindow.rb +299 -0
- data/examples/textedit/prefdialog.rb +239 -0
- data/examples/textedit/textedit.rb +1763 -0
- data/examples/unicode.rb +36 -0
- data/ext/fox16/fox16.so +0 -0
- data/index.html +14 -0
- data/lib/fox16/aliases.rb +5598 -0
- data/lib/fox16/calendar.rb +217 -0
- data/lib/fox16/chore.rb +105 -0
- data/lib/fox16/colors.rb +280 -0
- data/lib/fox16/core.rb +681 -0
- data/lib/fox16/dict.rb +35 -0
- data/lib/fox16/execute_nonmodal.rb +70 -0
- data/lib/fox16/glgroup.rb +166 -0
- data/lib/fox16/glshapes.rb +456 -0
- data/lib/fox16/input.rb +59 -0
- data/lib/fox16/irb.rb +178 -0
- data/lib/fox16/iterators.rb +371 -0
- data/lib/fox16/keys.rb +1374 -0
- data/lib/fox16/kwargs.rb +2725 -0
- data/lib/fox16/missingdep.rb +14 -0
- data/lib/fox16/pseudokeyboard.rb +40 -0
- data/lib/fox16/pseudomouse.rb +87 -0
- data/lib/fox16/responder.rb +70 -0
- data/lib/fox16/responder2.rb +131 -0
- data/lib/fox16/scintilla.rb +3641 -0
- data/lib/fox16/settings.rb +18 -0
- data/lib/fox16/signal.rb +71 -0
- data/lib/fox16/splashscreen.rb +82 -0
- data/lib/fox16/timeout.rb +136 -0
- data/lib/fox16/undolist.rb +455 -0
- data/lib/fox16/version.rb +9 -0
- data/rdoc-sources/FX4Splitter.rb +156 -0
- data/rdoc-sources/FX7Segment.rb +54 -0
- data/rdoc-sources/FXAccelTable.rb +102 -0
- data/rdoc-sources/FXApp.rb +545 -0
- data/rdoc-sources/FXArrowButton.rb +69 -0
- data/rdoc-sources/FXBMPIcon.rb +67 -0
- data/rdoc-sources/FXBMPImage.rb +30 -0
- data/rdoc-sources/FXBitmap.rb +115 -0
- data/rdoc-sources/FXBitmapFrame.rb +31 -0
- data/rdoc-sources/FXBitmapView.rb +44 -0
- data/rdoc-sources/FXButton.rb +59 -0
- data/rdoc-sources/FXCURCursor.rb +13 -0
- data/rdoc-sources/FXCanvas.rb +18 -0
- data/rdoc-sources/FXCheckButton.rb +58 -0
- data/rdoc-sources/FXChoiceBox.rb +49 -0
- data/rdoc-sources/FXColorBar.rb +48 -0
- data/rdoc-sources/FXColorDialog.rb +37 -0
- data/rdoc-sources/FXColorList.rb +55 -0
- data/rdoc-sources/FXColorRing.rb +49 -0
- data/rdoc-sources/FXColorSelector.rb +65 -0
- data/rdoc-sources/FXColorWell.rb +65 -0
- data/rdoc-sources/FXColorWheel.rb +57 -0
- data/rdoc-sources/FXComboBox.rb +211 -0
- data/rdoc-sources/FXComposite.rb +34 -0
- data/rdoc-sources/FXCursor.rb +67 -0
- data/rdoc-sources/FXDC.rb +720 -0
- data/rdoc-sources/FXDCPrint.rb +127 -0
- data/rdoc-sources/FXDCWindow.rb +33 -0
- data/rdoc-sources/FXDataTarget.rb +66 -0
- data/rdoc-sources/FXDebugTarget.rb +25 -0
- data/rdoc-sources/FXDelegator.rb +23 -0
- data/rdoc-sources/FXDial.rb +107 -0
- data/rdoc-sources/FXDialogBox.rb +32 -0
- data/rdoc-sources/FXDict.rb +79 -0
- data/rdoc-sources/FXDirBox.rb +55 -0
- data/rdoc-sources/FXDirDialog.rb +47 -0
- data/rdoc-sources/FXDirList.rb +149 -0
- data/rdoc-sources/FXDirSelector.rb +64 -0
- data/rdoc-sources/FXDockBar.rb +151 -0
- data/rdoc-sources/FXDockHandler.rb +26 -0
- data/rdoc-sources/FXDockSite.rb +104 -0
- data/rdoc-sources/FXDockTitle.rb +26 -0
- data/rdoc-sources/FXDocument.rb +29 -0
- data/rdoc-sources/FXDragCorner.rb +19 -0
- data/rdoc-sources/FXDrawable.rb +27 -0
- data/rdoc-sources/FXDriveBox.rb +46 -0
- data/rdoc-sources/FXExtentd.rb +85 -0
- data/rdoc-sources/FXExtentf.rb +85 -0
- data/rdoc-sources/FXFileDialog.rb +217 -0
- data/rdoc-sources/FXFileDict.rb +131 -0
- data/rdoc-sources/FXFileList.rb +208 -0
- data/rdoc-sources/FXFileSelector.rb +184 -0
- data/rdoc-sources/FXFileStream.rb +27 -0
- data/rdoc-sources/FXFoldingList.rb +504 -0
- data/rdoc-sources/FXFont.rb +361 -0
- data/rdoc-sources/FXFontDialog.rb +14 -0
- data/rdoc-sources/FXFontSelector.rb +37 -0
- data/rdoc-sources/FXFrame.rb +53 -0
- data/rdoc-sources/FXGIFCursor.rb +50 -0
- data/rdoc-sources/FXGIFIcon.rb +31 -0
- data/rdoc-sources/FXGIFImage.rb +29 -0
- data/rdoc-sources/FXGLCanvas.rb +45 -0
- data/rdoc-sources/FXGLContext.rb +40 -0
- data/rdoc-sources/FXGLObject.rb +75 -0
- data/rdoc-sources/FXGLShape.rb +69 -0
- data/rdoc-sources/FXGLViewer.rb +332 -0
- data/rdoc-sources/FXGLVisual.rb +94 -0
- data/rdoc-sources/FXGradientBar.rb +301 -0
- data/rdoc-sources/FXGroupBox.rb +33 -0
- data/rdoc-sources/FXHeader.rb +408 -0
- data/rdoc-sources/FXHorizontalFrame.rb +29 -0
- data/rdoc-sources/FXICOIcon.rb +65 -0
- data/rdoc-sources/FXICOImage.rb +31 -0
- data/rdoc-sources/FXIcon.rb +38 -0
- data/rdoc-sources/FXIconDict.rb +48 -0
- data/rdoc-sources/FXIconList.rb +447 -0
- data/rdoc-sources/FXIconSource.rb +100 -0
- data/rdoc-sources/FXId.rb +34 -0
- data/rdoc-sources/FXImage.rb +286 -0
- data/rdoc-sources/FXImageFrame.rb +36 -0
- data/rdoc-sources/FXImageView.rb +35 -0
- data/rdoc-sources/FXInputDialog.rb +77 -0
- data/rdoc-sources/FXJPGIcon.rb +70 -0
- data/rdoc-sources/FXJPGImage.rb +38 -0
- data/rdoc-sources/FXKnob.rb +76 -0
- data/rdoc-sources/FXLabel.rb +69 -0
- data/rdoc-sources/FXList.rb +440 -0
- data/rdoc-sources/FXListBox.rb +191 -0
- data/rdoc-sources/FXMDIButton.rb +67 -0
- data/rdoc-sources/FXMDIChild.rb +155 -0
- data/rdoc-sources/FXMDIClient.rb +65 -0
- data/rdoc-sources/FXMainWindow.rb +26 -0
- data/rdoc-sources/FXMatrix.rb +57 -0
- data/rdoc-sources/FXMemoryBuffer.rb +28 -0
- data/rdoc-sources/FXMemoryStream.rb +50 -0
- data/rdoc-sources/FXMenuBar.rb +23 -0
- data/rdoc-sources/FXMenuButton.rb +84 -0
- data/rdoc-sources/FXMenuCaption.rb +50 -0
- data/rdoc-sources/FXMenuCascade.rb +18 -0
- data/rdoc-sources/FXMenuCheck.rb +30 -0
- data/rdoc-sources/FXMenuCommand.rb +26 -0
- data/rdoc-sources/FXMenuPane.rb +13 -0
- data/rdoc-sources/FXMenuRadio.rb +33 -0
- data/rdoc-sources/FXMenuSeparator.rb +21 -0
- data/rdoc-sources/FXMenuTitle.rb +27 -0
- data/rdoc-sources/FXMessageBox.rb +72 -0
- data/rdoc-sources/FXObject.rb +28 -0
- data/rdoc-sources/FXOptionMenu.rb +83 -0
- data/rdoc-sources/FXPCXIcon.rb +63 -0
- data/rdoc-sources/FXPCXImage.rb +31 -0
- data/rdoc-sources/FXPNGIcon.rb +66 -0
- data/rdoc-sources/FXPNGImage.rb +34 -0
- data/rdoc-sources/FXPPMIcon.rb +36 -0
- data/rdoc-sources/FXPPMImage.rb +31 -0
- data/rdoc-sources/FXPacker.rb +63 -0
- data/rdoc-sources/FXPicker.rb +27 -0
- data/rdoc-sources/FXPopup.rb +53 -0
- data/rdoc-sources/FXPrintDialog.rb +36 -0
- data/rdoc-sources/FXProgressBar.rb +57 -0
- data/rdoc-sources/FXProgressDialog.rb +36 -0
- data/rdoc-sources/FXQuatd.rb +164 -0
- data/rdoc-sources/FXQuatf.rb +173 -0
- data/rdoc-sources/FXRGBIcon.rb +64 -0
- data/rdoc-sources/FXRGBImage.rb +31 -0
- data/rdoc-sources/FXRadioButton.rb +70 -0
- data/rdoc-sources/FXRanged.rb +100 -0
- data/rdoc-sources/FXRangef.rb +100 -0
- data/rdoc-sources/FXRealSlider.rb +101 -0
- data/rdoc-sources/FXRealSpinner.rb +140 -0
- data/rdoc-sources/FXRecentFiles.rb +77 -0
- data/rdoc-sources/FXRectangle.rb +149 -0
- data/rdoc-sources/FXRegion.rb +64 -0
- data/rdoc-sources/FXRegistry.rb +56 -0
- data/rdoc-sources/FXReplaceDialog.rb +56 -0
- data/rdoc-sources/FXRootWindow.rb +17 -0
- data/rdoc-sources/FXRuler.rb +130 -0
- data/rdoc-sources/FXRulerView.rb +225 -0
- data/rdoc-sources/FXScintilla.rb +121 -0
- data/rdoc-sources/FXScrollArea.rb +86 -0
- data/rdoc-sources/FXScrollBar.rb +107 -0
- data/rdoc-sources/FXScrollPane.rb +28 -0
- data/rdoc-sources/FXScrollWindow.rb +38 -0
- data/rdoc-sources/FXSearchDialog.rb +24 -0
- data/rdoc-sources/FXSeparator.rb +74 -0
- data/rdoc-sources/FXSettings.rb +248 -0
- data/rdoc-sources/FXShell.rb +8 -0
- data/rdoc-sources/FXShutter.rb +102 -0
- data/rdoc-sources/FXSize.rb +95 -0
- data/rdoc-sources/FXSlider.rb +98 -0
- data/rdoc-sources/FXSphered.rb +80 -0
- data/rdoc-sources/FXSpheref.rb +80 -0
- data/rdoc-sources/FXSpinner.rb +136 -0
- data/rdoc-sources/FXSplashWindow.rb +27 -0
- data/rdoc-sources/FXSplitter.rb +89 -0
- data/rdoc-sources/FXSpring.rb +61 -0
- data/rdoc-sources/FXStatusBar.rb +42 -0
- data/rdoc-sources/FXStatusLine.rb +60 -0
- data/rdoc-sources/FXStream.rb +142 -0
- data/rdoc-sources/FXStringDict.rb +38 -0
- data/rdoc-sources/FXSwitcher.rb +78 -0
- data/rdoc-sources/FXTGAIcon.rb +63 -0
- data/rdoc-sources/FXTGAImage.rb +31 -0
- data/rdoc-sources/FXTIFIcon.rb +70 -0
- data/rdoc-sources/FXTIFImage.rb +37 -0
- data/rdoc-sources/FXTabBar.rb +80 -0
- data/rdoc-sources/FXTabBook.rb +41 -0
- data/rdoc-sources/FXTabItem.rb +58 -0
- data/rdoc-sources/FXTable.rb +967 -0
- data/rdoc-sources/FXText.rb +578 -0
- data/rdoc-sources/FXTextField.rb +151 -0
- data/rdoc-sources/FXToggleButton.rb +69 -0
- data/rdoc-sources/FXToolBar.rb +61 -0
- data/rdoc-sources/FXToolBarGrip.rb +50 -0
- data/rdoc-sources/FXToolBarShell.rb +44 -0
- data/rdoc-sources/FXToolBarTab.rb +74 -0
- data/rdoc-sources/FXToolTip.rb +36 -0
- data/rdoc-sources/FXTopWindow.rb +163 -0
- data/rdoc-sources/FXTranslator.rb +32 -0
- data/rdoc-sources/FXTreeList.rb +514 -0
- data/rdoc-sources/FXTreeListBox.rb +219 -0
- data/rdoc-sources/FXTriStateButton.rb +49 -0
- data/rdoc-sources/FXVec2d.rb +96 -0
- data/rdoc-sources/FXVec2f.rb +96 -0
- data/rdoc-sources/FXVec3d.rb +113 -0
- data/rdoc-sources/FXVec3f.rb +113 -0
- data/rdoc-sources/FXVec4d.rb +129 -0
- data/rdoc-sources/FXVec4f.rb +129 -0
- data/rdoc-sources/FXVerticalFrame.rb +29 -0
- data/rdoc-sources/FXVisual.rb +79 -0
- data/rdoc-sources/FXWindow.rb +725 -0
- data/rdoc-sources/FXWizard.rb +59 -0
- data/rdoc-sources/FXXBMIcon.rb +37 -0
- data/rdoc-sources/FXXBMImage.rb +32 -0
- data/rdoc-sources/FXXPMIcon.rb +65 -0
- data/rdoc-sources/FXXPMImage.rb +31 -0
- data/rdoc-sources/README.rdoc +53 -0
- data/rdoc-sources/fxdefs.rb +90 -0
- data/tests/README +19 -0
- data/tests/TC_FXAccelTable.rb +43 -0
- data/tests/TC_FXApp.rb +15 -0
- data/tests/TC_FXArc.rb +26 -0
- data/tests/TC_FXBMPIcon.rb +15 -0
- data/tests/TC_FXBMPImage.rb +15 -0
- data/tests/TC_FXButton.rb +72 -0
- data/tests/TC_FXCheckButton.rb +57 -0
- data/tests/TC_FXComboBox.rb +52 -0
- data/tests/TC_FXDC.rb +372 -0
- data/tests/TC_FXDCPrint.rb +102 -0
- data/tests/TC_FXDCWindow.rb +23 -0
- data/tests/TC_FXDataTarget.rb +24 -0
- data/tests/TC_FXDirList.rb +30 -0
- data/tests/TC_FXFileAssoc.rb +62 -0
- data/tests/TC_FXFileStream.rb +90 -0
- data/tests/TC_FXFoldingList.rb +32 -0
- data/tests/TC_FXFont.rb +69 -0
- data/tests/TC_FXFontDesc.rb +58 -0
- data/tests/TC_FXGLGroup.rb +32 -0
- data/tests/TC_FXGLShape.rb +28 -0
- data/tests/TC_FXGLViewer.rb +20 -0
- data/tests/TC_FXGradientBar.rb +89 -0
- data/tests/TC_FXHeader.rb +82 -0
- data/tests/TC_FXIconDict.rb +52 -0
- data/tests/TC_FXIconList.rb +192 -0
- data/tests/TC_FXId.rb +19 -0
- data/tests/TC_FXImage.rb +155 -0
- data/tests/TC_FXLight.rb +33 -0
- data/tests/TC_FXList.rb +116 -0
- data/tests/TC_FXListBox.rb +49 -0
- data/tests/TC_FXMat4f.rb +228 -0
- data/tests/TC_FXMaterial.rb +89 -0
- data/tests/TC_FXMemoryStream.rb +97 -0
- data/tests/TC_FXMenuCheck.rb +57 -0
- data/tests/TC_FXMenuCommand.rb +12 -0
- data/tests/TC_FXMenuRadio.rb +57 -0
- data/tests/TC_FXPoint.rb +57 -0
- data/tests/TC_FXQuatf.rb +77 -0
- data/tests/TC_FXRadioButton.rb +57 -0
- data/tests/TC_FXRangef.rb +48 -0
- data/tests/TC_FXRectangle.rb +88 -0
- data/tests/TC_FXRegion.rb +54 -0
- data/tests/TC_FXRegistry.rb +27 -0
- data/tests/TC_FXScrollArea.rb +28 -0
- data/tests/TC_FXScrollWindow.rb +28 -0
- data/tests/TC_FXSegment.rb +22 -0
- data/tests/TC_FXSettings.rb +34 -0
- data/tests/TC_FXShell.rb +26 -0
- data/tests/TC_FXSize.rb +54 -0
- data/tests/TC_FXStream.rb +11 -0
- data/tests/TC_FXTable.rb +368 -0
- data/tests/TC_FXTableItem.rb +48 -0
- data/tests/TC_FXText.rb +96 -0
- data/tests/TC_FXTopWindow.rb +32 -0
- data/tests/TC_FXTreeList.rb +100 -0
- data/tests/TC_FXTreeListBox.rb +41 -0
- data/tests/TC_FXUndoList.rb +43 -0
- data/tests/TC_FXVec2d.rb +142 -0
- data/tests/TC_FXVec2f.rb +137 -0
- data/tests/TC_FXVec3d.rb +150 -0
- data/tests/TC_FXVec3f.rb +150 -0
- data/tests/TC_FXVec4f.rb +158 -0
- data/tests/TC_FXViewport.rb +30 -0
- data/tests/TC_FXXBMIcon.rb +15 -0
- data/tests/TC_FXXBMImage.rb +15 -0
- data/tests/TC_FXXPMIcon.rb +15 -0
- data/tests/TC_FXXPMImage.rb +15 -0
- data/tests/TC_Misc.rb +157 -0
- data/tests/TC_downcast.rb +15 -0
- data/tests/TS_All.rb +25 -0
- data/tests/blankpage.ps +166 -0
- data/tests/howdypage.ps +181 -0
- data/tests/stress1.rb +94 -0
- data/tests/stress2.rb +51 -0
- data/tests/stress3.rb +117 -0
- data/tests/testcase.rb +37 -0
- data/web/art/fxrubylogo.png +0 -0
- data/web/art/fxrubylogo_small.png +0 -0
- data/web/art/line.gif +0 -0
- data/web/art/oul_grey.gif +0 -0
- data/web/art/our.gif +0 -0
- data/web/downloads.html +93 -0
- data/web/home.html +113 -0
- data/web/menu.html +50 -0
- data/web/styles.css +167 -0
- data/web/top.html +15 -0
- metadata +548 -0
@@ -0,0 +1,156 @@
|
|
1
|
+
module Fox
|
2
|
+
|
3
|
+
#
|
4
|
+
# The four-way splitter is a layout manager which manages
|
5
|
+
# four children like four panes in a window.
|
6
|
+
# You can use a four-way splitter for example in a CAD program
|
7
|
+
# where you may want to maintain three orthographic views, and
|
8
|
+
# one oblique view of a model.
|
9
|
+
# The four-way splitter allows interactive repartitioning of the
|
10
|
+
# panes by means of moving the central splitter bars.
|
11
|
+
# When the four-way splitter is itself resized, each child is
|
12
|
+
# proportionally resized, maintaining the same split-percentage.
|
13
|
+
#
|
14
|
+
# === Events
|
15
|
+
#
|
16
|
+
# The following messages are sent by FX4Splitter to its target:
|
17
|
+
#
|
18
|
+
# +SEL_LEFTBUTTONPRESS+:: sent when the left mouse button goes down; the message data is an FXEvent instance.
|
19
|
+
# +SEL_LEFTBUTTONRELEASE+:: sent when the left mouse button goes up; the message data is an FXEvent instance.
|
20
|
+
# +SEL_COMMAND+:: sent at the end of a resize operation, to signal that the resize is complete
|
21
|
+
# +SEL_CHANGED+:: sent continuously while a resize operation is occurring
|
22
|
+
#
|
23
|
+
# === Splitter options
|
24
|
+
#
|
25
|
+
# +FOURSPLITTER_TRACKING+:: Track continuously during split
|
26
|
+
# +FOURSPLITTER_NORMAL+:: Normal mode (no continuous tracking)
|
27
|
+
#
|
28
|
+
# === Expansion options
|
29
|
+
#
|
30
|
+
# +ExpandNone+:: None expanded
|
31
|
+
# +ExpandTopLeft+:: Expand top left child
|
32
|
+
# +ExpandTopRight+:: Expand top right child
|
33
|
+
# +ExpandBottomLeft+:: Expand bottom left child
|
34
|
+
# +ExpandBottomRight+:: Expand bottom right child
|
35
|
+
# +ExpandTop+:: Expand top children
|
36
|
+
# +ExpandBottom+:: Expand bottom children
|
37
|
+
# +ExpandLeft+:: Expand left children
|
38
|
+
# +ExpandRight+:: Expand right children
|
39
|
+
# +ExpandAll+:: Expand all children
|
40
|
+
#
|
41
|
+
# === Message identifiers
|
42
|
+
#
|
43
|
+
# +ID_EXPAND_NONE+:: None expanded
|
44
|
+
# +ID_EXPAND_TOP+:: Expand top left and top right panes
|
45
|
+
# +ID_EXPAND_BOTTOM+:: Expand bottom left and bottom right panes
|
46
|
+
# +ID_EXPAND_LEFT+:: Expand leftmost panes
|
47
|
+
# +ID_EXPAND_RIGHT+:: Expand rightmost panes
|
48
|
+
# +ID_EXPAND_TOPLEFT+:: Expand top left pane
|
49
|
+
# +ID_EXPAND_TOPRIGHT+:: Expand top right pane
|
50
|
+
# +ID_EXPAND_BOTTOMLEFT+:: Expand bottom left pane
|
51
|
+
# +ID_EXPAND_BOTTOMRIGHT+:: Expand bottom right pane
|
52
|
+
# +ID_EXPAND_ALL+:: Expand all panes
|
53
|
+
#
|
54
|
+
class FX4Splitter < FXComposite
|
55
|
+
|
56
|
+
# Horizontal split fraction [Integer]
|
57
|
+
attr_accessor :hSplit
|
58
|
+
|
59
|
+
# Vertical split fraction [Integer]
|
60
|
+
attr_accessor :vSplit
|
61
|
+
|
62
|
+
# Current splitter style, either +FOURSPLITTER_TRACKING+ or +FOURSPLITTER_NORMAL+
|
63
|
+
attr_accessor :splitterStyle
|
64
|
+
|
65
|
+
# Splitter bar width, in pixels [Integer]
|
66
|
+
attr_accessor :barSize
|
67
|
+
|
68
|
+
# Currently expanded child (some combination of the expansion flags, or zero if no panes are expanded)
|
69
|
+
attr_accessor :expanded
|
70
|
+
|
71
|
+
# Top left child window, if any [FXWindow]
|
72
|
+
attr_reader :topLeft
|
73
|
+
|
74
|
+
# Top right child window, if any [FXWindow]
|
75
|
+
attr_reader :topRight
|
76
|
+
|
77
|
+
# Bottom left child window, if any [FXWindow]
|
78
|
+
attr_reader :bottomLeft
|
79
|
+
|
80
|
+
# Bottom right child window, if any [FXWindow]
|
81
|
+
attr_reader :bottomRight
|
82
|
+
|
83
|
+
#
|
84
|
+
# Return an initialized FX4Splitter instance, initially shown as four unexpanded panes
|
85
|
+
#
|
86
|
+
# ==== Parameters:
|
87
|
+
#
|
88
|
+
# +p+:: the parent widget for this splitter [FXComposite]
|
89
|
+
# +opts+:: the options [Integer]
|
90
|
+
# +x+:: initial x-position [Integer]
|
91
|
+
# +y+:: initial y-position [Integer]
|
92
|
+
# +width+:: initial width [Integer]
|
93
|
+
# +height+:: initial height [Integer]
|
94
|
+
#
|
95
|
+
def initialize(p, opts=FOURSPLITTER_NORMAL, x=0, y=0, width=0, height=0) # :yields: theSplitter
|
96
|
+
end
|
97
|
+
|
98
|
+
#
|
99
|
+
# Return an initialized FX4Splitter instance, initially shown as four unexpanded panes;
|
100
|
+
# notifies _tgt_ about size changes.
|
101
|
+
#
|
102
|
+
# ==== Parameters:
|
103
|
+
#
|
104
|
+
# +p+:: the parent widget for this splitter [FXComposite]
|
105
|
+
# +target+:: message target [FXObject]
|
106
|
+
# +selector+:: message identifier [Integer]
|
107
|
+
# +opts+:: the options [Integer]
|
108
|
+
# +x+:: initial x-position [Integer]
|
109
|
+
# +y+:: initial y-position [Integer]
|
110
|
+
# +width+:: initial width [Integer]
|
111
|
+
# +height+:: initial height [Integer]
|
112
|
+
#
|
113
|
+
def initialize(p, tgt, sel, opts=FOURSPLITTER_NORMAL, x=0, y=0, width=0, height=0) # :yields: theSplitter
|
114
|
+
end
|
115
|
+
|
116
|
+
#
|
117
|
+
# Change horizontal split fraction. The split fraction _s_ is
|
118
|
+
# an integer value between 0 and 10000 (inclusive), indicating
|
119
|
+
# how much space to allocate to the leftmost panes. For example,
|
120
|
+
# to split the panes at 35 percent, use:
|
121
|
+
#
|
122
|
+
# fourSplitter.setHSplit(3500)
|
123
|
+
#
|
124
|
+
# or just:
|
125
|
+
#
|
126
|
+
# fourSplitter.hSplit = 3500
|
127
|
+
#
|
128
|
+
def setHSplit(s); end
|
129
|
+
|
130
|
+
#
|
131
|
+
# Return the horizontal split fraction, an integer between 0 and
|
132
|
+
# 10000 inclusive. See FX4Splitter#setHSplit for more information.
|
133
|
+
#
|
134
|
+
def getHSplit(); end
|
135
|
+
|
136
|
+
#
|
137
|
+
# Change vertical split fraction. The split fraction _s_ is
|
138
|
+
# an integer value between 0 and 10000 (inclusive), indicating
|
139
|
+
# how much space to allocate to the topmost panes. For example,
|
140
|
+
# to split the panes at 35 percent, use:
|
141
|
+
#
|
142
|
+
# fourSplitter.setVSplit(3500)
|
143
|
+
#
|
144
|
+
# or just:
|
145
|
+
#
|
146
|
+
# fourSplitter.vSplit = 3500
|
147
|
+
#
|
148
|
+
def setVSplit(s); end
|
149
|
+
|
150
|
+
#
|
151
|
+
# Return the vertical split fraction, an integer between 0 and
|
152
|
+
# 10000 inclusive. See FX4Splitter#setVSplit for more information.
|
153
|
+
#
|
154
|
+
def getVSplit(); end
|
155
|
+
end
|
156
|
+
end
|
@@ -0,0 +1,54 @@
|
|
1
|
+
module Fox
|
2
|
+
#
|
3
|
+
# Seven-segment (eg LCD/watch style) widget, useful for making
|
4
|
+
# indicators and timers. Besides numbers, the seven-segment
|
5
|
+
# display widget can also display some letters and punctuations.
|
6
|
+
#
|
7
|
+
# === 7 Segment styles
|
8
|
+
#
|
9
|
+
# +SEVENSEGMENT_NORMAL+:: Draw segments normally
|
10
|
+
# +SEVENSEGMENT_SHADOW+:: Draw shadow under the segments
|
11
|
+
#
|
12
|
+
class FX7Segment < FXFrame
|
13
|
+
# The text for this label [String]
|
14
|
+
attr_accessor :text
|
15
|
+
|
16
|
+
# The text color [FXColor]
|
17
|
+
attr_accessor :textColor
|
18
|
+
|
19
|
+
# Cell width, in pixels [Integer]
|
20
|
+
attr_accessor :cellWidth
|
21
|
+
|
22
|
+
# Cell height, in pixels [Integer]
|
23
|
+
attr_accessor :cellHeight
|
24
|
+
|
25
|
+
# Segment thickness, in pixels [Integer]
|
26
|
+
attr_accessor :thickness
|
27
|
+
|
28
|
+
# Current text-justification mode [Integer]
|
29
|
+
attr_accessor :justify
|
30
|
+
|
31
|
+
# Status line help text [String]
|
32
|
+
attr_accessor :helpText
|
33
|
+
|
34
|
+
# Tool tip message [String]
|
35
|
+
attr_accessor :tipText
|
36
|
+
|
37
|
+
# Create a seven segment display
|
38
|
+
def initialize(p, text, opts=SEVENSEGMENT_NORMAL, x=0, y=0, width=0, height=0, padLeft=DEFAULT_PAD, padRight=DEFAULT_PAD, padTop=DEFAULT_PAD, padBottom=DEFAULT_PAD) # :yields: the7Segment
|
39
|
+
end
|
40
|
+
|
41
|
+
#
|
42
|
+
# Change 7 segment style, where _style_ is either +SEVENSEGMENT_NORMAL+ or
|
43
|
+
# +SEVENSEGMENT_SHADOW+.
|
44
|
+
#
|
45
|
+
def set7SegmentStyle(style); end
|
46
|
+
|
47
|
+
#
|
48
|
+
# Return the current 7 segment style, which is either +SEVENSEGMENT_NORMAL+
|
49
|
+
# or +SEVENSEGMENT_SHADOW+.
|
50
|
+
#
|
51
|
+
def get7SegmentStyle(); end
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
@@ -0,0 +1,102 @@
|
|
1
|
+
module Fox
|
2
|
+
#
|
3
|
+
# The accelerator table sends a message to a specific
|
4
|
+
# target object when the indicated key and modifier combination
|
5
|
+
# is pressed.
|
6
|
+
#
|
7
|
+
class FXAccelTable < FXObject
|
8
|
+
#
|
9
|
+
# Construct empty accelerator table.
|
10
|
+
#
|
11
|
+
def initialize # :yields: acceleratorTable
|
12
|
+
end
|
13
|
+
|
14
|
+
#
|
15
|
+
# Add an accelerator to the table. The _hotKey_ is a code returned
|
16
|
+
# by the Fox.fxparseAccel method. For example, to associate the
|
17
|
+
# Ctrl+S keypress with sending a "save" command to a document, you
|
18
|
+
# might use code like this:
|
19
|
+
#
|
20
|
+
# hotKey = fxparseAccel("Ctrl+S")
|
21
|
+
# accelTable.addAccel(hotKey, doc, FXSEL(SEL_COMMAND, MyDocument::ID_SAVE))
|
22
|
+
#
|
23
|
+
# ==== Parameters:
|
24
|
+
#
|
25
|
+
# +hotKey+:: the hotkey associated with this accelerator [Integer]
|
26
|
+
# +target+:: message target [FXObject]
|
27
|
+
# +seldn+:: selector for the +SEL_KEYPRESS+ event [Integer]
|
28
|
+
# +selup+:: selector for the +SEL_KEYRELEASE+ event [Integer]
|
29
|
+
#
|
30
|
+
def addAccel(hotKey, target=nil, seldn=0, selup=0) ; end
|
31
|
+
|
32
|
+
#
|
33
|
+
# Remove an accelerator from the table.
|
34
|
+
#
|
35
|
+
def removeAccel(hotKey) ; end
|
36
|
+
|
37
|
+
#
|
38
|
+
# Return +true+ if accelerator specified.
|
39
|
+
# Here, _hotKey_ is a code representing an accelerator key as returned
|
40
|
+
# by the Fox.fxparseAccel method. For example,
|
41
|
+
#
|
42
|
+
# if accelTable.hasAccel?(fxparseAccel("Ctrl+S"))
|
43
|
+
# ...
|
44
|
+
# end
|
45
|
+
#
|
46
|
+
def hasAccel?(hotKey) ; end
|
47
|
+
|
48
|
+
#
|
49
|
+
# Return the target object of the given accelerator, or +nil+ if
|
50
|
+
# the accelerator is not present in this accelerator table.
|
51
|
+
# Here, _hotKey_ is a code representing an accelerator key as returned
|
52
|
+
# by the Fox.fxparseAccel method. For example,
|
53
|
+
#
|
54
|
+
# doc = accelTable.targetofAccel(fxparseAccel("Ctrl+S"))
|
55
|
+
#
|
56
|
+
def targetOfAccel(hotKey) ; end
|
57
|
+
|
58
|
+
#
|
59
|
+
# Remove mapping for specified hot key.
|
60
|
+
# Here, _hotKey_ is a code representing an accelerator key as returned
|
61
|
+
# by the Fox.fxparseAccel method. For example,
|
62
|
+
#
|
63
|
+
# accelTable.removeAccel(fxparseAccel("Ctrl+S"))
|
64
|
+
#
|
65
|
+
def removeAccel(hotKey) ; end
|
66
|
+
end
|
67
|
+
|
68
|
+
#
|
69
|
+
# Parse accelerator from string, yielding modifier and
|
70
|
+
# key code. For example, parseAccel("Ctl+Shift+X")
|
71
|
+
# yields MKUINT(KEY_X,CONTROLMASK|SHIFTMASK).
|
72
|
+
#
|
73
|
+
def parseAccel(string); end
|
74
|
+
|
75
|
+
#
|
76
|
+
# Unparse hot key comprising modifier and key code back
|
77
|
+
# into a string suitable for parsing with #parseHotKey.
|
78
|
+
#
|
79
|
+
def unparseAccel(key); end
|
80
|
+
|
81
|
+
#
|
82
|
+
# Parse hot key from string, yielding modifier and
|
83
|
+
# key code. For example, parseHotKey(""Salt && &Pepper!"")
|
84
|
+
# yields MKUINT(KEY_p,ALTMASK).
|
85
|
+
#
|
86
|
+
def parseHotKey(string); end
|
87
|
+
|
88
|
+
#
|
89
|
+
# Obtain hot key offset in string, or -1 if not found.
|
90
|
+
# For example, findHotKey("Salt && &Pepper!") yields 7.
|
91
|
+
# Note that this is the byte-offset, not the character
|
92
|
+
# index!
|
93
|
+
#
|
94
|
+
def findHotKey(string); end
|
95
|
+
|
96
|
+
#
|
97
|
+
# Strip hot key combination from the string.
|
98
|
+
# For example, stripHotKey("Salt && &Pepper") should
|
99
|
+
# yield "Salt & Pepper".
|
100
|
+
#
|
101
|
+
def stripHotKey(string); end
|
102
|
+
end
|
@@ -0,0 +1,545 @@
|
|
1
|
+
module Fox
|
2
|
+
# FOX Event
|
3
|
+
class FXEvent
|
4
|
+
|
5
|
+
# Event type [Integer]
|
6
|
+
attr_reader :type
|
7
|
+
|
8
|
+
# Time of last event [Integer]
|
9
|
+
attr_reader :time
|
10
|
+
|
11
|
+
# Window-relative x-coordinate [Integer]
|
12
|
+
attr_reader :win_x
|
13
|
+
|
14
|
+
# Window-relative y-coordinate [Integer]
|
15
|
+
attr_reader :win_y
|
16
|
+
|
17
|
+
# Root window x-coordinate [Integer]
|
18
|
+
attr_reader :root_x
|
19
|
+
|
20
|
+
# Root window y-coordinate [Integer]
|
21
|
+
attr_reader :root_y
|
22
|
+
|
23
|
+
# Keyboard/modifier state [Integer]
|
24
|
+
attr_reader :state
|
25
|
+
|
26
|
+
# Button, keysym or mode; DDE source [Integer]
|
27
|
+
attr_reader :code
|
28
|
+
|
29
|
+
# Text of keyboard event [String]
|
30
|
+
attr_reader :text
|
31
|
+
|
32
|
+
# Window-relative x-coordinate of previous mouse location [Integer]
|
33
|
+
attr_reader :last_x
|
34
|
+
|
35
|
+
# Window-relative y-coordinate of previous mouse location [Integer]
|
36
|
+
attr_reader :last_y
|
37
|
+
|
38
|
+
# Window-relative x-coordinate of mouse press [Integer]
|
39
|
+
attr_reader :click_x
|
40
|
+
|
41
|
+
# Window-relative y-coordinate of mouse press [Integer]
|
42
|
+
attr_reader :click_y
|
43
|
+
|
44
|
+
# Root window x-coordinate of mouse press [Integer]
|
45
|
+
attr_reader :rootclick_x
|
46
|
+
|
47
|
+
# Root window y-coordinate of mouse press [Integer]
|
48
|
+
attr_reader :rootclick_y
|
49
|
+
|
50
|
+
# Time of mouse button press [Integer]
|
51
|
+
attr_reader :click_time
|
52
|
+
|
53
|
+
# Mouse button pressed [Integer]
|
54
|
+
attr_reader :click_button
|
55
|
+
|
56
|
+
# Click count [Integer]
|
57
|
+
attr_reader :click_count
|
58
|
+
|
59
|
+
# Target drag type being requested [Integer]
|
60
|
+
attr_reader :target
|
61
|
+
|
62
|
+
# Return true if cursor moved since last press
|
63
|
+
def moved? ; end
|
64
|
+
|
65
|
+
# Exposed rectangle for paint events
|
66
|
+
def rect ; end
|
67
|
+
|
68
|
+
# Return true if this is a synthetic expose event
|
69
|
+
def synthetic? ; end
|
70
|
+
end
|
71
|
+
|
72
|
+
#
|
73
|
+
# Application Object
|
74
|
+
#
|
75
|
+
# === Events
|
76
|
+
#
|
77
|
+
# The FXApp object itself doesn't have a designated message target like
|
78
|
+
# other FOX objects, but it can send messages to objects for a few
|
79
|
+
# special events.
|
80
|
+
#
|
81
|
+
# [*Timers*]
|
82
|
+
# When a timeout event is registered with the application using the
|
83
|
+
# addTimeout method, a +SEL_TIMEOUT+ message is sent to the message
|
84
|
+
# target.
|
85
|
+
# [*Chores*]
|
86
|
+
# When a chore event is registered with the application using the
|
87
|
+
# addChore method, a +SEL_CHORE+ message is sent to the message target.
|
88
|
+
# [*Inputs*]
|
89
|
+
# When an input event is registered with the application using the
|
90
|
+
# addInput method, a +SEL_IO_READ+, +SEL_IO_WRITE+ or +SEL_IO_EXCEPT+
|
91
|
+
# message may be sent to the message target.
|
92
|
+
# [*Signals*]
|
93
|
+
# When a signal handler object is registered with the application using
|
94
|
+
# the addSignal method, a +SEL_SIGNAL+ message may be sent to the message
|
95
|
+
# target.
|
96
|
+
#
|
97
|
+
# === File input modes for #addInput
|
98
|
+
#
|
99
|
+
# +INPUT_NONE+:: inactive
|
100
|
+
# +INPUT_READ+:: read input fd
|
101
|
+
# +INPUT_WRITE+:: write input fd
|
102
|
+
# +INPUT_EXCEPT+:: except input fd
|
103
|
+
#
|
104
|
+
# === All ways of being modal
|
105
|
+
#
|
106
|
+
# +MODAL_FOR_NONE+:: Non modal event loop (dispatch normally)
|
107
|
+
# +MODAL_FOR_WINDOW+:: Modal dialog (beep if outside of modal dialog)
|
108
|
+
# +MODAL_FOR_POPUP+:: Modal for popup (always dispatch to popup)
|
109
|
+
#
|
110
|
+
# === Default cursors provided by the application
|
111
|
+
#
|
112
|
+
# These constants symbolically represent the different cursor shapes used
|
113
|
+
# in FOX applications, and can be used as the _which_ arguments for
|
114
|
+
# #getDefaultCursor and #setDefaultCursor.
|
115
|
+
#
|
116
|
+
# +DEF_ARROW_CURSOR+:: Arrow cursor
|
117
|
+
# +DEF_RARROW_CURSOR+:: Reverse arrow cursor
|
118
|
+
# +DEF_TEXT_CURSOR+:: Text cursor
|
119
|
+
# +DEF_HSPLIT_CURSOR+:: Horizontal split cursor
|
120
|
+
# +DEF_VSPLIT_CURSOR+:: Vertical split cursor
|
121
|
+
# +DEF_XSPLIT_CURSOR+:: Cross split cursor
|
122
|
+
# +DEF_SWATCH_CURSOR+:: Color swatch drag cursor
|
123
|
+
# +DEF_MOVE_CURSOR+:: Move cursor
|
124
|
+
# +DEF_DRAGH_CURSOR+:: Resize horizontal edge
|
125
|
+
# +DEF_DRAGV_CURSOR+:: Resize vertical edge
|
126
|
+
# +DEF_DRAGTL_CURSOR+:: Resize upper-leftcorner
|
127
|
+
# +DEF_DRAGBR_CURSOR+:: Resize bottom-right corner
|
128
|
+
# +DEF_DRAGTR_CURSOR+:: Resize upper-right corner
|
129
|
+
# +DEF_DRAGBL_CURSOR+:: Resize bottom-left corner
|
130
|
+
# +DEF_DNDSTOP_CURSOR+:: Drag and drop stop
|
131
|
+
# +DEF_DNDCOPY_CURSOR+:: Drag and drop copy
|
132
|
+
# +DEF_DNDMOVE_CURSOR+:: Drag and drop move
|
133
|
+
# +DEF_DNDLINK_CURSOR+:: Drag and drop link
|
134
|
+
# +DEF_CROSSHAIR_CURSOR+:: Cross hair cursor
|
135
|
+
# +DEF_CORNERNE_CURSOR+:: North-east cursor
|
136
|
+
# +DEF_CORNERNW_CURSOR+:: North-west cursor
|
137
|
+
# +DEF_CORNERSE_CURSOR+:: South-east cursor
|
138
|
+
# +DEF_CORNERSW_CURSOR+:: South-west cursor
|
139
|
+
# +DEF_HELP_CURSOR+:: Help arrow cursor
|
140
|
+
# +DEF_HAND_CURSOR+:: Hand cursor
|
141
|
+
# +DEF_ROTATE_CURSOR+:: Rotate cursor
|
142
|
+
# +DEF_WAIT_CURSOR+:: Wait cursor
|
143
|
+
#
|
144
|
+
# === Messages identifiers
|
145
|
+
#
|
146
|
+
# +ID_QUIT+:: Terminate the application normally
|
147
|
+
# +ID_DUMP+:: Dump the current widget tree
|
148
|
+
|
149
|
+
class FXApp < FXObject
|
150
|
+
|
151
|
+
# Application name [String]
|
152
|
+
attr_reader :appName
|
153
|
+
|
154
|
+
# Vendor name [String]
|
155
|
+
attr_reader :vendorName
|
156
|
+
|
157
|
+
# Argument count [Integer]
|
158
|
+
attr_reader :argc
|
159
|
+
|
160
|
+
# Argument vector [Array]
|
161
|
+
attr_reader :argv
|
162
|
+
|
163
|
+
# Display [Integer]
|
164
|
+
attr_reader :display
|
165
|
+
|
166
|
+
# Border color [FXColor]
|
167
|
+
attr_accessor :borderColor
|
168
|
+
|
169
|
+
# Background color of GUI controls [FXColor]
|
170
|
+
attr_accessor :baseColor
|
171
|
+
|
172
|
+
# Hilite color of GUI controls [FXColor]
|
173
|
+
attr_accessor :hiliteColor
|
174
|
+
|
175
|
+
# Shadow color of GUI controls [FXColor]
|
176
|
+
attr_accessor :shadowColor
|
177
|
+
|
178
|
+
# Default background color [FXColor]
|
179
|
+
attr_accessor :backColor
|
180
|
+
|
181
|
+
# Default foreground color [FXColor]
|
182
|
+
attr_accessor :foreColor
|
183
|
+
|
184
|
+
# Default foreground color for selected objects [FXColor]
|
185
|
+
attr_accessor :selforeColor
|
186
|
+
|
187
|
+
# Default background color for selected objects [FXColor]
|
188
|
+
attr_accessor :selbackColor
|
189
|
+
|
190
|
+
# Default foreground color for tooltips [FXColor]
|
191
|
+
attr_accessor :tipforeColor
|
192
|
+
|
193
|
+
# Default background color for tooltips [FXColor]
|
194
|
+
attr_accessor :tipbackColor
|
195
|
+
|
196
|
+
# Default text color for selected menu items [FXColor]
|
197
|
+
attr_accessor :selMenuTextColor
|
198
|
+
|
199
|
+
# Default background color for selected menu items [FXColor]
|
200
|
+
attr_accessor :selMenuBackColor
|
201
|
+
|
202
|
+
# Default visual [FXVisual]
|
203
|
+
attr_accessor :defaultVisual
|
204
|
+
|
205
|
+
# Default font [FXFont]
|
206
|
+
attr_accessor :normalFont
|
207
|
+
|
208
|
+
# Wait cursor [FXCursor]
|
209
|
+
attr_accessor :waitCursor
|
210
|
+
|
211
|
+
# Monochrome visual [FXVisual]
|
212
|
+
attr_reader :monoVisual
|
213
|
+
|
214
|
+
# Root window [FXRootWindow]
|
215
|
+
attr_reader :rootWindow
|
216
|
+
|
217
|
+
# The window under the cursor, if any [FXWindow]
|
218
|
+
attr_reader :cursorWindow
|
219
|
+
|
220
|
+
# The window at the end of the focus chain, if any [FXWindow]
|
221
|
+
attr_reader :focusWindow
|
222
|
+
|
223
|
+
# The active top-level window, if any [FXWindow]
|
224
|
+
attr_reader :activeWindow
|
225
|
+
|
226
|
+
# The main window, if any [FXWindow]
|
227
|
+
attr_reader :mainWindow
|
228
|
+
|
229
|
+
# The window of the current modal loop [FXWindow]
|
230
|
+
attr_reader :modalWindow
|
231
|
+
|
232
|
+
# Mode of current modal loop [Integer]
|
233
|
+
attr_reader :modalModality
|
234
|
+
|
235
|
+
# Typing speed used for the FXIconList, FXList and FXTreeList widgets' lookup features,
|
236
|
+
# in milliseconds. Default value is 1000 milliseconds.
|
237
|
+
attr_accessor :typingSpeed
|
238
|
+
|
239
|
+
# Click speed, in milliseconds [Integer]
|
240
|
+
attr_accessor :clickSpeed
|
241
|
+
|
242
|
+
# Scroll speed, in milliseconds [Integer]
|
243
|
+
attr_accessor :scrollSpeed
|
244
|
+
|
245
|
+
# Scroll delay time, in milliseconds [Integer]
|
246
|
+
attr_accessor :scrollDelay
|
247
|
+
|
248
|
+
# Blink speed, in milliseconds [Integer]
|
249
|
+
attr_accessor :blinkSpeed
|
250
|
+
|
251
|
+
# Animation speed, in milliseconds [Integer]
|
252
|
+
attr_accessor :animSpeed
|
253
|
+
|
254
|
+
# Menu pause, in milliseconds [Integer]
|
255
|
+
attr_accessor :menuPause
|
256
|
+
|
257
|
+
# Tooltip pause, in milliseconds [Integer]
|
258
|
+
attr_accessor :tooltipPause
|
259
|
+
|
260
|
+
# Tooltip time, in milliseconds [Integer]
|
261
|
+
attr_accessor :tooltipTime
|
262
|
+
|
263
|
+
# Drag delta, in pixels [Integer]
|
264
|
+
attr_accessor :dragDelta
|
265
|
+
|
266
|
+
# Number of wheel lines [Integer]
|
267
|
+
attr_accessor :wheelLines
|
268
|
+
|
269
|
+
# Scroll bar size [Integer]
|
270
|
+
attr_accessor :scrollBarSize
|
271
|
+
|
272
|
+
# Amount of time (in milliseconds) to yield to Ruby's thread scheduler [Integer]
|
273
|
+
attr_accessor :sleepTime
|
274
|
+
|
275
|
+
# Message translator [FXTranslator]
|
276
|
+
attr_accessor :translator
|
277
|
+
|
278
|
+
# Copyright notice for library
|
279
|
+
def FXApp.copyright() ; end
|
280
|
+
|
281
|
+
#
|
282
|
+
# Construct application object; the _appName_ and _vendorName_ strings are used
|
283
|
+
# as keys into the registry database for this application's settings.
|
284
|
+
# Only one single application object can be constructed.
|
285
|
+
#
|
286
|
+
def initialize(appName="Application", vendorName="FoxDefault") # :yields: theApp
|
287
|
+
end
|
288
|
+
|
289
|
+
#
|
290
|
+
# Open connection to display; this is called by #init.
|
291
|
+
#
|
292
|
+
def openDisplay(dpyname=nil) ; end
|
293
|
+
|
294
|
+
# Close connection to the display
|
295
|
+
def closeDisplay() ; end
|
296
|
+
|
297
|
+
# Return true if the application has been initialized.
|
298
|
+
def initialized?; end
|
299
|
+
|
300
|
+
# Return +true+ if input methods are supported.
|
301
|
+
def hasInputMethod?; end
|
302
|
+
|
303
|
+
#
|
304
|
+
# Process any timeouts due at this time.
|
305
|
+
#
|
306
|
+
def handleTimeouts(); end
|
307
|
+
|
308
|
+
#
|
309
|
+
# Add signal processing message to be sent to target object when
|
310
|
+
# the signal _sig_ is raised; flags are to be set as per POSIX definitions.
|
311
|
+
# When _immediate_ is +true+, the message will be sent to the target right away;
|
312
|
+
# this should be used with extreme care as the application is interrupted
|
313
|
+
# at an unknown point in its execution.
|
314
|
+
#
|
315
|
+
def addSignal(sig, tgt, sel, immediate=false, flags=0) ; end
|
316
|
+
|
317
|
+
#
|
318
|
+
# Remove signal message for signal _sig_.
|
319
|
+
#
|
320
|
+
def removeSignal(sig) ; end
|
321
|
+
|
322
|
+
#
|
323
|
+
# Remove input message and target object for the specified file descriptor
|
324
|
+
# and mode, which is a bitwise OR of (+INPUT_READ+, +INPUT_WRITE+, +INPUT_EXCEPT+).
|
325
|
+
#
|
326
|
+
def removeInput(fd, mode) ; end
|
327
|
+
|
328
|
+
# Create application's windows
|
329
|
+
def create() ; end
|
330
|
+
|
331
|
+
# Destroy application's windows
|
332
|
+
def destroy() ; end
|
333
|
+
|
334
|
+
# Detach application's windows
|
335
|
+
def detach() ; end
|
336
|
+
|
337
|
+
#
|
338
|
+
# Return key state (either +true+ or +false+) for _keysym_.
|
339
|
+
#
|
340
|
+
def getKeyState(keysym); end
|
341
|
+
|
342
|
+
#
|
343
|
+
# Peek to determine if there's an event.
|
344
|
+
#
|
345
|
+
def peekEvent(); end
|
346
|
+
|
347
|
+
# Perform one event dispatch; return +true+ if event was dispatched.
|
348
|
+
def runOneEvent(blocking=true); end
|
349
|
+
|
350
|
+
# Run the main application event loop until #stop is called,
|
351
|
+
# and return the exit code passed as argument to #stop.
|
352
|
+
def run(); end
|
353
|
+
|
354
|
+
#
|
355
|
+
# Run an event loop till some flag becomes non-zero, and
|
356
|
+
# then return.
|
357
|
+
#
|
358
|
+
def runUntil(condition); end
|
359
|
+
|
360
|
+
#
|
361
|
+
# Run event loop while events are available, non-modally.
|
362
|
+
# Return when no more events, timers, or chores are outstanding.
|
363
|
+
#
|
364
|
+
def runWhileEvents(); end
|
365
|
+
|
366
|
+
#
|
367
|
+
# Run event loop while there are events are available in the queue.
|
368
|
+
# Returns 1 when all events in the queue have been handled, and 0 when
|
369
|
+
# the event loop was terminated due to #stop or #stopModal.
|
370
|
+
# Except for the modal window and its children, user input to all windows
|
371
|
+
# is blocked; if the modal window is +nil+, all user input is blocked.
|
372
|
+
#
|
373
|
+
def runModalWhileEvents(window=nil); end
|
374
|
+
|
375
|
+
# Run modal event loop, blocking keyboard and mouse events to all windows
|
376
|
+
# until #stopModal is called.
|
377
|
+
def runModal(); end
|
378
|
+
|
379
|
+
# Run a modal event loop for the given window, until #stop or #stopModal is
|
380
|
+
# called. Except for the modal window and its children, user input to all
|
381
|
+
# windows is blocked; if the modal window is +nil+ all user input is blocked.
|
382
|
+
def runModalFor(window); end
|
383
|
+
|
384
|
+
# Run modal while window is shown, or until #stop or #stopModal is called.
|
385
|
+
# Except for the modal window and its children, user input to all windows
|
386
|
+
# is blocked; if the modal window is +nil+ all user input is blocked.
|
387
|
+
def runModalWhileShown(window); end
|
388
|
+
|
389
|
+
# Run popup menu while shown, until #stop or #stopModal is called.
|
390
|
+
# Also returns when entering previous cascading popup menu.
|
391
|
+
def runPopup(window); end
|
392
|
+
|
393
|
+
# Returns +true+ if the window is modal
|
394
|
+
def modal?(window) ; end
|
395
|
+
|
396
|
+
# Terminate the outermost event loop, and all inner modal loops;
|
397
|
+
# All more deeper nested event loops will be terminated with code equal
|
398
|
+
# to 0, while the outermost event loop will return code equal to _value_.
|
399
|
+
def stop(value=0); end
|
400
|
+
|
401
|
+
#
|
402
|
+
# Break out of the matching modal loop, returning code equal to _value_.
|
403
|
+
# All deeper nested event loops are terminated with code equal to 0.
|
404
|
+
#
|
405
|
+
def stopModal(window, value=0); end
|
406
|
+
|
407
|
+
#
|
408
|
+
# Break out of the innermost modal loop, returning code equal to _value_.
|
409
|
+
#
|
410
|
+
def stopModal(value=0); end
|
411
|
+
|
412
|
+
# Force GUI refresh
|
413
|
+
def forceRefresh(); end
|
414
|
+
|
415
|
+
# Schedule a refresh
|
416
|
+
def refresh(); end
|
417
|
+
|
418
|
+
# Flush pending repaints
|
419
|
+
def flush(sync=false); end
|
420
|
+
|
421
|
+
# Paint all windows marked for repainting.
|
422
|
+
# On return all the applications windows have been painted.
|
423
|
+
def repaint(); end
|
424
|
+
|
425
|
+
#
|
426
|
+
# Return a reference to the registry (an FXRegistry instance).
|
427
|
+
# The registry keeps settings and configuration information for an application,
|
428
|
+
# which are automatically loaded when the application starts
|
429
|
+
# up, and saved when the application terminates.
|
430
|
+
#
|
431
|
+
def reg; end
|
432
|
+
|
433
|
+
# Initialize application.
|
434
|
+
# Parses and removes common command line arguments, reads the registry.
|
435
|
+
# Finally, if _connect_ is +true+, it opens the display.
|
436
|
+
def init(argv, connect=true) ; end
|
437
|
+
|
438
|
+
# Exit application.
|
439
|
+
# Closes the display and writes the registry.
|
440
|
+
def exit(code=0); end
|
441
|
+
|
442
|
+
#
|
443
|
+
# Register a drag type with the given name and return the drag
|
444
|
+
# drag type. If this drag type has already been registered, this
|
445
|
+
# method will return the previously returned drag type. For example,
|
446
|
+
#
|
447
|
+
# yamlDragType = app.registerDragType("application/x-yaml")
|
448
|
+
#
|
449
|
+
# See also #getDragTypeName.
|
450
|
+
#
|
451
|
+
def registerDragType(name) ; end
|
452
|
+
|
453
|
+
#
|
454
|
+
# Return the name of a previously registered drag type, e.g.
|
455
|
+
#
|
456
|
+
# dragTypeName = app.getDragTypeName(yamlDragType)
|
457
|
+
#
|
458
|
+
# See also #registerDragType.
|
459
|
+
#
|
460
|
+
def getDragTypeName(dragType) ; end
|
461
|
+
|
462
|
+
# Beep
|
463
|
+
def beep(); end
|
464
|
+
|
465
|
+
# Return application instance
|
466
|
+
def FXApp.instance(); end
|
467
|
+
|
468
|
+
# End the most deeply nested wait-cursor block.
|
469
|
+
# See also #beginWaitCursor.
|
470
|
+
def endWaitCursor(); end
|
471
|
+
|
472
|
+
#
|
473
|
+
# Return a reference to one of the default application cursors (an
|
474
|
+
# FXCursor instance), where _which_ is one of the default cursor
|
475
|
+
# identifiers listed above, e.g.
|
476
|
+
#
|
477
|
+
# rotateCursor = app.getDefaultCursor(DEF_ROTATE_CURSOR)
|
478
|
+
#
|
479
|
+
# See also #setDefaultCursor.
|
480
|
+
#
|
481
|
+
def getDefaultCursor(which) ; end
|
482
|
+
|
483
|
+
#
|
484
|
+
# Replace one of the default application cursors with _cursor_; e.g
|
485
|
+
#
|
486
|
+
# app.setDefaultCursor(DEF_ROTATE_CURSOR, myRotateCursor)
|
487
|
+
#
|
488
|
+
# See also #getDefaultCursor.
|
489
|
+
#
|
490
|
+
def setDefaultCursor(which, cursor); end
|
491
|
+
|
492
|
+
#
|
493
|
+
# Write a window and its children, and all resources reachable from this
|
494
|
+
# window, into the stream _store_ (an FXStream instance).
|
495
|
+
#
|
496
|
+
# ==== Parameters:
|
497
|
+
#
|
498
|
+
# +store+:: [FXStream]
|
499
|
+
# +window+:: [FXWindow]
|
500
|
+
#
|
501
|
+
def writeWindow(store, window); end
|
502
|
+
|
503
|
+
#
|
504
|
+
# Read a window and its children from the stream store, and append
|
505
|
+
# it under father; note it is initially not created yet.
|
506
|
+
# Return a reference to the new window.
|
507
|
+
#
|
508
|
+
# ==== Parameters:
|
509
|
+
#
|
510
|
+
# +store+:: [FXStream]
|
511
|
+
# +father+:: [FXWindow]
|
512
|
+
# +owner+:: [FXWindow]
|
513
|
+
#
|
514
|
+
def readWindow(store, father, owner); end
|
515
|
+
|
516
|
+
#
|
517
|
+
# Return a reference to the application-wide mutex (an FXMutex instance).
|
518
|
+
# Normally, the main user interface thread holds this mutex,
|
519
|
+
# insuring that no other threads are modifying data during the
|
520
|
+
# processing of user interface messages. However, whenever the
|
521
|
+
# main user interface thread blocks for messages, it releases
|
522
|
+
# this mutex, to allow other threads to modify the same data.
|
523
|
+
# When a new message becomes available, the main user interface
|
524
|
+
# thread regains the mutex prior to dispatching the message.
|
525
|
+
# Other threads should hold this mutex only for short durations,
|
526
|
+
# so as to not starve the main user interface thread.
|
527
|
+
#
|
528
|
+
def mutex(); end
|
529
|
+
|
530
|
+
# Dump widget information
|
531
|
+
def dumpWidgets() ; end
|
532
|
+
|
533
|
+
# Return the number of existing windows.
|
534
|
+
def windowCount; end
|
535
|
+
|
536
|
+
# Enable support for multithreaded applications
|
537
|
+
def enableThreads(); end
|
538
|
+
|
539
|
+
# Disable support for multithreaded applications
|
540
|
+
def disableThreads(); end
|
541
|
+
|
542
|
+
# Check to see if multithreaded applications are supported
|
543
|
+
def threadsEnabled?(); end
|
544
|
+
end
|
545
|
+
end
|